| 函数逻辑报告 | 
| Source Code: ipc\mqueue.c | Create Date:2022-07-27 18:26:41 | 
| Last Modify:2020-03-17 23:00:47 | Copyright©Brick | 
| 首页 | 函数Tree | 
| 注解内核,赢得工具 | 下载SCCT | English | 
函数名称:do_mq_timedsend
函数原型:static int do_mq_timedsend(mqd_t mqdes, const char __user *u_msg_ptr, size_t msg_len, unsigned int msg_prio, struct timespec64 *ts)
返回类型:int
参数:
| 类型 | 参数 | 名称 | 
|---|---|---|
| mqd_t | mqdes | |
| const char __user * | u_msg_ptr | |
| size_t | msg_len | |
| unsigned int | msg_prio | |
| struct timespec64 * | ts | 
| 974 | struct posix_msg_tree_node * new_leaf = NULL | 
| 975 | ret等于0 | 
| 978 | 如果此条件成立可能性小(为编译器优化)(msg_prio >= (unsignedlong)MQ_PRIO_MAX)则返回:负EINVAL | 
| 981 | 如果ts则 | 
| 986 | audit_mq_sendrecv(mqdes, msg_len, msg_prio, ts) | 
| 989 | 如果此条件成立可能性小(为编译器优化)(!file)则 | 
| 994 | inode等于file_inode(file) | 
| 995 | 如果此条件成立可能性小(为编译器优化)(f_op != & mqueue_file_operations)则 | 
| 1000 | audit_file(file) | 
| 1002 | 如果此条件成立可能性小(为编译器优化)(!(f_mode & le is open for writing ))则 | 
| 1007 | 如果此条件成立可能性小(为编译器优化)(msg_len > maximum message size )则 | 
| 1015 | 如果是错误则 | 
| 1019 | message text size 等于msg_len | 
| 1027 | 如果非node_cache则new_leaf等于开辟内存 | 
| 1030 | 加自旋锁 | 
| 1032 | 如果非node_cache且new_leaf则 | 
| 1037 | 否则 | 
| 1038 | 释放内存 | 
| 1042 | 如果f_flags按位与O_NONBLOCK则 | 
| 1044 | 否则 | 
| 1055 | 否则 | 
| 1057 | 如果receiver则 | 
| 1059 | 否则 | 
| 1062 | 如果ret则转到:out_unlock | 
| 1066 | i_atime等于i_mtime等于i_ctime等于current_time(inode) | 
| 1069 | out_unlock : | 
| 1070 | 自旋锁解锁 | 
| 1072 | out_free : | 
| 1075 | out_fput : | 
| 1077 | out : | 
| 1078 | 返回:ret | 
| 名称 | 描述 | 
|---|---|
| SYSCALL_DEFINE5 | 
| 源代码转换工具 开放的插件接口 | X | 
|---|---|
| 支持:c/c++/esqlc/java Oracle/Informix/Mysql 插件可实现:逻辑报告 代码生成和批量转换代码 |