linux驱动开发--内核模块参数

内核模块参数,验证小例子:

/**
*Copyright (c) 2013.TianYuan
*All rights reserved.
*
*文件名称: Modparma.c
*文件标识: 模块参数的验证
*
*当前版本:1.0
*作者:wuyq
*
*取代版本:xxx
*原作者:xxx
*完成日期:2013-11-18
*/
#include <linux/init.h>
#include <linux/module.h>

/*内核提供的机制:在用户空间修改内核模块中全局变量的值*/
/*安装模块的时候,可以指定参数的值:\
如insmod modparam.ko mpshort=100 mpint=200 mpstring="nihao" mparray=300,400*/
/*ls /sys/module/modparam/parameters*/
/*cat mparray; 有权限的能够写echo 55 > mpshort;cat mpshort*/
MODULE_LICENSE("GPL");

/* 定义全局变量*/
static short mpshort = 1;
static int mpint = 10;
static char *mpstring = "hello";
static int mparray[2] = {100, 200};
/*模块参数的声明*/
module_param(mpshort ,short, S_IRWXU);
module_param(mpint, int , S_IRUSR);
module_param(mpstring, charp, 00400);/*char* */
module_param_array(mparray, int, NULL, 00400); 

static int __init modparam_init(void)
{
	printk("mpshort = %d\n", mpshort);
	printk("mpint = %d\n", mpint);
	printk("mpstring = %s\n", mpstring);
	printk("mparray = %d, %d\n", mparray[0], mparray[1]);
	return 0;
}

static void __exit modparam_exit(void)
{
	printk("mpshort = %d\n", mpshort);
	printk("mpint = %d\n", mpint);
	printk("mpstring = %s\n", mpstring);
	printk("mparray = %d, %d\n", mparray[0], mparray[1]);
}

module_init(modparam_init);
module_exit(modparam_exit);
时间: 2024-09-12 07:35:24

linux驱动开发--内核模块参数的相关文章

Linux驱动开发必看详解神秘内核(完全转载)

Linux驱动开发必看详解神秘内核 完全转载-链接:http://blog.chinaunix.net/uid-21356596-id-1827434.html   IT168 技术文档]在开始步入Linux设备驱动程序的神秘世界之前,让我们从驱动程序开发人员的角度看几个内核构成要素,熟悉一些基本的内核概念.我们将学习内核定时器.同步机制以及内存分配方法.不过,我们还是得从头开始这次探索之旅.因此,本章要先浏览一下内核发出的启动信息,然后再逐个讲解一些有意思的点. 2.1 启动过程 图2-1显示

红帽-台式机x64 架构linux 驱动开发的安装问题

问题描述 台式机x64 架构linux 驱动开发的安装问题 我们知道Linux下的驱动开发可以静态加载也可以动态加载的.本人想在台式机上面的小红帽 下静态安装驱动.每次动态加载太费事了,但是貌似没有嵌入式Linux 下面的简单.有哪些方法可以实现系统自动加载,难道只有修改启动脚本么? 请大牛不吝赐教!跪拜!三客优! 解决方案 自己编译一个系统内核吧,这样想怎么弄就怎么弄了 或者查阅红帽的开发手册,看看有木有说明 解决方案二: 谢谢,网上可以下载到红帽的内核么 台式机上面怎么放系统里面启动呢? 解

《Android深度探索(卷1):HAL与驱动开发》——1.5节如何学习Linux驱动开发

1.5 如何学习Linux驱动开发 Android深度探索(卷1):HAL与驱动开发 由于Linux的内核版本更新较快(稳定版本1至3月更新一次,升级版本1至2周更新一次),每一次内核的变化就意味着Linux驱动的变化(就算不需要修改驱动代码,至少也得在新的Linux内核版本下重新编译),所以Linux内核的不断变化对从事Linux驱动开发的程序员影响比较大.不过这对于学习Linux驱动开发来说影响相对较小.因为不管是哪个版本的Linux内核,开发Linux驱动的方法和步骤基本相同,只要掌握了一

Linux 驱动之模块参数--Linux设备驱动程序

模块参数 很多情况下,我们期望通过参数来控制我们的驱动的行为,比如由于系统的不同,而为了保证我们驱动有较好的移植性,我们有时候期望通过传递参数来控制我们驱动的行为,这样不同的系统中,驱动可能有不同的行为控制. 为了满足这种需求,内核允许对驱动程序指定参数,而这些参数可在加载驱动的过程中动态的改变 参数的来源主要有两个 使用insmod/modprobe ./xxx.ko时候在命令行后直接给出参数: modprobe命令装载模块时可以从它的配置文件/etc/modprobe.conf文件中读取参数

Linux驱动开发常用调试工具---之内存读写工具devmem和devkmem

问题 这段时间实验室要完成一个内存故障注入工具和寄存器故障注入工具,在编写驱动的过程中,调试起来很麻烦(一般都是printk打印出来的,调试起来太不方便),于是想 "可不可以在调试设备驱动的时候,利用一个小工具来读写内存某块区域的值以及CPU中寄存器的值? 这点前辈的大神已经为我们找到了,参见<LDD3>的<第十五章 内存映射和DMA> 目前已经有这样的工具了devmem和devkmem,就是通过mmap映射/dev/mem的. 这个工具的源码简单,google一下到处都

linux驱动开发--字符设备:静态分配设备号

字符设备(char device)         采用字节流方式访问的设备称为字符设备,通常智能采用顺序访问方式,也有极少数可以前后移动访问指针的设备(如:帧捕捉卡等设备).系统标准字符设备,例如:字符中断.串口等设备.常见待开发设备驱动的字符设备,例如:触摸屏.键盘.视频捕捉设备.音频设备等. 设备号 主设备号     用于标识设备类型,内核代码根据该号码对应设备文件和对应的设备驱动程序 次设备号     用于标识通类型的不同设备个体,驱动程序根据该号码辨别具体操作的是哪个设备个体. 设备号

linux驱动开发--字符设备:原子操作

解决竞态问题的途径是保证对共享资源的互斥访问,所谓互斥访问是指一个执行单元在访问共享资源的时候,其他的执行单元被禁止访问. 访问共享资源的代码区域称谓临界区(critical sections),临界区需要以某种互斥机制加以保护.中断屏蔽.原子操作.自旋锁和信号量是Linux设备驱动中可采用的互斥途径. 原子操作 原子操作指的是在执行过程中不会被别的代码路径所中断的操作. Linux内核停工了一系列函数来实现内核中的原子操作.这些函数分为两类,分别针对位和整型变量进行原子操作.他们的共同点是在任

linux驱动开发--中断:按键中断

1.中断定义 中断是指cpu在执行过程中,出现了某些突发事件时cpu必须暂停执行当前的程序,转去处理突发事件,处理完毕后cpu又返回原程序被中断的位置并继续执行. 2.中断分类 3.Linux中断处理程序结构 a.在Linux系统中,中断处理程序分解为两个半部:顶半部(TopHalf)和底半部(BottomHalt). b.顶半部:完成尽可能少的比较紧急的功能,往往只是简单的读取寄存器中的中断状态并清除中断标志后就进行"登记中断"的工作,也就是将底半部处理程序挂到该设备的底半部执行队列

linux驱动开发--字符设备:信号量

信号量的使用 信号量(semaphore)是用于保护临界区的一种常用方法,它的使用和自旋锁类似.与自旋锁相同,只有得到信号量的进程才能执行临界区代码.但是与自旋锁不同的是当获取不到信号量时,进程不会原地打转而是进入休眠等待状态. 关于信号量的操作函数: 1.定义信号量 struct semaphore sem; 2.初始化信号量 sema_init(struct semaphore *sem, int val);//用于初始化信号量并设置sem为val init_MUTEX(struct sem