linux驱动中的module_param与module_param_array

本文深入解析了Linux驱动中module_param与module_param_array宏的作用及用法,包括参数类型、访问权限设置,以及如何通过insmod命令传递参数。同时,介绍了如何在驱动中声明并使用这些参数。
【版权申明】未经博主同意,谢绝转载!(请尊重原创,博主保留追究权) 

linux驱动中的module_param与module_param_array

1. module_param(name, type, perm)

宏作用: 向驱动模块提供参数, 或者说是驱动模块中的某一个变量赋值, 若没有赋值则使用默认值.

参数说明:

@param name 既是用户看到的参数名, 又是模块内接受参数的变量;

@param type 表示参数的数据类型;
	有byte, short, ushort, int, uint, long, ulong, charp, bool, invbool;
	(类型与模块内的参数定义是一致的)
      
@param perm(permission) 指定了在sysfs中相应文件的访问权限. 访问权限与linux文件访问权限相同的方式管理,0644, 或使用stat.h中的宏如S_IRUGO表示.
	0    表示完全关闭在sysfs中相对应的项
	#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


/**
 * include/linux/stat.h
 */
#define S_IRWXUGO	(S_IRWXU|S_IRWXG|S_IRWXO)
#define S_IALLUGO	(S_ISUID|S_ISGID|S_ISVTX|S_IRWXUGO)
#define S_IRUGO		(S_IRUSR|S_IRGRP|S_IROTH)
#define S_IWUGO		(S_IWUSR|S_IWGRP|S_IWOTH)
#define S_IXUGO		(S_IXUSR|S_IXGRP|S_IXOTH)

典型用法如下:

// 驱动文件中
static unsigned int gpio_chip_num = 4;
module_param(gpio_chip_num, uint, S_IRUGO);

// 装载驱动时
insmod xxxx.ko gpio_chip_num=x

2. module_param_array(para, type, &n_para, perm)

传递多个参数时, 可以通过宏 module_param_array(para, type, &n_para, perm) 来实现:

@param para 既是外部模块的参数名又是程序内部的变量名, 在这里它是一个数组, 数组要足够大(该变量决定着能输入多少个参数)
@param type 数据类型
@param n_para 参数的个数, 用于告诉驱动在insmod驱动时, para参数输入的参数个数.
@param perm sysfs的访问权限

典型用法如下:

// 驱动文件中
static int para[MAX_FISH];
static int n_para;
module_param_array(para , int , &n_para , S_IRUGO); 

// 装载驱动时
insmod xxxx.ko para=6,6,6,6,6

3. 驱动模块参数的查看:

cat /sys/module/xxxxx/parameters/gpio_chip_num
<think>好的,我现在需要回答用户关于module_param_array支持的参数类型的问题。首先,我得回忆一下Linux内核中模块参数的相关知识,特别是module_param_array的用法。 根据用户提供的引用,特别是引用[1]和[3],module_param_array用于向内核模块传递数组参数。用户想知道支持哪些参数类型。我需要先确定常见的参数类型,比如基本类型和可能的其他类型。 记得module_parammodule_param_array使用的类型是类似的,比如bool、int、charp等。引用[2]提到module_param的定义,而引用[3]中的示例使用了uint类型,这可能是指无符号整型。但需要确认内核支持的具体类型列表。 接下来,我需要查阅Linux内核文档或相关头文件,比如moduleparam.h,里面定义的参数类型可能包括:byte、short、ushort、int、uint、long、ulong、charp、bool等。此外,可能还有invbool这种反向布尔类型。 还需要注意,数组参数需要传递长度指针,如引用[3]中的示例使用了&tas5707_EQ_table_length。参数类型必须匹配,否则会导致错误。 最后,需要将这些类型整理成列表,并说明每个类型的用途,确保用户清楚每种类型对应的数据格式。同时,可能存在的权限参数(perm)也是需要注意的,但用户主要问的是类型,所以可以简要提及权限的作用,如sysfs中的访问权限。</think>### module_param_array支持的内核参数类型 在Linux内核模块开发中,$module\_param\_array$ 宏支持以下基础数据类型: #### 1. **基础整数类型** - $byte$:单字节整数(等效于 $char$) - $short$:短整型 - $ushort$:无符号短整型 - $int$:整型 - $uint$:无符号整型 - $long$:长整型 - $ulong$:无符号长整型 - $charp$:字符指针(用于字符串参数) - $bool$:布尔值(`true`/`false` 或 `1`/`0`) - $invbool$:反向布尔值(逻辑取反) #### 2. **数组参数的特殊要求** - 参数类型需模块内定义的数组类型严格匹配。例如: ```c static unsigned int tas5707_EQ_table[10]; module_param_array(tas5707_EQ_table, uint, &length, 0644); ``` 这里类型指定为 $uint$,对应数组的实际类型 $unsigned\ int$[^3]。 #### 3. **权限控制参数(perm)** 权限值(如 $0644$)控制通过sysfs接口访问参数的读写权限,但不会影响参数类型本身[^1][^3]。 --- ### 示例解析 ```c module_param_array(tas5707_EQ_table, uint, &tas5707_EQ_table_length, 0664); ``` - **类型匹配**:数组 $tas5707\_EQ\_table$ 必须定义为 $unsigned\ int$ 类型 - **长度指针**:$&tas5707\_EQ\_table\_length$ 用于自动记录数组实际长度 - **权限**:$0664$ 表示sysfs中该参数可被所有者/组读写,其他用户只读[^3] --- ### 注意事项 1. **类型一致性**:若声明为 $int$ 但实际使用 $unsigned\ int$,可能导致数据错误。 2. **字符串参数**:使用 $charp$ 类型时,需确保内存安全(如避免缓冲区溢出)。 3. **模块加载语法**:加载模块时数组参数通过逗号分隔,例如: ```bash insmod module.ko param_array=1,2,3,4 ``` ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

安河桥

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

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

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

打赏作者

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

抵扣说明:

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

余额充值