linux网络驱动初始化module_init函数跟踪

简介: module_init函数对做驱动开发的同学是在太熟悉了,但是关于底层的知识可能大家有些不愿去了解,而其中知识对于网络初始化也直接相关,所以先将此分享。 在驱动程序中有module_init函数,该函数定义在文件 include/linux/module.h中(以前好像在include/linux/init.h中),如下。

module_init函数对做驱动开发的同学是在太熟悉了,但是关于底层的知识可能大家有些不愿去了解,而其中知识对于网络初始化也直接相关,所以先将此分享。

在驱动程序中有module_init函数,该函数定义在文件

include/linux/module.h(以前好像在include/linux/init.h),如下。

#define module_init(x)  __initcall(x);

       该函数是驱动初始化函数入口,在内核启动或模块加载时候执行。每个模块一个module_init函数。

       不过module_init只是个宏,声明为__initcall,又声明在arch/um/include/shared/init.h文件中。

#define __initcall(fn) __define_initcall("1", fn)

#define __define_initcall(level,fn) \

        static initcall_t __initcall_##fn __used \

        __attribute__((__section__(".initcall" level ".init"))) = fn

__define_initcall(level,fn)这个宏的作用就是将初始化函数放在".initcall" level ".init"中。

       其中##表示连接的意思,__initcall_##fn##id 为__initcall_fn_id

如果fn = test_init,id = 6时,__initcall_##fn##id 为 __initcall_test_init6。(如果是#是字符串化的意思,#id 为“id”,id=6时,#id 为“6”。)

通过__attribute__(__section__)设置函数属性,也就是将test_init放在.initcall6.init段中。这个涉及连接的脚本。

       这些宏用于标记一些初始化函数或初始化数。内核在初始化阶段使用这些函数并在之后释放内存资源。

       平台设备的初始化(注册)用arch_initcall()调用,initcall的level为3;驱动的注册用module_init调用,即device_initcall,它的initcall 的level为6。

#define pure_initcall(fn)               __define_initcall(fn, 0)                                                    

 

#define core_initcall(fn)               __define_initcall(fn, 1)

#define core_initcall_sync(fn)          __define_initcall(fn, 1s)

#define postcore_initcall(fn)           __define_initcall(fn, 2)

#define postcore_initcall_sync(fn)      __define_initcall(fn, 2s)

#define arch_initcall(fn)               __define_initcall(fn, 3)

#define arch_initcall_sync(fn)          __define_initcall(fn, 3s)

#define subsys_initcall(fn)             __define_initcall(fn, 4)

#define subsys_initcall_sync(fn)        __define_initcall(fn, 4s)

#define fs_initcall(fn)                 __define_initcall(fn, 5)

#define fs_initcall_sync(fn)            __define_initcall(fn, 5s)

#define rootfs_initcall(fn)             __define_initcall(fn, rootfs)

#define device_initcall(fn)             __define_initcall(fn, 6)

#define device_initcall_sync(fn)        __define_initcall(fn, 6s)

#define late_initcall(fn)               __define_initcall(fn, 7)

#define late_initcall_sync(fn)          __define_initcall(fn, 7s)  

然后会调用do_initcalls函数调用通过xxx_initcall注册的各种函数,优先级高的先执行。所以通过module_init注册的函数在kernel启动的时候会被顺序执行。

目录
相关文章
|
1月前
|
机器学习/深度学习 数据采集 人工智能
未来的守护神:AI驱动的网络安全之盾,如何用智慧的光芒驱散网络黑暗势力?揭秘高科技防御系统背后的惊天秘密!
【10月更文挑战第3天】随着网络技术的发展,网络安全问题日益严峻,传统防御手段已显不足。本文探讨了构建AI驱动的自适应网络安全防御系统的必要性及其关键环节:数据采集、行为分析、威胁识别、响应决策和执行。通过Python库(如scapy、scikit-learn和TensorFlow)的应用实例,展示了如何利用AI技术提升网络安全防护水平。这种系统能够实时监控、智能分析并自动化响应,显著提高防护效率与准确性,为数字世界提供更强大的安全保障。
57 2
用MASM32按Time Protocol(RFC868)协议编写网络对时程序中的一些有用的函数代码
用MASM32按Time Protocol(RFC868)协议编写网络对时程序中的一些有用的函数代码
|
14天前
|
运维 监控 网络协议
|
18天前
|
Ubuntu Linux 虚拟化
Linux虚拟机网络配置
【10月更文挑战第25天】在 Linux 虚拟机中,网络配置是实现虚拟机与外部网络通信的关键步骤。本文介绍了四种常见的网络配置方式:桥接模式、NAT 模式、仅主机模式和自定义网络模式,每种模式都详细说明了其原理和配置步骤。通过这些配置,用户可以根据实际需求选择合适的网络模式,确保虚拟机能够顺利地进行网络通信。
|
29天前
|
机器学习/深度学习 编解码
深度学习笔记(三):神经网络之九种激活函数Sigmoid、tanh、ReLU、ReLU6、Leaky Relu、ELU、Swish、Mish、Softmax详解
本文介绍了九种常用的神经网络激活函数:Sigmoid、tanh、ReLU、ReLU6、Leaky ReLU、ELU、Swish、Mish和Softmax,包括它们的定义、图像、优缺点以及在深度学习中的应用和代码实现。
107 0
深度学习笔记(三):神经网络之九种激活函数Sigmoid、tanh、ReLU、ReLU6、Leaky Relu、ELU、Swish、Mish、Softmax详解
|
30天前
|
网络协议 安全 Ubuntu
Linux中网络连接问题
【10月更文挑战第3天】
28 1
|
2月前
|
Linux Shell
Linux系统编程:掌握popen函数的使用
记得在使用完 `popen`打开的流后,总是使用 `pclose`来正确关闭它,并回收资源。这种做法符合良好的编程习惯,有助于保持程序的健壮性和稳定性。
83 6
|
1月前
|
监控 Linux 测试技术
Linux系统命令与网络,磁盘和日志监控总结
Linux系统命令与网络,磁盘和日志监控总结
52 0
|
1月前
|
监控 Linux 测试技术
Linux系统命令与网络,磁盘和日志监控三
Linux系统命令与网络,磁盘和日志监控三
37 0
|
1月前
|
机器学习/深度学习 数据可视化 算法
激活函数与神经网络------带你迅速了解sigmoid,tanh,ReLU等激活函数!!!
激活函数与神经网络------带你迅速了解sigmoid,tanh,ReLU等激活函数!!!

热门文章

最新文章