基于ARM嵌入式Linux字符设备驱动设计研究.docVIP

基于ARM嵌入式Linux字符设备驱动设计研究.doc

  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文档。上传文档
查看更多
基于ARM嵌入式Linux字符设备驱动设计研究

基于ARM嵌入式Linux字符设备驱动设计研究   【摘要】本文描述了基于ARM嵌入式Linux的字符设备驱动设计,设备调用的过程,阐述了嵌入式linux下字符设备驱动设计中的关键技术,包括设备的注册、中断响应卸载等。   【关键词】字符设备;驱动设计;设备调用   1.引言   随着嵌入式系统的发展,嵌入式Linux以其稳定性和开放源代码的优点在嵌入式系统的开发中得到广泛应用。越来越多的软硬件厂商使用嵌入式Linux来开发自己的产品,对于嵌入式Linux平台开发设备的驱动程序和应用程序的需求在成倍增长。   2.驱动程序   驱动程序为应用程序提供了操作设备的接口;Linux设备分为字符设备,块设备和网络设备。字符设备是以字节流的方式被访问的设备,是所有设备中相对简单的设备。一般的访问方式是字符设备被映射到Linux文件系统的文件和目录,通过文件系统的系统调用接口open(),write(),read(),close()等函数访问字符设备,实现设备的操作。   3.系统字符设备驱动程序的设计方法   Linux驱动程序是设备与具体的应用程序的中间层,它提供操作设备的接口,应用程序员不需要知道具体设备工作细节,只要调用一组标准化的函数就能完成对设备的操作,这些标准化的函数与具体的驱动没有关系,而将这些函数映射到作用于具体设备上的操作则与驱动程序相关。   以下具体介绍字符设备调用及驱动的实现方法。   一般对于字符设备的访问分为:   初始化、中断调用响应、释放等过程。   3.1 初始化   设备初始化通过初始化函数实现,Linux系统中,设备驱动的初始化函数负责注册设备,并完成驱动程序必要的初始化以及申请中断等。Linux系统使用module_init宏指定初始化函数。在初始化函数中调用regiSTer_chrdev函数向系统注册字符设备,通过request_IRq函数申请中断。例如初始化函数如下:   static int__init moto_init(void){   int ret;   ret=register_chrdev(MOTO_MAJOR,”moto”,moto_fops);   if(ret){   printk(KERN_ERR”%s:can’t get major %d.\n,   __func__,MOTO_MAJOR);   return ret;   }   printk(KERN_INFO”%s:register moto device successfully.\n”,__func__);   return 0;   }其中,register_chrdev函数的第一个参数为主设备号,如果为0则系统为此驱动程序动态地分配一个主设备号;第二个参数是设备名称,这里是以moto为设备名称;第三个参数moto_fops是默认的struct file_operations结构体。   3.2 中断   在Linux系统中,中断是由系统来管理与维护的。中断服务子程序在初始化函数中调用request_irq函数与相应中断号关联,并将该中断的相关信息添加到系统的中断信息列表中。中断发生时,Linux系统响应中断号来实现中断处理程序的执行。   3.3 释放   释放是通过清除函数来实现。清除函数的功能和初始化函数的功能相反,它将驱动程序所占用的系统资源、中断号进行释放。Linux系统使用module_exit宏指定清除函数。   3.4 设备驱动接口的实现示例   在Linux内核中,字符设备使用struct file_operations结构体来实现设备的各种操作接口,这些操作主要用来实现系统调用,命名为open、read等等。file_operations结构是定义在中的函数指针数组,每个设备文件都与它自己的操作函数相关联。编写字符设备驱动程序,主要是实现struct file_operations结构中的各个函数。   字符设备驱动的设计主要是实现open、read、write和release这四个方法接口。file_operation结构成员如下:   struct file_operations device_fops={   open方法提供给驱动程序以初始化的能力,从而为以后的操作完成初始化做准备。   当多个设备共用一个驱动的情况出现时,驱动中的open方法程序框架如下:   int device_open(struct inode *inode, struct file*filp){int minor=MINOR(kdev);//设备号的读取switch(minor){   case first_device:dev

文档评论(0)

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

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

1亿VIP精品文档

相关文档