1.中断响应的条件1)当前机器周期还不是正在执行指令的最后一个机器周期,任何中断请求都得不到响应。2)同优先级或高优先级的中断已在进行中,此中断不会被响应。中断查询的机器周期正好是指令的最后一个机器周期时,查询占1个机器周期,响应中断执行隐指令LCALL需两个机器周期,则共需3个机器周期。......
2023-11-17
响应任意一个中断后,都需要对断点和现场进行保护,中断返回时必须恢复断点和现场,而断点的保护和恢复由硬件自动完成(即自动工作方式,将当前PC自动压入堆栈进行断点保护,将堆栈保护的断点送给PC完成断点恢复)。因此在中断处理程序中开始必须保护好现场,中断响应完成后返回前必须恢复好现场,它是用户程序必须完成的内容(即指令工作方式,中断处理程序中编写现场保护和恢复程序),以便返回时程序能正确执行。具体中断处理程序的流程如图6-2所示。
1.关中断
在低优先级中断保护现场前要将中断关掉,以防止现场没保护好却响应了高优先级中断而破坏了现场。
2.保护现场
一般是用堆栈指令将原程序中用到的寄存器、存储单元等的内容压入堆栈保护起来。因为中断发生的随机性,所以要按照最极端的情况考虑保护的内容,保护的内容一定要全面。
3.开中断
现场保护好后开中断,允许响应高优先级中断即中断嵌套。
4.中断处理主体
中断处理主体是响应此中断的功能程序。
5.关中断
在低优先级中断恢复现场前要将中断关掉,以防止现场没恢复好却响应了高优先级中断而破坏了现场。
6.恢复现场
将保护在堆栈中的数据弹出来恢复现场,必须按照先进后出的原则编写程序,保证现场的正确恢复,恢复时弹出的数量必须和保护时压栈的数量相等,否则将导致自动恢复的断点错误。(www.chuimin.cn)
7.开中断
现场恢复好后开中断。
8.返回
此时CPU自动将压入到堆栈的断点地址弹回到程序计数器PC,从而使CPU继续执行刚才被中断的程序。
可以看出:中断优先级别高的(即IP的对应位设为1)在保护现场和恢复现场时无需关中断和开中断,中断嵌套只能出现在中断主体程序中。
【例6-2】外部中断1的优先级设为0,且主程序中有20H、R0、DPTR、PSW、A的内容需要保护,编制相应的程序。
【程序】
图6-2 中断处理程序流程图
有关单片机基础及应用的文章
1.中断响应的条件1)当前机器周期还不是正在执行指令的最后一个机器周期,任何中断请求都得不到响应。2)同优先级或高优先级的中断已在进行中,此中断不会被响应。中断查询的机器周期正好是指令的最后一个机器周期时,查询占1个机器周期,响应中断执行隐指令LCALL需两个机器周期,则共需3个机器周期。......
2023-11-17
8051有5个中断源,即两个外部中断、两个定时/计数器中断和一个串行发送/接收中断。1.外部中断外部中断是由连接到单片机外部引脚信号变化而引起的中断,反映外部某一事件的发生。CPU是在每个机器周期的S5P2检测P 3.2和P 3.3上的信号,如果是有效信号则对定时器控制寄存器TCON中的IE0或IE1置1,建立中断请求标志。表6-1中断源的主要内容及说明......
2023-11-17
中断优先级的控制或设置由中断允许控制寄存器IE、优先级控制寄存器IP的设置和同一优先级中的优先顺序决定。表6-3同级中断的优先顺序表2.中断优先级的控制原则1)当CPU正在执行中断服务程序时,又有中断优先级更高的中断申请产生,这时CPU就会暂停当前的中断服务转而处理高优先级的中断申请,待高优先级中断处理程序完毕再返回原中断程序断点处继续执行,即可以中断嵌套。......
2023-11-17
CPU对中断处理过程包括中断初始化、中断响应、保护现场、中断服务程序处理、中断撤销和中断返回。所以在进入中断服务子程序后,一般都要保护现场,再执行中断服务程序,返回主程序前再恢复现场,用户在编制中断处理程序时必须要考虑上述问题。......
2023-11-04
MCS-51单片机有5个中断源,中断允许控制寄存器IE的功能是设置所有中断是允许状态或禁止状态。中断允许控制寄存器IE的每位定义如下:1.EA:中断允许总控制位EA=0时,禁止所有中断,CPU屏蔽所有中断;EA=1时,总的中断允许,CPU开放中断,但具体每个中断是否被允许取决于该中断的允许位。2.EX0和EX1:外部中断允许控制位EX0为外部中断0的中断允许位,EX1为外部中断1的中断允许位。......
2023-11-17
MCS-51单片机的算术运算类指令包括加、减、乘、除、加1、减1等指令。这类指令有ADD、ADDC、INC、SUBB、DEC、DA、MUL、DIV共8种。表3-3算术运算类指令注:√表示该指令影响某一标志位。运算结果对PSW的影响同上述4条ADD指令。6.十进制调整指令十进制调整指令只有以下1条:该指令用于BCD码加法运算时,对BCD码的加法运算结果自动进行调整,但对BCD码的减法运算不能用此指令来调整。在运算过程中,单片机按二进制规则进行运算。......
2023-11-17
多分支结构中具有两个以上条件可供选择,可使用无条件间接转移指令“JMP@A+DPTR”来实现。使用散转指令设计多分支程序结构时可采用下面的两种方法:1)数据指针DPTR固定,根据累加器A的内容,程序转入相应的分支程序中去。采用转向地址表实现多分支结构,转移的目标程序序号存放于R7中。......
2023-11-17
相关推荐