函数逻辑报告 |
Source Code:ipc\mqueue.c |
Create Date:2022-07-27 18:26:50 |
Last Modify:2020-03-17 23:00:47 | Copyright©Brick |
首页 | 函数Tree |
注解内核,赢得工具 | 下载SCCT | English |
函数名称:do_mq_timedreceive
函数原型:static int do_mq_timedreceive(mqd_t mqdes, char __user *u_msg_ptr, size_t msg_len, unsigned int __user *u_msg_prio, struct timespec64 *ts)
返回类型:int
参数:
类型 | 参数 | 名称 |
---|---|---|
mqd_t | mqdes | |
char __user * | u_msg_ptr | |
size_t | msg_len | |
unsigned int __user * | u_msg_prio | |
struct timespec64 * | ts |
1092 | struct posix_msg_tree_node * new_leaf = NULL |
1094 | 如果ts则 |
1099 | audit_mq_sendrecv(mqdes, msg_len, 0, ts) |
1102 | 如果此条件成立可能性小(为编译器优化)(!file)则 |
1107 | inode等于file_inode(file) |
1108 | 如果此条件成立可能性小(为编译器优化)(f_op != & mqueue_file_operations)则 |
1113 | audit_file(file) |
1115 | 如果此条件成立可能性小(为编译器优化)(!(f_mode & le is open for reading ))则 |
1121 | 如果此条件成立可能性小(为编译器优化)(msg_len < maximum message size )则 |
1131 | 如果非node_cache则new_leaf等于开辟内存 |
1134 | 加自旋锁 |
1136 | 如果非node_cache且new_leaf则 |
1138 | 初始化链表头 |
1139 | node_cache等于new_leaf |
1140 | 否则 |
1141 | 释放内存 |
1144 | 如果 number of messages currently queued 恒等于0则 |
1145 | 如果f_flags按位与O_NONBLOCK则 |
1148 | 否则 |
1154 | 否则 |
1168 | 如果ret恒等于0则 |
1169 | ret等于message text size |
1177 | out_fput : |
1179 | out : |
1180 | 返回:ret |
名称 | 描述 |
---|---|
SYSCALL_DEFINE5 |
源代码转换工具 开放的插件接口 | X |
---|---|
支持:c/c++/esqlc/java Oracle/Informix/Mysql 插件可实现:逻辑报告 代码生成和批量转换代码 |