24小时服务热线:18923830091

当前位置:芯德斯 >> 解密技术 >> 浏览文章

PIC16F87X系列单片机中断模块探讨

  对芯片解密中的过错攻击技术、硬件安全分析、UV 攻击技术、EEPROM 和 Flash技术分析、安全保护位置的查找以及侵入式攻击与非侵入式攻击技术,芯德斯均拥有透彻的理解和丰富的实战应用经验,经过多次反复实验,可以为每一款芯片提供最具经济价值、最具可靠性、最具成本控制优势的解密技术手法。下面我们介绍一下PIC16F87X系列单片机中断模块,供大家参考。
  PIC16F87X系列单片机可以接收多达14个中断源。中断控制器寄存器INTCON标记着各个中断源的请求,对各个中断设置屏蔽位,对全部中断设置全局屏蔽位。
  PIC16F87X系列的中断包含:TMR0溢出中断(TOIF)、外部中断(INTF)、端口B变化中断(RBIF)、并行从动端口中断(PSPIF)、A/D变换中断、USART异步接收中断(RCIF)和异步发送中断(TXIF)、同步串行端口中断(SSPIF)、CCP1中断(CCPIIF)、TMR2中断(TMR2IF)、TMR1中断、CCP1中断(CCP2)、E2PROM写中断(EEIF)、总线碰撞中断(BCLIF)。
  各个中断采用查询方式进行,即当CPU口向应中断时,事先要通过查询中断标志位去判断是哪个中断产生中断请求,然后执行相应的中断服务程序。
  RB0/INT外中断仍遵守PIC16F87X单片机的中断原则,当有中断时产生中断标志位,由CPU查询识别中断。根据这一原则,可以扩展多个外中断源,CPU响应中断后查询中断标志位识别中断。
  RB0/INT引脚上的外部中断由边沿触发,既可以是上升沿,也可以是下降沿,这由选择寄存器OPTION_REG的INTEDG位(D6)决定。当INTEDG=1时,选择上升沿触发;当INTEDG=0时,选择下降沿触发。一旦检测到引脚上出现有效边沿,就把INTF位(INTCON的D1)置1。这个中断由中断控制位INTE设置允许或禁止。
  为了防止错误的死循环执行同一个中断,在重新开放这个中断之前必须在中断服务程序中用软件对INTF位清0。如果INTE位在进入休眠状态之前已被置1,INT中断可以唤醒在休眠状态下的CPU。GIE位的状态决定处理器是否在被唤醒后转至中断矢量。
  当定时器TIMER0的计数器TMR0计满溢出(即由FFH变成00H)时,硬件将自动把TGIF位置1。其中断可以通过对TOIE位进行设置来控制该中断是否开放。
  当CPU响应RB7、RB4中断时,就有两种情况产生:第一种称为“短脉冲”,即在CPU响应中断期间引脚电平恢复到原始状态,对这种情况CPU不会产生虚假中断现象。第二种称为“宽脉冲”,即在CPU响应中断后引脚电平才恢复到原始状态,恢复到原始状态的过程也产生中断请求,这种情况就是虚假中断现象。
  在端口B的D7~D4引脚上一旦有电平变化就把RBIF位置1,这个中断可以通过对RBIE位进行设置来控制该中断是否开放。

微信扫描二维码咨询