module_param和module_param_array用法
如何向模块传递参数? Linux kernel 提供了一个简单的框架。利用module_param和module_param_arra来实现。
1. module_param(name, type, perm);
name 既是用户看到的参数名,又是模块内接受参数的变量;
type 表示参数的数据类型,是下列之一:byte, short, ushort, int, uint, long, ulong, charp, bool, invbool;
perm 指定了在sysfs中相应文件的访问权限。访问权限与linux文件访问权限相同的方式管理,如0644,或使用stat.h中的宏如S_IRUGO表示。
#define S_IRUSR 00400 文件所有者可读
#define S_IWUSR 00200 文件所有者可写
#define S_IXUSR 00100 文件所有者可执行
#define S_IRGRP 00040 与文件所有者同组的用户可读
#define S_IWGRP 00020
#define S_IXGRP 00010
#define S_IROTH 00004 与文件所有者不同组的用户可读
#define S_IWOTH 00002
#define S_IXOTH 00001
这些宏不会声明变量,因此在使用宏之前,必须声明变量,典型地用法如下:
static unsigned int int_var = 0;
module_param(int_var, uint, S_IRUGO);
insmod xxxx.ko int_var=x
2. 传递多个参数可以通过宏 module_param_array(para , type , &n_para , perm) 实现。
其中,para既是外部模块的参数名又是程序内部的变量名,type是数据类型,perm是sysfs的访问权限。指针n_para指向一个整数,其值表示有多少个参数存放在数组para中。
para:参数数组;数组的大小才是决定能输入多少个参数的决定因素。
n_para: 参数个数;这个变量其实无决定性作用;只要para数组大小够大,在插入模块的时候,输入的参数个数会改变n_para的值,最终传递数组元素个数存在n_para中。
典型地用法如下:
static int para[MAX_FISH];
static int n_para;
module_param_array(para , int , &n_para , S_IRUGO);
源文件:info_test.c
1 #include <linux/init.h> 2 #include <linux/module.h> 3 #include <linux/sysctl.h> 4 #include <linux/stat.h> 5 #include <linux/debugfs.h> 6 #include <linux/seq_file.h> 7 #include <linux/proc_fs.h> 8 9 static char *name = "kevin"; 10 static int count = 2; 11 static int para[8] = {1,2,3,4}; 12 static int n_para = 1; 13 14 module_param(count, int, S_IRUGO); 15 module_param(name, charp, S_IRUGO); 16 module_param_array(para , int , &n_para , S_IRUGO); 17 18 static int info_init(void) 19 { 20 printk("init first_drv drv!\n"); 21 22 int i; 23 for (i = 0; i < count; i++) //count输入3, name输入kevin 24 printk(KERN_ALERT "(%d) Hello, %s\n", i, name); 25 26 for (i = 0; i < 8; i++) 27 printk(KERN_ALERT "para[%d] : %d \n", i, para[i]); //para输入6,7,8,9 28 29 for(i = 0; i < n_para; i++) //n_para的值等于para输入的个数,参考上面的para参数,所有这里等于4;如果para我输入6,7,则n_para等于2 30 printk(KERN_ALERT "para[%d] : %d \n", i, para[i]); 31 32 return 0; 33 } 34 35 static void info_exit(void) 36 { 37 printk("%s()\n",__func__); 38 } 39 40 module_init(info_init); 41 module_exit(info_exit); 42 43 MODULE_LICENSE("GPL");
Makefile:
1 obj-m:=info_test.o 2 CURRENT_PATH:=$(shell pwd) 3 VERSION_NUM :=$(shell uname -r) 4 LINUX_PATH :=/usr/src/linux-headers-$(VERSION_NUM) 5 6 all : 7 make -C $(LINUX_PATH) M=$(CURRENT_PATH) modules 8 clean : 9 make -C $(LINUX_PATH) M=$(CURRENT_PATH) clean
编译成ko文件info_test.ko,运行在linux本机或者arm开发板中。
通过dmesg查看打印信息:
参考地址:https://www.cnblogs.com/mylinux/p/5670279.html