| 函数逻辑报告 | 
| Source Code: kernel\locking\rtmutex.c | Create Date:2022-07-27 10:52:28 | 
| Last Modify:2020-03-17 14:26:38 | Copyright©Brick | 
| 首页 | 函数Tree | 
| 注解内核,赢得工具 | 下载SCCT | English | 
函数名称:Task blocks on lock.* Prepare waiter and propagate pi chain* This must be called with lock->wait_lock held and interrupts disabled
函数原型:static int task_blocks_on_rt_mutex(struct rt_mutex *lock, struct rt_mutex_waiter *waiter, struct task_struct *task, enum rtmutex_chainwalk chwalk)
返回类型:int
参数:
| 类型 | 参数 | 名称 | 
|---|---|---|
| struct rt_mutex * | lock | |
| struct rt_mutex_waiter * | waiter | |
| struct task_struct * | task | |
| enum rtmutex_chainwalk | chwalk | 
| 933 | owner等于rt_mutex_owner(lock) | 
| 934 | top_waiter等于waiter | 
| 936 | chain_walk等于0 | 
| 938 | lockdep_assert_held( & 保护自旋锁) | 
| 961 | rt_mutex_enqueue(lock, waiter) | 
| 963 | pi_blocked_on等于waiter | 
| 967 | 如果非owner则返回:0 | 
| 971 | 如果waiter恒等于rt_mutex_top_waiter(lock)则 | 
| 973 | rt_mutex_enqueue_pi(owner, waiter) | 
| 976 | 如果pi_blocked_on则chain_walk等于1 | 
| 979 | chain_walk等于1 | 
| 991 | 如果非chain_walk或非next_lock则返回:0 | 
| 999 | get_task_struct(owner) | 
| 1001 | raw_spin_unlock_irq( & 保护自旋锁) | 
| 1003 | res等于Adjust the priority chain | 
| 1008 | 返回:res | 
| 名称 | 描述 | 
|---|---|
| rt_mutex_slowlock | Slow path lock function: | 
| __rt_mutex_start_proxy_lock | __rt_mutex_start_proxy_lock() - Start lock acquisition for another task*@lock: the rt_mutex to take*@waiter: the pre-initialized rt_mutex_waiter*@task: the task to prepare* Starts the rt_mutex acquire; it enqueues the @waiter and does deadlock* detection | 
| 源代码转换工具 开放的插件接口 | X | 
|---|---|
| 支持:c/c++/esqlc/java Oracle/Informix/Mysql 插件可实现:逻辑报告 代码生成和批量转换代码 |