module_param()函数

1.定义模块参数的方法:

module_param(name, type, perm);

其中,name:表示参数的名字;
     type:表示参数的类型;
     perm:表示参数的访问权限;

2. 数组类型模块参数的定义:

用逗号间隔的列表提供的值;
声明一个数组参数:
module_param_array(name, type, num, perm);
其中,name:表示数组的名字;
     type:表示参数的类型;
     num :表示数组中元素数量;
     perm:表示参数的访问权限;

3.type支持的基本类型有:
bool   :布尔类型
invbool:颠倒了值的bool类型;
charp  :字符指针类型,内存为用户提供的字符串分配;
int    :整型
long   :长整型
short  :短整型
uint   :无符号整型
ulong  :无符号长整型
ushort :无符号短整型

4. perm参数 设定访问权限
modlue_param和module_param_array中的perm用于设定该参数的访问权限;
perm表示该参数在sysfs文件系统中所对应的文件节点的属性;你用该使用<Linux/stat.h>中定义的权限值;这个值控制谁可以存取这些模块参数在sysfs文件系统中的表示;当perm为0时,表示此参数不存在sysfs文件系统下对应的文件节点;否则,模块被加载后,在/sys/module/目录下将会出现以此模块名命名的目录,带有给定的权限;
比如:
#define S_IRWXU 00700
#define S_IRUSR 00400
#define S_IWUSR 00200
#define S_IXUSR 00100
#define S_IRWXG 00070
#define S_IRGRP 00040
#define S_IWGRP 00020
#define S_IXGRP 00010
#define S_IRWXO 00007
#define S_IROTH 00004
#define S_IWOTH 00002
#define S_IXOTH 00001
注意:如果一个参数被sysfs修改了,那么你的模块看到的参数值也被修改了,但是你的模块不会收到任何通知;你应当不要使模块参数可写,除非你准备好检测这个改变并因而作出反应;

5. 也可以在insmod(装载模块)的时候为参数指定值,如果没有指定则使用默认值,如下面的例子。

[cpp] view plain copy

  1. MODULE_LICENSE("Dual BSD/GPL");
  2. static int num=10;
  3. module_param(num,int,S_IRUGO);
  4. static int hello_init(void)
  5. {
  6. printk("Hello module init./n");
  7. printk("num=%d/n",num);
  8. return 0;
  9. }
  10. static void   hello_exit(void)
  11. {
  12. printk("Goodbye module exit./n");
  13. }
  14. module_init(hello_init);
  15. module_exit(hello_exit);
  16. MODULE_DESCRIPTION("a simple module");
  17. MODULE_ALIAS("hello");

上面的num=10,则10是参数num的默认值。

保存为源文件hello.c, 编译生成hello.ko , 当我们使用insmod进行载入时, 使用

insmod hello.ko num=20

则可以 cat /sys/module/hello/parameters/num ,看到为 20

时间: 2024-10-22 20:39:53

module_param()函数的相关文章

[linux内核笔记-1]内核模块参数传递----module_param()函数

1.module_param()的定义 module_param()宏是Linux 2.6内核中新增的,该宏被定义在include/linux/moduleparam.h文件中,定义如下 1 /** 2 * module_param - typesafe helper for a module/cmdline parameter 3 * @value: the variable to alter, and exposed parameter name. 4 * @type: the type o

[Linux编程] module_param()函数学习笔记

在读TCP cubic源码中,遇到了module_param(),网上查到的资料如下: 在用户态下编程可以通过main()来传递命令行参数,而编写一个内核模块则可通过module_param()来传递命令行参数. 它的具体实现方式为:module_param_named( name, type, perm),具体为变量名,它的类型,以及一个权限掩码用来做一个辅助的sysfs入口. 给出一个cubic的例子: module_param(fast_convergence, int, 0644);

linux驱动开发第二步 驱动模块传参(module_param函数使用)

在驱动的模块中声明一下你要传递的参数名称,类型和权限 module_param(变量的名称,类型,权限); 先上例子 #include <linux/init.h> #include <linux/module.h> static char *p_name = "Usr"; module_param(p_name, charp, S_IRUGO); MODULE_PARM_DESC(p_name, "This is a char * string.&q

内核模块参数设计

1.模块传递参数的概念 对于如何向模块传递参数,Linux kernel提供了一个简单的框架.其允许驱动程序声明参数,并且用户在系统启动或模块装载时为参数指定相应值,在驱动程序里,参数的用法如同全局变量. 2.代码如下 使用如下命令: insmod param.ko int_var=1 str_var=hi,param int_array=128.256.512 输出如下: 关于函数module_param(name,type,perm)的第三个参数perm表示sysfs中建立的对应文件的权限,

Linux设备驱动(1)模块的相关概念

最简单的内核模块 #include<linux/init.h> #include<linux/module.h> static int __init hello_init(void) //内核初始化函数 { printk("hello world!\n"); //打印函数,和prinft类似 return 0; } static void __exit hello_exit(void)//内核清除函数 { printk("good bye!\n&quo

insmod module_param 模块参数

模块参数 引导模块时,可以向它传递参数.要使用模块参数加载模块,这样写: insmod module.ko [param1=value param2=value ...] 为了使用这些参数的值,要在模块中声明变量来保存它们,并在所有函数之外的某个地方使用宏MODULE_PARM(variable, type) 和 MODULE_PARM_DESC(variable, description) 来接收它们.type参数应该是一个格式为 [min[-max]]{b,h,i,l,s} 字符串,其中 m

linux内核启动第二阶段之setup_arch()函数分析-2.6.36

执行setup_arch()函数 回到start_kernel当中,569行,调用setup_arch函数,传给他的参数是那个未被初始化的内部变量command_line.这个setup_arch()函数是start_kernel阶段最重要的一个函数,每个体系都有自己的setup_arch()函数,是体系结构相关的,具体编译哪个体系的setup_arch()函数,由顶层Makefile中的ARCH变量决定: 它首先通过检测出来的处理器类型进行处理器内核的初始化,然后通过 bootmem_init

linux中模块的构建,传参,和printk函数的简单使用

静态编译,动态加载应用想访问内核需要通过系统调用 驱动:1.模块(打包,加入内核)2.内核机制3.操作硬件 在Kconfig里面配置menuconfig的时候,不同的类型会在图形化界面的终端显示不用的配置选项:bool CONFIG_HELLO []hello_driver 两态tristate CONFIG_HELLO <>hello_driver 三态的 空 * Mstring/int CONFIG_HELLO ()hello_driver 相当于宏替换 (dest)hello_drive

ioctl函数详解

大部分驱动除了需要具备读写设备的能力之外,还需要具备对硬件控制的能力. 一.在用户空间,使用ioctl系统调用来控制设备,原型如下: int ioctl(int fd,unsigned long cmd,...); /* fd:文件描述符 cmd:控制命令 ...:可选参数:插入*argp,具体内容依赖于cmd */ 用户程序所作的只是通过命令码告诉驱动程序它想做什么,至于怎么解释这些命令和怎么实现这些命令,这都是驱动程序要做的事情. 二.驱动ioctl方法: int (*ioctl) (str