linux字符设备驱动一般模板
2012-05-30 09:48
489 查看
#include <linux/miscdevice.h> //头文件有很多,可以根据具体的情况添加删除,这里给一个例子。 #include <linux/delay.h> #include <asm/irq.h> #include <mach/regs-gpio.h> #include <mach/hardware.h> #include <linux/kernel.h> #include <linux/module.h> #include <linux/init.h> #include <linux/mm.h> #include <linux/fs.h> #include <linux/types.h> #include <linux/moduleparam.h> #include <linux/slab.h> #include <linux/errno.h> #include <linux/ioctl.h> #include <linux/cdev.h> #include <linux/string.h> #include <linux/list.h> #include <linux/pci.h> #include <linux/gpio.h> #include <asm/uaccess.h> #include <asm/atomic.h> #include <asm/unistd.h> #include <linux/device.h> #include <plat/gpio-cfg.h> #define DEVICE_NAME "devicename" //文件名 static int major = xxx_major; //预定义的主设备号 struct xxx_dev_t{ //字符设备结构体 struct cdev cdev; }xxx_dev;//这一段和static struct cdev cdev;表达了一种意思 static struct class *xxx_class; //在驱动初始化的代码里调用class_create为该设备创建一个class,再为每个设备调用device_create创建对应的设备 static int xxx_open(struct inode *inode, struct file *filp) //文件节点,仅有一个;file结构体,追踪文件运行时的状态信息,可为NULL { } /*清理未结束的输入输出操作,释放资源,可为null*/ static int xxx_realease(struct inode *inode, struct file *filp) { } /*目标文件结构体指针;对应放置信息的缓冲区(用户空间);要读取的信息长度;读的位置相对于文件开头的偏移*/ static ssize_t xxx_read(struct file *filp, char __user *buf, size_t len, loff_t *offset) { } /*目标文件结构体指针;要写入放置信息的缓冲区;要写入的信息长度;写的位置相对于文件开头的偏移*/ static ssize_t xxx_write(struct file *filp, const char __user *buf, size_t len, loff_t *offset) { } static struct file_operations xxx_fops= //文件操作结构体 { .owner = THIS_MODULE, .read = xxx_read, .write = xxx_writ, .open = xxx_open, .release = xxx_release, .ioctl = xxx_ioctl, }; static int __init xxx_init(void) //设备驱动模块加载函数 { int result; int ret; dev_t xxx_dev_no = MKDEV(xxx_major,0); //由预定义的主设备号生成dev_t设备号 if(xxx_major){ result = register_chrdev_region(xxx_dev_no,1,DEVICE_NAME); //静态申请设备号 }else{ result = alloc_chrdev_region(&xxx_dev_no,0,1,DEVICE_NAME); //动态分配设备号 xxx_major = MAJOR(xxx_dev_no); } if(result<0) return result; cdev_init(&xxx_dev.dev,&xxx_fops); //初始化cdev结构 xxx_dev.cdev.owner = THIS_MODULE; ret = cdev_add(&xxx_dev.cdev,MKDEV(xxx_major,0),1); //注册字符设备 if (ret) { printk("cdev add failed\n"); goto fail1; } xxx_class = class_create(THIS_MODULE,"xxx_class"); if(IS_ERR(xxx_class)) { printk("Err: failed in creating class./n"); goto fail2; } device_create(xxx_class, NULL, MKDEV(xxx_major,0), NULL, DEVICE_NAME); return 0; fail2: cdev_del(&xxx_dev.cdev); fail1: unregister_chrdev_region(xxx_dev_no, 1); return result; } static void __exit xxx_exit(void) //设备驱动模块卸载函数 { device_destory(xxx_class,MKDEV(xxx_major,0)); class_destroy(xxx_class); cdev_del(&xxx_dev.cdev); unregister_chrdev_region(MKDEV(xxx_major,0), 1); } module_init(xxx_init); module_exit(xxx_exit); MODULE_LICENSE("GPL"); MODULE_AUTHOR("your_name");
相关文章推荐
- linux驱动学习之字符设备驱动模板
- linux字符设备驱动开发模板及Makefile
- linux字符设备驱动开发模板及Makefile
- linux2.6字符设备驱动开发模板
- Linux驱动开发--Linux字符设备驱动模板
- 写Linux字符设备驱动模板--测试通过
- linux字符设备驱动模板(新标准)
- Linux驱动开发之字符设备模板
- Linux字符设备驱动之cdev_init()系列
- 手把手教你学linux驱动开发”OK6410系列之02---虚拟字符设备
- Linux字符设备驱动之异步通知
- linux设备驱动开发-高级字符设备操作poll
- linux设备驱动--字符设备模型
- linux 驱动程序 设备模块 设备号 设备文件创建 设备注册 字符驱动设备分析
- Linux 字符设备驱动开发基础(五)—— ioremap() 函数解析
- 18 linux字符设备驱动之设备号
- linux网络设备应用与驱动编程学习4——模板与实例(C)——其它方法
- Linux驱动学习——简单字符设备
- linux驱动开发之字符设备--内核和用户空间数据的交换(sysfs)
- 深入浅出:Linux设备驱动之字符设备驱动