函数逻辑报告 |
Source Code:fs\pipe.c |
Create Date:2022-07-29 10:34:20 |
Last Modify:2020-03-12 14:18:49 | Copyright©Brick |
首页 | 函数Tree |
注解内核,赢得工具 | 下载SCCT | English |
函数名称:fifo_open
函数原型:static int fifo_open(struct inode *inode, struct file *filp)
返回类型:int
参数:
类型 | 参数 | 名称 |
---|---|---|
struct inode * | inode | |
struct file * | filp |
1016 | is_pipe等于s_magic恒等于PIPEFS_MAGIC |
1019 | f_version等于0 |
1021 | 加自旋锁 |
1022 | 如果i_pipe则 |
1026 | 否则 |
1027 | 自旋锁解锁 |
1028 | pipe等于alloc_pipe_info() |
1031 | files等于1 |
1032 | 加自旋锁 |
1033 | 如果此条件成立可能性小(为编译器优化)(i_pipe)则 |
1038 | 否则 |
1046 | __pipe_lock(pipe) |
1052 | 当: & == le is open for reading |
1058 | r_counter自加 |
1059 | 如果readers自加恒等于0则wake_up_partner(pipe) |
1072 | 退出 |
1074 | 当: & == le is open for writing |
1081 | 如果非is_pipe且f_flags按位与O_NONBLOCK且非readers则转到:err |
1084 | w_counter自加 |
1085 | 如果非writers自加则wake_up_partner(pipe) |
1089 | 如果wait_for_partner(pipe, & r_counter)则转到:err_wr |
1092 | 退出 |
1094 | 当: & == le is open for reading | le is open for writing |
1102 | readers自加 |
1103 | writers自加 |
1104 | r_counter自加 |
1105 | w_counter自加 |
1106 | 如果readers恒等于1或writers恒等于1则wake_up_partner(pipe) |
1108 | 退出 |
1110 | 默认 |
1116 | __pipe_unlock(pipe) |
1117 | 返回:0 |
1119 | err_rd : |
1120 | 如果非readers先自减则wake_up_interruptible( & wait) |
1123 | 转到:err |
1125 | err_wr : |
1126 | 如果非writers先自减则wake_up_interruptible( & wait) |
1129 | 转到:err |
1131 | err : |
1132 | __pipe_unlock(pipe) |
1134 | put_pipe_info(inode, pipe) |
1135 | 返回:ret |
源代码转换工具 开放的插件接口 | X |
---|---|
支持:c/c++/esqlc/java Oracle/Informix/Mysql 插件可实现:逻辑报告 代码生成和批量转换代码 |