[2018年最新整理]chp7下半段和推后执行的工作.pptVIP

[2018年最新整理]chp7下半段和推后执行的工作.ppt

  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文档。上传文档
查看更多
[2018年最新整理]chp7下半段和推后执行的工作

第7章 下半段和推后执行的工作 下半部 下半部的任务主要是执行与中断相关的工作,这些工作没有被中断服务程序本身完成. 历史 最初的机制:BH 2.5内核后被废止 任务队列 2.5内核之后被工作队列替代 2.3内核引入软中断(softirq)和tasklet 32个软中断,实际上只用到6个 tasklet实现于软中断之上 2.5内核引入工作队列 为什么要把中断分为两部分 中断服务程序异步执行,可能会中断其他的重要代码,包括其他中断服务程序。因此,为了避免被中断的代码延迟太长的时间,中断服务程序需要尽快运行. 希望限制中断服务程序所做的工作,因此处理中断的时间越短越好。 中断服务程序只作必须的工作,其他的工作推迟到以后处理。 2.6内核的三种方法 : softirqs, tasklet, 和work queue 软中断Softirqs kernel/softirq.c定义了一个32个元素的结构数组 /*本结构代表了一个软中断项*/ struct softirq_action { void (*sction) (struct softirq_action *);/*带执行的函数*/ void *data; /*传给函数的指针*/ } 固定 – 登记的softirqs最大数目不能动态改变. 工作时允许中断. 一个softirq不能抢占另一个。它只能被中断服务程序抢占. 另一个softirq,甚至是同一个可运行于另一个CPU. 使用软中断 分配索引 注册处理程序 open_softirq(索引号,处理程序,NULL) 触发软中断 raise_softirq(索引号) softirq_pending(CPU)宏:返回指定CPU上未处理的软中断 软中断的执行 中断处理程序在返回前标记它的软中断,使其在稍后执行 检查和执行待处理的软中断的时机: -从硬件中断代码返回; - 在ksoftirqd内核线程中; - 显式检查和处理软中断的代码中 使用软中断的情况:对时间要求最严格和最重要的下半部使用 - 网络和SCSI设备 - 内核定时器和tasklet Softirqs的执行 u32 pending = softirq_pending(cpu); if (pending) { struct softirq_action *h = softirq_vec; softirq_pending(cpu) = 0; do { if (pending 1) h-action(h); h++; pending = 1; } while (pending); } Tasklet 的类型 Tasklets的结构 struct tasklet_struct { struct tasklet_struct *next; unsigned long state; //见下 atomic_t count; /*reference count 锁*/ void (*func)(unsigned long); /*tasklet 处理函数*/ unsigned long data; /*tasklet 处理函数的参数 */ }; Tasklets Tasklets 实现于softirq之上,实际上也是softirqs. Tasklet 同时只运行于一个 CPU. 注: softirq,甚至是同一个可运行于另一个CPU. 不同的tasklets 可同时运行于不同的CPU. tasklet_schedule()的调度过程 检查tasklet的状态是否为TASKLET_STATE_SCHED,如果是,则立即返回; 保存中断状态,禁止本地中断; 把需要调度的tasklet指定处理器的tasklet_vec或tasklet_hi_vec链表; 唤起TASKLET_SOFTIRQ或HI_SORTIRQ软中断,这样在下一次调用do_softirq()时会执行该tasklet; 恢复中断到原状态并返回。 tasklet处理过程 禁止中断,取当前处理器的tasklet_vec或tasklet_hi_vec链表; 将当前处理器的这两个链表清空; 允许响应中断; 循环遍历链表上的每一个待处理的tasklet; 如果是多处理器系统,则检查TASKLET_STATE_RUN标志判断这个tasklet是否在其他处理器上运行,如果在运行,则跳转掉下一个tasklet,否则置其状态为TASKLET_STATE_RUN; 检查tasklet是否

文档评论(0)

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

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

1亿VIP精品文档

相关文档