网站大量收购独家精品文档,联系QQ:2885784924

嵌入式操作系统驱动程序编写基础.pptVIP

  1. 1、本文档共10页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多

mknod()系统调用用来创建老式的设备文件设备文件名。在/dev目录下产生一个文件名操作权限和设备类型。其中设备类型指定:S_IFCHR或S_IFBLK。inod设备号16位,主设备号:次设备号可以指定设备号01注册一个设备驱动程序意味着把它与对应的设备文件连接起来02使得对设备文件发出的系统调用可以由内核转化为相应的设备驱动程序对应的函数03按照设备驱动程序模型,分配一个新的device_driver描述符,对应到设备文件上04访问一个没有注册设备驱动程序的设备文件将会返回错误码-ENODEV注册设备驱动程序确定外部中断号自动检测IRQ:内核在linux/interrupt.h中声明了两个用于自动检测IRQ的函数两个函数使用结构如下:检测IRQ函数举例注册外部中断中断程序的注册一个模块被希望来请求一个中断通道(或者IRQ,对于中断请求),在使用它之前要注册它,并且当结束时释放它.函数声明在linux/interrupt.h,实现中断注册接口:中断处理程序:一个中断处理的角色是给它的设备关于中断接收的回应并且读或写数据,根据被服务的中断的含义.第一步常常包括清除接口板上的一位;让大部分硬件设备不产生别的中断直到它们的“中断挂起”位被清除.–即action.中断处理程序与普通c代码没有太大不同,不同的是中断程序在中断期间运行,有如下限制:不能向用户空间发送或接收数据---发生中断的上下文是当前的用户空间,如果发数据,会污染用户空间不能执行有睡眠操作的函数不能调用调度函数---中断优先级很高,内核不支持中断中调度12345每一个中断服务例程都应该∵尽快地释放处理器,把能够推迟的工作尽量后推。中断处理程序的∴上半部和下半部上半部分会立即被内核执行下半部分会被推迟执行:下半部的执行并不需要指明一个确切时间,只要把这些任务推迟,让它们在系统不太繁忙并且中断恢复后执行就可以了。1中断处理程序的上半部和下半部的划分:2如果一个任务对时间非常敏感,将其放在上半部执行5其他所有任务,考虑放置在下半部执行4如果一个任务要保证不被其他中断(特别是相同的中断)打断,将其放在上半部中执行3如果一个任务和硬件相关,将其放在上半部中执行中断处理程序下半部的实现机制:01软中断02Tasklet:基于软中断来实现,但比软中断接口简单,同步要求较低;软中断保留给执行频率及时间要求高的下半部使用。03工作队列041、软中断(32g)的主要数据结构在softirq_vec中定义在softirq_vec数组中每一项对应一个软中断,系统中最多可以有32个软中断。优先级对应于softirq_vec的下标软中断函数及其参数kernel/softirq.cinclude/linux/interrupt.h内核只预定义了6个中断include/linux/interrupt.h优先级4:块设备相关优先级5:处理tasklet优先级2:把数据包传送到网卡优先级6:调度SMP相关优先级1:与时钟中断相关的tasklet优先级3:从网卡接受数据包优先级0:处理高优先级的tasklet和下半部分软中断的初始化初始化软中断函数软中断初始注册函数open_softirq接受三个参数,软中断的序号(如nr置为0)、软中断处理函数以及传递给软中断处理函数的参数软中断处理程序被注册后,触发软中断的函数为raise_softirq;该函数接受要被激活的软中断序号最为参数。例如:1raise_softirq(NET_TX_SOFTIRQ)使该软中断的处理函数net_tx_action处于可运行状态2该软中断处理函数net_tx_action会在内核下次执行软中断do_softirq()时被执行??3自学linux内核的软中断机制?4软中断的触发与执行2、Tasklet机制Tasklet是I/O驱动程序中实现可延迟函数的首选方法---比软中断好建立在HI_SOFTIRQ和TASKLET_SOFTIRQ等软中断之上Tasklet和高优先级的tasklet分别存放在tasklet_vec和tasklet_hi_vec数组中数组的每一项针对一个CPU,代表这个CPU上的tasklet列表分别由tasklet_action和tasklet_hi_action处理找到CPU对应的那个项,遍历执行include/linux/interrupt.h0:enable32410:disable自己写的next指针指向下一个tasklet,它用于将多个t

文档评论(0)

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

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

1亿VIP精品文档

相关文档