【C语言】Linux内核bind系统调用代码

一、Linux 4.9内核bind系统调用代码注释

int __sys_bind(int fd, struct sockaddr __user *umyaddr, int addrlen)
{struct socket *sock;                     // 定义socket对象的指针struct sockaddr_storage address;         // 用于存储从用户空间复制过来的地址int err, fput_needed;                    // 错误码和文件指针释放标志// 通过文件描述符获取socket对象,并检查是否需要释放文件指针sock = sockfd_lookup_light(fd, &err, &fput_needed);if (sock) {  // 如果获取socket对象成功// 将用户空间的socket地址复制到内核空间err = move_addr_to_kernel(umyaddr, addrlen, &address);if (err >= 0) {  // 如果地址复制成功// 进行安全检查,判断是否允许绑定操作err = security_socket_bind(sock, (struct sockaddr *)&address, addrlen);if (!err)  // 安全检查通过// 调用协议层的bind函数完成实际的绑定操作err = sock->ops->bind(sock, (struct sockaddr *)&address, addrlen);}// 根据fput_needed标志决定是否释放文件指针fput_light(sock->file, fput_needed);}return err;  // 返回操作结果
}// 定义bind系统调用
SYSCALL_DEFINE3(bind, int, fd, struct sockaddr __user *, umyaddr, int, addrlen)
{// 调用__sys_bind函数,并返回其结果return __sys_bind(fd, umyaddr, addrlen);
}

二、代码解释

这段代码来自较老的版本的Linux内核,是`bind`系统调用的实现,其作用是将一个本地地址绑定到一个socket上。在Linux网络编程中,`bind`函数用于指定socket的本地地址,通常用在服务端指定端口号。下面将逐段用中文解读这段代码:

int __sys_bind(int fd, struct sockaddr __user *umyaddr, int addrlen)
{

定义了函数`__sys_bind`,它接收三个参数:一个文件描述符`fd`,一个指向用户空间socket地址的指针`umyaddr`,以及地址的长度`addrlen`。

    struct socket *sock;struct sockaddr_storage address;int err, fput_needed;

定义几个局部变量:`sock`用于存储内核中的socket对象的指针,`address`用于临时存储socket地址信息,`err`用于记录错误代码,`fput_needed`用于标记是否需要释放文件指针。

    sock = sockfd_lookup_light(fd, &err, &fput_needed);

通过文件描述符`fd`获取对应的socket对象,并将该对象的地址存入`sock`。此外,记录任何查找错误到`err`,并设定是否需要释放文件指针到`fput_needed`。

    if (sock) {

如果成功获取到了socket对象(即`sock`不为NULL)。

        err = move_addr_to_kernel(umyaddr, addrlen, &address);

将用户空间中的socket地址`umyaddr`复制到内核空间中的`address`变量中,检查地址的有效性,如果成功则`err`为非负值。

        if (err >= 0) {err = security_socket_bind(sock,(struct sockaddr *)&address,addrlen);

如果地址成功移动到内核空间,接着进行安全检查,看是否允许bind操作。

            if (!err)err = sock->ops->bind(sock,(struct sockaddr *)&address, addrlen);}

如果通过了安全检查,调用对应协议的`bind`函数,以进行实际的绑定操作。

        fput_light(sock->file, fput_needed);

完成绑定操作后,根据之前记录的`fput_needed`变量的值来决定是否释放文件指针。

    }return err;
}

返回操作结果,如果`err`为0,则表示绑定成功;如果为负值,则表示绑定过程中出现了错误。
最后是`SYSCALL_DEFINE3`宏定义的`bind`函数,这是一个宏来方便地定义具有三个参数的系统调用,并最终调用`__sys_bind`来完成实际的工作:

SYSCALL_DEFINE3(bind, int, fd, struct sockaddr __user *, umyaddr, int, addrlen)
{return __sys_bind(fd, umyaddr, addrlen);
}

这部分定义了系统调用`bind`,接收三个参数,内部简单地调用了`__sys_bind`函数,并返回它的返回值。这个宏用于定义一个系统调用,它定义了一个名为bind的系统调用,该系统调用接受三个参数:fdumyaddraddrlenSYSCALL_DEFINE3宏会生成一个系统调用的实现,该实现会将参数从用户空间复制到内核空间,然后调用__sys_bind函数来处理请求。

总之,这段代码实现了bind系统调用,它允许用户空间程序将套接字与本地地址和端口号关联起来。在绑定过程中,还进行了必要的安全检查和地址结构体的复制操作。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/683498.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

谷歌搜索技巧与 ChatGPT 实用指南:提升你的在线生产力

探索谷歌搜索技巧,提升搜索效率 前言 在搜索三巨头百度、必应、谷歌中,谷歌在搜索精确度以及多语言兼容性方面有明显的优势。其次在国内想要使用谷歌搜索你需要会科学上网(这里不说)。 一.排除干扰内容(广告&#xff…

【实战】一、Jest 前端自动化测试框架基础入门(四) —— 前端要学的测试课 从Jest入门到TDD BDD双实战(四)

文章目录 一、Jest 前端自动化测试框架基础入门10.Jest 中的 Mock(1)toBeCalled(2)func.mock(3)mockReturnValue & mockReturnValueOnce 学习内容来源:Jest入门到TDD/BDD双实战_前端要学的测…

算法训练day29Leetcode491递增子序列46全排列47全排列Ⅱ

491 递增子序列 题目描述 给你一个整数数组 nums ,找出并返回所有该数组中不同的递增子序列,递增子序列中 至少有两个元素 。你可以按 任意顺序 返回答案。 数组中可能含有重复元素,如出现两个整数相等,也可以视作递增序列的一…

【自我介绍】计算机软件工程人工智能研究生复试资料整理

1、JAVA 2、计算机网络 3、计算机体系结构 4、数据库 5、计算机租场原理 6、软件工程 7、大数据 8、英文 自我介绍 自我介绍 英文 自我介绍 英文 第一段: Good afternoon, dear professors, thank you for the chance to introduce myself. My name is Yan Zhen Xing, and I a…

已解决AttributeError: ‘str‘ object has no attribute ‘decode‘异常的正确解决方法,亲测有效!!!

已解决AttributeError: str object has no attribute decode异常的正确解决方法,亲测有效!!! 文章目录 问题分析 报错原因 解决思路 解决方法 总结 当你在Python编程时碰到“AttributeError: str object has no attribute d…

UVA1449 Dominating Patterns 题解

UVA1449 Dominating Patterns 题解 板子题诶。 解法 AC 自动机模板题,因为数据范围比较小,所以不加拓扑排序优化建图即可通过本题。这里简单介绍一下拓扑排序优化建图。 在查找时,每次都暴力的条 f a i l fail fail 指针是很消耗时间的&…

vue-进阶语法(四)

目录 v-model原理 v-model应用于组件 sync修饰符 ref 和 $refs(重点) $nextTick v-model原理 原理:v-model本质上是一个语法糖。例如应用在输入框上,就是 value属性 和 input事件 的合写。 作用:提供数据的双向…

压缩PDF的大小-Adobe Acrobat Pro

经常遇到上传的pdf太大,无法成功上传。 今天找到一个方法: 打开Adobe Acrobat Pro软件 → 文件 → 另存为其他(H)... →缩小大小的PDF 版本选择 4.0 最低的版本。 文件由9M变为1.5M。

Codeforces Round 924 (Div. 2) B - D

B. Equalize 题目: 思路:首先排序然后去重(可以用set来去重),我们可以肯定的是,如果连续k个数最大值最小值的差小于等于n的话,那么这个长度为k的区间就符合答案要求,那么k就和答案…

###51单片机学习(2)-----如何通过C语言运用延时函数设计LED流水灯

前言:感谢您的关注哦,我会持续更新编程相关知识,愿您在这里有所收获。如果有任何问题,欢迎沟通交流!期待与您在学习编程的道路上共同进步。 目录 一. 延时函数的生成 1.通过延时计算器得到延时函数 2.可赋值改变…

Linux释放内存

free -m是Linux上查看内存的指令,其中-m是以兆(MB)为单位,如果不加则以KB为单位。 如下图表示,(total)总物理内存是809MB,(used)已使用167MB,&…

【AI视野·今日NLP 自然语言处理论文速览 第七十九期】Thu, 18 Jan 2024

AI视野今日CS.NLP 自然语言处理论文速览 Thu, 18 Jan 2024 Totally 35 papers 👉上期速览✈更多精彩请移步主页 Daily Computation and Language Papers Deciphering Textual Authenticity: A Generalized Strategy through the Lens of Large Language Semantics …

使用STM32CubeMX配置和优化DMA传输

STM32CubeMX是STMicroelectronics提供的一款图形化配置工具,可以帮助开发人员对STM32微控制器进行初始化配置和代码生成。在本文中,我们将介绍如何使用STM32CubeMX来配置和优化DMA传输,并提供一个简单的示例代码来演示DMA的配置和使用。 ✅作…

【Py/Java/C++三种语言详解】LeetCode每日一题240215【二叉树BFS】LeetCode107、二叉树的层序遍历II

有LeetCode交流群/华为OD考试扣扣交流群可加:948025485 可上全网独家的 欧弟OJ系统 练习华子OD、大厂真题 绿色聊天软件戳 od1336了解算法冲刺训练 文章目录 题目链接题目描述解题思路DFS和BFS异同用队列维护的BFS 代码PythonJavaC时空复杂度 相关习题华为OD算法/大…

寒假学习记录13:JS对象

目录 对象转数组 对象双值转数组 Object.entries() (转为二维数组)(属性的值和键) 对象右值转数组 Object.values() (属性的值) 对象左值转数组 Object.keys() (属性的键) 对象左值转…

计算机视觉基础:获取图像的ROI

在图像处理过程中,我们可能会对图像的某一个特定区域感兴趣,该区域被称为感兴趣区域(Region of Interest,ROI)。在设定感兴趣区域ROI后,就可以对该区域进行整体操作。 Python实现代码如下: # -…

怎样学习Windows下命令行编写

第一:Windows下命令行指的是cmd和powershell命令行编写 第二:必须要用好help或/?命令,这个命令是最基本的也是最常用的命令列表和语法查看命令 第三:cmd命令使用help查看命令列表或“一串带参数的命令 /?"(不…

[职场] 花园管家是做什么的 #笔记#学习方法

花园管家是做什么的 一、工作内容职责: 1.管理花园内的活动和工作,协调各方资源,确保活动的顺利进行; 2.提供优质的客户服务和接待工作,解决客户问题,处理投诉,提高客户满意度; …

(03)Hive的相关概念——分区表、分桶表

目录 一、Hive分区表 1.1 分区表的概念 1.2 分区表的创建 1.3 分区表数据加载及查询 1.3.1 静态分区 1.3.2 动态分区 1.4 分区表的本质及使用 1.5 分区表的注意事项 1.6 多重分区表 二、Hive分桶表 2.1 分桶表的概念 2.2 分桶表的创建 2.3 分桶表的数据加载 2.4 …

C++ 基础算法 前缀和

输入一个长度为 n 的整数序列。 接下来再输入 m 个询问,每个询问输入一对 l,r 。 对于每个询问,输出原序列中从第 l 个数到第 r 个数的和。 输入格式 第一行包含两个整数 n 和 m 。 第二行包含 n 个整数,表示整数数列。 接下来 m 行&…