在线客服
扫描二维码
下载博学谷APP扫描二维码
关注博学谷微信公众号
本文就CPU中断响应过程的九个步骤进行简单讲述,希望大家都能通过本文大致了解中断响应过程。
CPU响应中断,就是CPU要去执行相应的中断服务程序,其响应过程是CPU将现在执行程序的指令地址压入堆栈,跳转到中断服务程序入口地址,中断服务程序的入口地址就是中断向量,这个中断向量用2个16位寄存器存放。入口地址是22位的,地址的低16位保存在该向量的低16位,地址的高16位则保存在它的高6位,更高的10位保留。
步骤一:任何一个PIE中断组的外设或外部中断产生中断。如果外设模块内的中断被使能,中断请求将被送到PIE模块。
步骤二:PIE模块将识别出别的PIE中断组x内的y中断(INTx.y)申请,然后相应的PIE中断标志位被锁存:PIEIFRx.y=1。
步骤三:PIE的中断如要送到CPU需满足下面两个条件:
1.相应的使能位必须被设置(PIEIERx.y=1)。
2.相应的PIEACKx位必须被清除。
步骤四:如果满足步骤三中的两个条件,中断请求将被送到CPU并且相应的响应寄存器位被置1(PIEACKx=1)。PIEACKx位将保持不变,除非为了使本组中的其他中断向CPU发出申请而清除该位。
步骤五:CPU中断标志位被置位(CPUIFRx=1),表明产生一个CPU级的挂起中断。
步骤六:如果CPU中断被使能(CPUIERx=1,或DBGIERx=1),并且全局中断使能(INTM=0),CPU将处理中断INTx。
步骤七:CPU识别到中断并且自动保存相关的中断信息,清除使能寄存器(IER)位,设置INTM,清除EALLOW。CPU完成这些任务准备执行中断服务程序。
步骤八:CPU从PIE中获取响应的中断向量。
步骤九:对于复用中断,PIE模块用PIEIERx和PIEIFRx寄存器中的值确定响应中断的向量地址。有以下两种情况:
1.在步骤四中若有更高优先级的中断产生,并使能了PIEIERx寄存器,且PIEIFRx的相应位处于挂起状态,则首先响应优先级更高的中断。
2.如果在本组内没有挂起的中断被使能,PIE将响应组内优先级最高的中断,调转地址使用INTx.1。这种操作相当于处理器的TRAP或INT指令。
CPU进入中断服务程序后,将清除PIEIFRx.y位。需要说明的是,PIEIERx寄存器用来确定中断向量,在清除PIEIERx寄存器时必须注意。
以上就是CPU中断响应过程,讲解的每一个步骤都是干货,大家都弄清楚了吗?觉得有用的小伙伴可以分享出去,给更多需要的人看到。
— 申请免费试学名额 —
在职想转行提升,担心学不会?根据个人情况规划学习路线,闯关式自适应学习模式保证学习效果
讲师一对一辅导,在线答疑解惑,指导就业!
相关推荐 更多
嵌入式工程师待遇怎么样?工资高吗?
嵌入式工程师待遇怎么样?以北京为例的一线城市,嵌入式工程师待遇优渥。不算其他福利,基础月薪怎么也有一万五,工作两三年差不多在三万左右。这样的工资即使是在北京也已经算是高薪了。而且随着物联网和智能硬件的发展,嵌入式技术逐渐与智能学科相结合,相信在未来二三线城市会有更多的工作需求,嵌入式工程师待遇都不会太低。
8542
2019-08-01 11:14:24
2019年流行的DevOps工具推荐
对于还是DevOps的新手来说,“2019年流行的DevOps工具有哪些”无疑是第一位要解决的问题。众所周知,DevOps不仅可以看成一种技术或工具,还是一种强调不同硬件和计算机协同工作的文化。DevOps可以帮助团队从整个编程中获益,因此掌握一些好用的DevOps工具显得格外有必要。本文我们将向大家推荐八款DevOps工具。
6208
2019-12-05 13:02:24
Linux5.6五大功能升级更新介绍
最近,Linux将要发行新的版本,不得不说,这是一个振奋人心的好消息。相信大家都会好奇,Linux5.6版本能给我们带来怎样崭新的体验?本文就来带大家好好了解下Linux5.6 版本中升的五大最新功能,看看这次版本的更新换代能为我们带来哪些确确实实的好处,感兴趣的朋友现在赶紧和小编一起一睹为快吧!
4745
2020-02-10 21:13:56
如何通过建立索引优化SQL?
优化SQL是一个老生常谈的问题,我们可以从多方面入手对SQL进行优化。今天本文主要从应用层来看,如何通过建立索引优化SQL。索引的数据结构B+Tree有着较高的查询性能,因此建立索引主要是对SQL 的查询性能进行优化。下面我们一起来看看建立普通索引、建立复合索引、最左前缀匹配原则、索引下推、覆盖索引、普通索引等等内容吧~
5445
2020-06-24 17:37:23
删除又恢复?微软怎么惹恼了开源社区?
近日,.NET开源社区“再起波澜”。起因是微软在即将发布的 .NET 6 中悄悄删除了 Hot Reload(热重载) 的核心部分,此举彻底激怒了.NET开源社区开发者,他们强烈反对微软这种行为,认为微软此举是不利于 .NET 开源社区健康发展。
3139
2021-10-25 18:19:27