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