AVR有不同的中断源。每个中断和复位在程序空间都有独立的中断向量。所有的中断事件 都有自己的使能位。当使能位置位,且状态寄存器的全局中断使能位I 也置位时,中断可 以发生。根据程序计数器PC 的不同,在引导锁定位BLB02 或BLB12 被编程的情况下, 中断可能被自动禁止。这个特性提高了软件的安全性。详见 P 209“ 存储器编程” 的描述。
程序存储区的最低地址缺省为复位向量和中断向量。完整的向量列表请参见P 43“ 中断” 列表也决定了不同中断的优先级。向量所在的地址越低,优先级越高。RESET 具有最高 的优先级,第二个为INT0 – 外部中断请求0。通过置位通用中断控制寄存器 (GICR) 的 IVSEL,中断向量可以移至引导Flash的起始处,参见P 43“中断” 。编程熔丝位BOOTRST 也可以将复位向量移至引导Flash 的起始处。具体参见P 196“ 支持引导装入程序 -在写 的同时可以读(RWW, Read-While-Write) 的自我编程能力” 。
任一中断发生时全局中断使能位I 被清零,从而禁止了所有其他的中断。用户软件可以在 中断程序里置位I 来实现中断嵌套。此时所有的中断都可以中断当前的中断服务程序。执 行RETI 指令后I 自动置位。
从根本上说有两种类型的中断。第一种由事件触发并置位中断标志。对于这些中断,程序 计数器跳转到实际的中断向量以执行中断处理程序,同时硬件将清除相应的中断标志。中 断标志也可以通过对其写”1” 的方式来清除。当中断发生后,如果相应的中断使能位为 "0",则中断标志位置位,并一直保持到中断执行,或者被软件清除。类似的,如果全局 中断标志被清零,则所有已发生的中断都不会被执行,直到I 置位。然后挂起的各个中断 按中断优先级依次执行。
第二种类型的中断则是只要中断条件满足,就会一直触发。这些中断不需要中断标志。若 中断条件在中断使能之前就消失了,中断不会被触发。
AVR 退出中断后总是回到主程序并至少执行一条指令才可以去执行其他被挂起的中断。
要注意的是,进入中断服务程序时状态寄存器不会自动保存,中断返回时也不会自动恢 复。这些工作必须由用户通过软件来完成。
使用CLI 指令来禁止中断时,中断禁止立即生效。没有中断可以在执行CLI 指令后发生, 即使它是在执行CLI 指令的同时发生的。下面的例子说明了如何在写EEPROM 时使用这 个指令来防止中断发生以避免对EEPROM 内容的破坏。
汇编代码例程 |
in r16, SREG ; 保存SREG cli ; 禁止中断 sbi EECR, EEMWE ; 启动 EEPROM 写操作 sbi EECR, EEWE out SREG, r16 ; 恢复SREG (I 位) |
C 代码例程 |
char cSREG; cSREG = SREG; /* 保存SREG */ /* 禁止中断*/ _CLI(); EECR |= (1< |
使用SEI 指令使能中断时,紧跟其后的第一条指令在执行任何中断之前一定会首先得到执行。
汇编代码例程 |
sei ; 置位全局中断使能标志 sleep ; 进入休眠模式,等待中断发生 ; 注意: 在执行任何被挂起的中断之前MCU 将首先进入休眠模式 |
C 代码例程 |
_SEI(); /* 置位全局中断使能标志*/ _SLEEP(); /* 进入休眠模式,等待中断发生*/ /* 注意: 在执行任何被挂起的中断之前MCU 将首先进入休眠模式*/ |
中断响应时间
AVR 中断响应时间最少为4 个时钟周期。4 个时钟周期后,程序跳转到实际的中断处理例程。在这4 个时钟期期间PC 自动入栈。在通常情况下,中断向量为一个跳转指令,此跳转需要3 个时钟周期。如果中断在一个多时钟周期指令执行期间发生,则在此多周期指令执行完毕后MCU 才会执行中断程序。若中断发生时MCU 处于休眠模式,中断响应时间还需增加4 个时钟周期。此外还要考虑到不同的休眠模式所需要的启动时间。
中断返回需要4 个时钟。在此期间PC( 两个字节) 将被弹出栈,堆栈指针加二,状态寄存器SREG 的I 置位。
上一篇:ATmega8 Flash程序存储器
下一篇:ATmega8 指令执行时序
推荐阅读最新更新时间:2024-11-06 10:33
设计资源 培训 开发板 精华推荐
- AM1G-1212DH30Z ±12V 1 瓦 DC-DC 转换器的典型应用
- AM30EW-240515TZ 5V 单路输出 DC/DC 转换器的典型应用
- C3010198_OC6701B芯片方案验证板
- LTC3634HFE 降压稳压器的典型应用电路,具有使用两个输入电源的 2 相 VTT 终端
- LT3471EDD 演示板,采用 3mm-3mm DFN 的双通道 1.3A、1.2MHz 逆变器
- 带有外部 PNP 饱和开关的 MC33063A 降压开关转换器的典型应用
- LTC3403EDD 演示板、WCDMA 蜂窝电话降压稳压器、2.7V 至 5V 输入、600mA 输出
- EVAL-AD977ACB,用于 AD977A 16 位、200 KSPS 模数转换器的评估板
- 使用 Analog Devices 的 LTC1174CN8-3.3 的参考设计
- FRDM-KW41Z: 面向Kinetis® KW41Z/31Z/21Z MCU的Freedom开发套件