一步一步学习Linux驱动之自动创建设备节点
来源:程序员人生 发布时间:2015-08-04 07:51:35 阅读次数:4217次
<span style="font-size:12px;">extern struct device *device_create(struct class *cls, struct device *parent,
dev_t devt, void *drvdata,
const char *fmt, ...)
__attribute__((format(printf, 5, 6)));</span>
函数功能:
函数device_create()用于动态的建立逻辑装备,并对新的逻辑装备类进行相应初始化,将其与函数的第1个参数所代表的逻辑类关联起来,然后将此逻辑装备加到linux内核系统的装备驱动程序模型中。函数能够自动在/sys/devices/virtual目录下创建新的逻辑装备目录,在/dev目录下创建于逻辑类对应的装备文件
参数说明:
struct class cls:与行将创建额逻辑装备相干的逻辑类。
dev_t dev:装备号
void *drvdata: void类型的指针,代表回调函数的输入参数
const char *fmt: 逻辑装备的装备名,即在目录 /sys/devices/virtual创建的逻辑装备目录的目录名。
#include <linux/module.h>
#include <linux/kernel.h>
#include <linux/fs.h>
#include <linux/init.h>
#include <linux/delay.h>
#include <linux/irq.h>
#include <asm/u
access.h>
#include <asm/irq.h>
#include <asm/io.h>
#include <linux/poll.h>
#include <linux/device.h>
static struct class *Myleddrv_class; //自动注册驱动主装备
static struct device *Myleddrv_dev;
volatile unsigned long *gpbcon = NULL; //控制寄存器
volatile unsigned long *gpbdat = NULL; //数据寄存器
static int Myleddrv_open(void)
{
printk("Hello Linux World!
");
return 0;
}
static int Myleddrv_write(void)
{
return 0;
}
static struct file_operations Myleddrv_fops = {
.owner = THIS_MODULE, /* 这是1个宏,推向编译模块时自动创建的__this_module变量 */
.open = Myleddrv_open,
.write = Myleddrv_write,
};
static int major; //全局变量
static int Myleddrv_init(void)
{
major = register_chrdev(0, "Myleddrv", &Myleddrv_fops); // 注册, 告知内核
Myleddrv_class = class_create(THIS_MODULE, "Myleddrv");
Myleddrv_dev = device_create(Myleddrv_class, NULL, MKDEV(major, 0), NULL, "Myleddrv"); /* /dev/Myleddrv */
return 0;
}
static void Myleddrv_exit(void)
{
unregister_chrdev(major, "Myleddrv"); // 卸载
printk("Myleddrv has been unregistered!
");
device_unregister(Myleddrv_dev);
device_destroy(Myleddrv_class,major);
}
module_init(Myleddrv_init);
module_exit(Myleddrv_exit);
MODULE_LICENSE("GPL");
生活不易,码农辛苦
如果您觉得本网站对您的学习有所帮助,可以手机扫描二维码进行捐赠