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