Linux 2.6.32内核字符设备驱动模板.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
引言:Linux驱动中,字符设备的设计一般会占产品驱动开发的90%以上,作者根据驱动开发的实际经验,总结了一个标准的字符设备驱动的模板,仅供参考。 //=======================字符设备驱动模板开始 ===========================// #define CHAR_DEV_DEVICE_NAME char_dev // 设备名 struct class *char_dev _class; // class结构用于自动创建设备结点 static int major = 0;/* 0表示动态分配主设备号,可以设置成未被系统分配的具体的数字。*/ static struct cdev char_dev_devs;// 定义一个cdev结构 // 设备建立子函数,被char_dev_init函数调用 static void char_dev_setup_cdev(struct cdev *dev, int minor, struct file_operations *fops) { int err, devno = MKDEV(major, minor); cdev_init(dev, fops); dev-owner = THIS_MODULE; dev-ops = fops; err = cdev_add(dev, devno, 1); if( err ) { printk(KERN_NOTICE Error %d adding char_dev %d\n, err, minor); } } // file_operations 结构体设置,该设备的所有对外接口在这里明确,此处只写出了几常用的 static struct file_operations char_dev_fops = { .owner = THIS_MODULE, .open = char_dev_open, // 打开设备 .release = char_dev_release, // 关闭设备 .read = char_dev_read, // 实现设备读功能 .write = char_dev_write, // 实现设备写功能 .ioctl = char_dev_ioctl, //实现设备控制功能 }; // 进行初始化设置,打开设备,对应应用空间的open 系统调用 int char_dev_open (struct inode *inode, struct file *filp) { ... // 这里可以进行一些初始化 return 0; } // 释放设备,关闭设备,对应应用空间的close 系统调用 static int char_dev_release (struct inode *node, struct file *file) { ... // 这里可以进行一些资源的释放 return 0; } // 实现读功能,读设备,对应应用空间的read 系统调用 ssize_t char_dev_read (struct file *file,char __user *buff,size_t count,loff_t *offp) { ... return 0; } // 实现写功能,写设备,对应应用空间的write 系统调用 ssize_t char_dev_write(struct file *file,const char __user *buff,size_t count,loff_t *offp) { ... return 0; } // 实现主要控制功能,控制设备,对应应用空间的ioctl 系统调用 static int char_dev _ioctl(struct inode *inode,struct file *file,unsigned int cmd,unsigned long arg) { ... return 0; } // 设备初始化 static int char_dev_init(void) { int result; dev_t dev = MKDEV(major, 0); if( major ) { // 给定设备号注册 result = register_chrdev_region(dev, 1, CHAR_DEV_DEVICE_NAME); } else { // 动态分配设备号 result = alloc_chrdev_

文档评论(0)

hong333666 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档