Function report | 
Source Code:kernel\locking\osq_lock.c | 
Create Date:2022-07-28 09:51:16 | 
| Last Modify:2020-03-12 14:18:49 | Copyright©Brick | 
| home page | Tree | 
| Annotation kernel can get tool activity | Download SCCT | Chinese | 
Name:Get a stable @node->next pointer, either for unlock() or unqueue() purposes.* Can return NULL in case we were the last queued and we updated @lock instead.
Proto:static inline struct optimistic_spin_node *osq_wait_next(struct optimistic_spin_queue *lock, struct optimistic_spin_node *node, struct optimistic_spin_node *prev)
Type:struct optimistic_spin_node
Parameter:
| Type | Parameter | Name | 
|---|---|---|
| struct optimistic_spin_queue * | lock | |
| struct optimistic_spin_node * | node | |
| struct optimistic_spin_node * | prev | 
| 46 | struct optimistic_spin_node * next = NULL | 
| 47 | curr = We use the value 0 to represent "no CPU", thus the encoded value* will be the CPU number incremented by 1. | 
| 55 | old = If prev Then coded CPU # + 1 value Else OSQ_UNLOCKED_VAL | 
| 57 | cycle | 
| 65 | Break | 
| 78 | If next Then | 
| 84 | cpu_relax() | 
| 87 | Return next | 
| Name | Describe | 
|---|---|
| osq_lock | |
| osq_unlock | 
| Source code conversion tool public plug-in interface  | X | 
|---|---|
| Support c/c++/esqlc/java Oracle/Informix/Mysql Plug-in can realize: logical Report Code generation and batch code conversion  |