虚拟字符驱动设备程序.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下的设备驱动程序被组织为一组完成不同任务的函数的集合,在应用程序看来,硬件设备只是一个设备文件,应用程序可以像操作普通文件一样对硬件设备进行操作,如open?()、close?()、read?()、write?()?等。 然后Linux主要将设备分为二类:字符设备和块设备。字符设备是指设备发送和接收数据以字符的形式进行;而块设备则以整个数据缓冲区的形式进行。字符设备的驱动相对比较简单。 由于驱动程序是内核的一部分,因此我们需要给其添加模块初始化函数,该函数用来完成对所控设备的初始化工作.并调用register_chrdev()?函数注册字符设备:? static?int?__init?gobalvar_init(void)?{? ?if?(register_chrdev(MAJOR_NUM,??gobalvar?,?gobalvar_fops))?? {? ??//…注册失败? ?}??else {? ??//…注册成功? ?} ?}? ? 其中,register_chrdev函数中的参数MAJOR_NUM为主设备号,gobalvar为设备名,gobalvar_fops为包含基本函数入口点的结构体,类型为file_operations。当gobalvar模块被加载时,gobalvar_init被执行,它将调用内核函数register_chrdev,把驱动程序的基本入口点指针存放在内核的字符设备地址表中,在用户进程对该设备执行系统调用时提供入口地址。? 与模块初始化函数对应的就是模块卸载函数,需要调用register_chrdev()的反函数?unregister_chrdev():? static?void?__exit?gobalvar_exit(void)? {? if?(unregister_chrdev(MAJOR_NUM,??gobalvar?))? ? {? ?? //…卸载失败? ?}??else?? {? ?? //…卸载成功? ? } }? 二、下面是该字符驱动设备的整体函数代码及分步的分析: Test_drv.c: #include linux/module.h #include linux/init.h #include linux/fs.h #include linux/kernel.h #include linux/slab.h #include linux/types.h #include linux/errno.h #include linux/cdev.h #include asm/uaccess.h #define TEST_DEVICE_NAME test_dev #define BUFF_SZ 1024 /* 全局变量 */ static struct cdev test_dev; unsigned int major=0; static char *data=NULL; dev_t dev; /* 读函数 */ static ssize_t test_read(struct file *file,char *buf,size_t count,loff_t *f_pos) { /buf指向缓冲区的指针 int len; if(count0) /count读取和写入的字节数 { return -EINVAL; } len=strlen(data); count=(lencount) count:len; if(copy_to_user(buf,data,count)) //将内核缓冲的数据复制到用户空间 { return -EFAULT; } return count; } /* 写函数 */ static ssize_t test_write(struct file *file,const char *buffer,size_t count,loff_t *f_pos) { if(count0) { return -EINVAL; } memset(data,0,BUFF_SZ); count=(BUFF_SZcount) ?count:BUFF_SZ; if(copy_from_user(data,buffer,count

文档评论(0)

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

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

1亿VIP精品文档

相关文档