本节说明ATmega128 的中断处理。更一般的AVR 中断处理请参见 P 12“ 复位和中断处理” 。
Notes:
1. 当熔丝位BOOTRST被编程时,复位后程序跳转到Boot Loader。请参见 P 255“ 支持引导装入程序 – 在写的同时可以读(RWW, Read-While-Write) 的自我编程能力” 。
2. 当寄存器MCUCR的IVSEL置位时,中断向量转移到Boot区的起始地址。此时各个中断向量的实际地址为表中地址与Boot 区起始地址之和。
3. 地址为$0030 - $0044 的中断在ATmega103 兼容模式中不存在。
Table 24给出了不同的BOOTRST/IVSEL设置下的复位和中断向量的位置。如果程序永远不使能中断,中断向量就没有意义。用户可以在此直接写程序。同样,如果复位向量位于应用区,而其他中断向量位于Boot 区,则复位向量之后可以直接写程序。反过来亦是如此。
Note: Boot 区复位地址列P 266Table 112 。对于熔丝位BOOTRST,“1” 表示未编程, “0” 表示已编程。
ATmega128 典型的复位和中断设置如下:
当熔丝位BOOTRST 未编程, Boot 区为8K 字节,且中断使能之前寄存器MCUCR 的 IVSEL 置位时,典型的复位和中断设置如下:
当熔丝位BOOTRST 已编程,且Boot 区为8K 字节时,典型的复位和中断设置如下:
当熔丝位BOOTRST 已编程, Boot 区为8K 字节时,且中断使能之前寄存器MCUCR 的 IVSEL 置位时,典型的复位和中断设置如下:
在应用区和Boot 区之间移动中断
通用中断控制寄存器决定中断向量表的放置地址。
MCU 控制寄存器- MCUCR
• Bit 1 – IVSEL: 中断向量选择
当IVSEL 为"0“ 时,中断向量位于Flash 存储器的起始地址;当IVSEL 为"1“ 时,中断向量转移到Boot 区的起始地址。实际的Boot 区起始地址由熔丝位BOOTSZ 确定。具体请参考P 255“ 支持引导装入程序 – 在写的同时可以读(RWW, Read-While-Write) 的自我编程能力” 。为了防止无意之间改变中断向量表,修改IVSEL 时需要遵照如下过程:
1. 置位中断向量修改使能位IVCE。
在紧接的4 个时钟周期里将需要的数据写入IVSEL,同时对IVCE 写”0”。
执行上述序列时中断自动被禁止。其实,在置位IVCE 时中断就被禁止了,并一直保持到写IVSEL 操作之后的下一条语句。如果没有IVSEL 写操作,则中断在置位IVCE 之后的4 个时钟周期保持禁止。状态寄存器的位I 不受此序列的影响。
Note:
若中断向量位于Boot区,且Boot锁定位BLB02被编程,则执行应用区的程序时中断被禁止;若中断向量位于应用区,且Boot 锁定位BLB12 被编程, 则执行Boot 区的程序时中断被禁止。有关Boot 锁定位的细节请参见 P 255“ 支持引导装入程序 – 在写的同时可以读(RWW, Read-While-Write) 的自我编程能力” 。
• Bit 0 – IVCE: 中断向量修改使能
改变IVSEL 时IVCE 必须置位。在IVCE 或IVSEL 写操作之后4 个时钟周期, IVCE 被硬件清零。如前面所述,置位IVCE 将禁止中断。代码如下:
汇编代码例程 |
Move_interrupts: ; 使能中断向量的修改 ldi r16, (1< ; 将中断向量转移到boot 区 ldi r16, (1< ret |
C 代码例程 |
void Move_interrupts(void) { /* 使能中断向量的修改 */ MCUCR = (1< MCUCR = (1< |
上一篇:ATmega128 看门狗定时器
下一篇:ATmega128 基准电压使能信号和启动时间
推荐阅读最新更新时间:2024-11-08 16:38
设计资源 培训 开发板 精华推荐
- FEBFAN2306_LVA,基于 FAN2306 6A 超声波模式同步降压稳压器的评估板
- HV9985DB1,3 通道 LED 驱动器演示板
- AM1DR-1209SH30Z 9V 1 瓦 DC-DC 转换器的典型应用
- LTC1779ES6 演示板,单路或双路锂离子电池降压至 1.8V @ 250mA
- LT8570IDD-1 1.5MHz、5V 至 12V 输出升压转换器的典型应用
- 1.45V、6 芯、镍镉便携式电池充电器
- Loli 高频头
- AM2G-4805DH30Z ±5V 2 瓦 DC-DC 转换器的典型应用
- TA4401CT频段功放2.45GHz无线局域网典型应用
- 使用 Analog Devices 的 AD974 的参考设计