函数逻辑报告 | 
Source Code:kernel\workqueue.c | 
Create Date:2022-07-27 10:27:21 | 
| Last Modify:2020-03-12 14:18:49 | Copyright©Brick | 
| 首页 | 函数Tree | 
| 注解内核,赢得工具 | 下载SCCT | English | 
函数名称:start_flush_work
函数原型:static bool start_flush_work(struct work_struct *work, struct wq_barrier *barr, bool from_cancel)
返回类型:bool
参数:
| 类型 | 参数 | 名称 | 
|---|---|---|
| struct work_struct * | work | |
| struct wq_barrier * | barr | |
| bool | from_cancel | 
| 2976 | might_sleep() | 
| 2980 | 如果非pool则 | 
| 2985 | spin_lock_irq( & he pool lock ) | 
| 2987 | pwq等于get_work_pwq(work) | 
| 2988 | 如果pwq则 | 
| 2989 | 如果此条件成立可能性小(为编译器优化)(I: the associated pool != pool)则转到:already_gone | 
| 2991 | 否则 | 
| 2993 | 如果非worker则转到:already_gone | 
| 2995 | pwq等于L: current_work's pwq | 
| 3001 | spin_unlock_irq( & he pool lock ) | 
| 3012 | 如果非from_cancel且saved_max_active恒等于1或rescuer的值则 | 
| 3014 | lock_map_acquire( & lockdep_map) | 
| 3015 | lock_map_release( & lockdep_map) | 
| 3018 | 返回:true | 
| 3019 | already_gone : | 
| 3020 | spin_unlock_irq( & he pool lock ) | 
| 3022 | 返回:false | 
| 名称 | 描述 | 
|---|---|
| __flush_work | 
| 源代码转换工具 开放的插件接口  | X | 
|---|---|
| 支持:c/c++/esqlc/java Oracle/Informix/Mysql 插件可实现:逻辑报告 代码生成和批量转换代码  |