linux内核模块参数

    在装载内核模块时,用户可以向模块传递参数,形式为:insmod/modprobe 模块名 参数名 =   参数值。

如果不传递,参数将使用模块内定义的缺省值。


    我们可以使用以下方法为模块定义一个参数:

    module_param(参数名,参数类型,参数读/写权限);

    如下代码定义了一个整型参数:

    static int num = 4000 ;

    module_param(num, int , S_IRUGO);

    参数可以是以下类型:

byte

short

ushort

int

uint

long

ulong

char(字符指针)

bool

invbool(布尔的反,invbool 类型颠倒了值, 所以真值变成 false,)


    在模块被编译时会将module_param中声明的类型与变量定义的类型进行比较,判断是否一致。

    模块被加载后,在/sys/module/目录下将出现以此模块命名的目录。

    当“参数读/写权限”为0时,表示此参数不存在sysfs文件系统下对应的文件节点。

    当“参数读/写权限”不为0时,在此模块的目录下还将出现parameters目录,包含一系列以参数名命名的文件节点,这些文件的权限值就是传入module_param( )的“参数读写权限”,而这些文件的内容为参数的值。

    除此之外,模块也可以拥有参数数组,形式为“module_param_array(数组名,数组类型,数组长,参数读/写权限)”。

    从2.6.0~2.6.10版本,需要将数组长变量名赋给“数组长”。从2.6.10版本开始,需将数组长变量的指针赋给“数组长”,当不需要保存实际输入的数组元素个数时,可以设置“数组长”为NULL。

    运行insmod或modprobe命令时,使用逗号分割输入的数组元素。

    一下是实验例子:

[cpp]  view plain copy
  1. #include <linux/init.h>  
  2. #include <linux/module.h>  
  3. #include <linux/moduleparam.h>  
  4. ///  
  5. MODULE_LICENSE("Dual BSD/GPL");  
  6. char *msg_buf = "Hello world!";  
  7. int n_arr[] = {1,2,3,4,5};  
  8. int n = 7;  
  9. //module_param(n, int, S_IRUSR);  
  10. module_param_array(n_arr, int, &n, S_IRUSR);  
  11. module_param(msg_buf, charp, S_IRUSR);  
  12. ///  
  13. static __init int hello_init(void)  
  14. {  
  15.     int i;      
  16.     printk("%s/n", msg_buf);  
  17.     for (i=0; i<n; i++)  
  18.     {  
  19.         printk("n_arr[%d]=%d/n", i, n_arr[i]);  
  20.     }  
  21.     return 0;  
  22. }  
  23. ///  
  24. static __exit void hello_exit(void)  
  25. {  
  26.     printk("Goodbye, kernel!/n");  
  27. }  
  28. module_init(hello_init);  
  29. module_exit(hello_exit);  
 

Makefile文件:

[xhtml]  view plain copy
  1. ### Makefile  
  2. obj-m :hello.o  
  3. KERNEL_DIR  := /lib/modules/$(shell uname -r)/build  
  4. PWD         := $(shell pwd)  
  5.   
  6. default:  
  7.     $(MAKE) -C $(KERNEL_DIR) M=$(PWD) modules  
  8. clean:  
  9.     $(MAKE) -C $(KERNEL_DIR) M=$(PWD) clean  
 

运行命令:

 

sudo insmod hello.ko msg_buf=veryCD

然后使用dmesg可以查看到printk的输出:
[35983.685059] veryCD
[35983.685067] n_arr[0]=1
[35983.685072] n_arr[1]=2
[35983.685075] n_arr[2]=3
[35983.685079] n_arr[3]=4
[35983.685083] n_arr[4]=5
[35983.685087] n_arr[5]=7
[35983.685091] n_arr[6]=1
可以看出,实现n_arr的长度应该为5,而n为7,驱动里面并没有检测出,n_arr[5],n_arr[6]已经越界了,,,
但是insmod的时候却是会检测n_arr的长度的,,
输入命令:
sudo insmod hello.ko msg_buf=veryCD n_arr=1,2,3,4,5,6
但是提示出错了,:
insmod: error inserting 'hello.ko': -1 Invalid parameters
因为n_arr的数组长度为5,当输入的数组长度小于等于5的时候,insmod可以加载模块成功,
sudo insmod hello.ko msg_buf=veryCD n_arr=1,2,3
[36315.732903] veryCD
[36315.732908] n_arr[0]=1
[36315.732909] n_arr[1]=2
[36315.732911] n_arr[2]=3
可以看出,module_param_array中的nump的值为实际的输入数组参数长度。
然后当使用insmod加载内核模块,并传递数据参数的时候,系统会自动检测数组的长度,当输入的数组长度小于模块的数组长度是,insmod才会成功。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Linux内核模块是一种可以动态加载到Linux内核中的程序,它可以扩展和定制内核的功能。内核模块相对于直接编译到内核的代码而言,更加灵活和可扩展。 Linux内核模块详解主要包括以下内容: 1. 动态加载和卸载:与静态编译到内核不同,内核模块可以动态加载到内核中,并在不需要时卸载。这样可以减小内核的体积和开机启动时间,同时方便模块的管理和更新。 2. 内核符号表:内核模块中包含了一些导出的符号,其他模块或内核可以通过这些符号与模块进行交互和调用。内核提供了一系列函数和宏来管理和使用内核符号表。 3. 模块的编写:编写一个内核模块需要包括初始化函数和清理函数。初始化函数是模块加载时被调用的函数,通常用来注册模块的功能和初始化资源。清理函数是模块卸载时被调用的函数,用于清理资源和注销已注册的功能。 4. 模块参数:模块还可以定义一些可配置的参数,通过在模块加载时指定参数的值,可以动态改变模块的行为。内核提供了一套机制来管理模块参数。 5. 模块依赖性:模块间可能存在依赖关系,一个模块可能依赖于其他模块的功能。内核提供了机制来声明和管理模块的依赖关系,确保模块的加载顺序和依赖关系正确。 6. 内核接口:内核提供了一系列的接口供模块使用,包括文件系统、设备驱动、网络协议等。模块可以通过这些接口来访问内核的功能和资源。 总的来说,Linux内核模块是一种动态加载到内核中的程序,可以扩展和定制内核的功能。通过内核模块,可以实现新的功能、优化性能和对内核进行定制,是Linux内核开发和定制的重要手段。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

洪流之源

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值