当前位置:易博PCB抄板工作室 >> 技术文档 >> IC解密知识:中断的响应过程

IC解密知识:中断的响应过程

  中断的响应过程有哪些主要过程呢?有是在满足什么条件之下才能触发中断的响应的发生呢?下面由IC解密工程师详解这一问题:
  若某个中断源通过编程设置,处于被打开的状态,并满足中断响应的条件,而且①当前正在执行的那条指令已被执行完
  1、当前末响应同级或高级中断
  2、不是在操作IE,IP中断控制寄存器或执行REH指令则单片机响应此中断。
  在正常的情况下,从中断请求信号有效开始,到中断得到响应,通常需要3个机器周期到8个机器周期。中断得到响应后,自动清除中断请求标志(对串行I/O端口的中断标志,要用软件清除),将断点即程序计数器之值(PC)压入堆栈(以备恢复用);然后把相应的中断入口地址装入PC,使程序转入到相应的中断服务程序中去执行。
  各个中断源在程序存储器中的中断入口地址如下:
  中断源 入口地址
  INT0(外部中断0) 0003H
  TF0(TO中断) 000BH
  INT1(外部中断1) 0013H
  TFl(T1中断) 001BH
  RI/TI(串行口中断) 0023H
  由于各个中断入口地址相隔甚近,不便于存放各个较长的中断服务程序,故通常在中断入口地址开始的二三个单元中,安排一条转移类指令,以转入到安排在那儿的中断服务程序。以T1中断为例,其过程下如图四所示。
  由于5个中断源各有其中断请求标志0,TF0,IEl,TFl以及RI/TI,在中断源满足中断请求的条件下,各标志自动置1,以向CPU请求中断。如果某一中断源提出中断请求后,CPU不能立即响应,只要该中断请求标志不被软件人为清除,中断请求的状态就将一直保持,直到CPU响应了中断为止,对串行口中断而言,这一过程与其它4个中断的不同之处在于;即使CPU响应了中断,其中断标志RI/TI也不会自动清零,必须在中断服务程序中设置清除RI/TI的指令后,才会再一次地提出中断请求。
  CPU的现场保护和恢复必须由被响应的相应中断服务程序去完成,当执行RETI中断返回指令后,断点值自动从栈顶2字节弹出,并装入PC寄存器,使CPU继续执行被打断了的程序。