函数逻辑报告 |
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 插件可实现:逻辑报告 代码生成和批量转换代码 |