资料介绍
//CM3 有 最多240个中断(通常外部中断写作IRQs),就是 软件上说的 IRQ CHANAELx(中断通道号x)
每个中断有自己的可编程的中断优先级【 有唯一对应的 中断优先级寄存器 】。由于CM3支持 硬件中断嵌套,所以可以有 256 级的可编程优先级和 256级中断嵌套【 书上称:抢占(preempt) 优先级】
所以大家可以设:
IRQ CHANAEL 0 通道 = 2 中断优先级 WWDG 窗口定时器中断
IRQ CHANAEL 1 通道 = 0 中断优先级 PVD 联到EXTI的电源电压检测(PVD)中断
IRQ CHANAEL 3 通道 = 255 中断优先级 RTC 实时时钟(RTC)全局中断
IRQ CHANAEL 6 通道 = 10 中断优先级 EXTI0 EXTI线0中断
。..。.
IRQ CHANAEL 239 通道 = (0
这个实在是太恐怖了! 是的,其实CM3 并没有这样做。
实在的芯片例如STM32等就只有设计来可用才64级可编程优先级和8级中断嵌套。
对 64级中断就是说:( INT0 到 INT63)这个大家比较好理解,其它的64···239就不用了。
IRQ CHANAEL 0
。。。
IRQ CHANAEL 63
而8级中断嵌套这又是何解呢?
是这样的,上面说 一个 【中断】对应 一个【中断优先级寄存器】,而这个寄存器是 8 位的。
当然就是 256级了。而现在就用了 它其中的 BIT7,IT6,BIT5 三位来表示,而且是MSB对齐的。
用了3 个位来表达优先级(MSB 对齐的我们能够使用的8 个优先级为:0x00(最高),0x20,0x40,0x60,0x80,0xA0,0xC0 以及0xE0。)
这样我们在【中断优先级寄存器】就不能按理论的填 0到255之间的数了,而只能填0x00(最高),0x20,0x40,0x60,0x80,0xA0,0xC0 以及0xE0。)
所以大家可以设:
IRQ CHANAEL 0 通道 = 0x20 中断优先级 WWDG 窗口定时器中断
IRQ CHANAEL 1 通道 = 0x40 中断优先级 PVD 联到EXTI的电源电压检测(PVD)中断
IRQ CHANAEL 3 通道 = 0x20 中断优先级 RTC 实时时钟(RTC)全局中断
IRQ CHANAEL 6 通道 = 0xA0 中断优先级 EXTI0 EXTI线0中断
。..。.
IRQ CHANAEL 63 通道 = 【0x00(最高),0x20,0x40,0x60,0x80,0xA0,0xC0 以及0xE0。)】
大家注意到了,上面通道0和通道3 的优先级都是0X20, 这怎么办?
// 如果优先级完全相同的多个异常同时悬起,则先响应异常编号最小的那一个。如IRQ #0会比IRQ #3 先得到响应
而且文中还讲了 【优先级分组】,这又是什么回事?
其实我回头看来,这个【优先级分组】和【抢占优先级】【亚优先级】都毫无意义的。
如果当时用 256级即是 把【中断优先级寄存器】的8位都全用上,就没这个必要了。还什么优先级分组呢!
就是因为厂家现在【偷工减料】,才搞出这个明堂来的。
是这样的,在 应用程序中断及复位控制寄存器(AIRCR) 中的 10:8 位【3位】是表示【优先级分组】
它作用主要是 用于对【中断优先级寄存器】『我们现在中用了BIT7,BIT6,BIT5三位』的功能的说明。
有一个表,在《Cortex-M3 权威指南》的110页, 例如我们把AIRCR的10:8 位设为【5】 ,查表可得【抢占优先级】=【7:6】,【亚优先级】=【5:0】,对于【中断优先级寄存器】只用了BIT7,6,5, 因此我们可以看作是 【7:6】,【5】。那4-0 可以不管。
现在我们的 IRQ0=0X20, IRQ3=0X20, 也就是 【0 0 1 0 】『 bit7=0,bit6=0,bit5=1,bit4=0』
因为大家(IRQ0/IRQ3)的 【抢占优先级】=【7:6】都是0, 说明它们的中断相应级别是一样的。
再继续判断它们哪个更优先的责任就要看【5】,结果连【5】都是一样的!
那就按默认:
// 如果优先级完全相同的多个异常同时悬起,则先响应异常编号最小的那一个。如IRQ #0会比IRQ #3 先得到响应
由于CM3没有 进中断【关全局中断相应】这事,只要是中断通道打开了,就会存在 通道间的 嵌套,即是会发生【抢占】的情况了。
上面就简短的说明,如果要详细理解,可以看《Cortex-M3 权威指南》。
有任何理解不当,请各位多多指教!
补充注意:
“2)抢占式优先级别相同的中断源之间没有嵌套关系;”
所以大家可以设:
IRQ CHANAEL 0 通道 = 0x20 中断优先级 WWDG 窗口定时器中断
IRQ CHANAEL 1 通道 = 0x40 中断优先级 PVD 联到EXTI的电源电压检测(PVD)中断
IRQ CHANAEL 3 通道 = 0x20 中断优先级 RTC 实时时钟(RTC)全局中断
IRQ CHANAEL 6 通道 = 0xA0 中断优先级 EXTI0 EXTI线0中断
这样 0 通道和3 通道就不会有嵌套情况,而是0 通道按默认比3 通道优先高些。
而0 通道与1 通道就会有嵌套情况。
芯片复位后,默认的优先级分组 是 0, 就是 【7:1】表示抢占式优先级,【0】表示亚优先级,这样对于MSB对齐的 8 个优先级为:0x00(最高),0x20,0x40,0x60,0x80,0xA0,0xC0 以及0xE0。)
使用就很方便了,建议大家就用默认的默认的优先级分组 是 0,也就是复位后的值,哈哈!
例如下面的两个按键,都使用外中断方式, 使用了PD.3,和PD.4两个引脚。这两个中断的优先级都是0X20,按默认的优先级分组,它们之间不会发生中断嵌套。
/* Enable the EXTI3 Interrupt on PD.3 */
STM32_Nvic_Regs-》Priority[9].all=0x20; // 中断的优先级是 0X20
STM32_Nvic_Regs-》Enable[0].bit.INT9=1; // 开INT9 中断 IRQ9
/* Enable the EXTI4 Interrupt on PD.4 */
STM32_Nvic_Regs-》Priority[10].all=0x20; // 中断的优先级是 0X20
STM32_Nvic_Regs-》Enable[0].bit.INT10=1; // 开INT10 中断 IRQ10
我也是靠看这本书才弄懂的:
Cortex-M3 权威指南
Joseph Yiu 著
宋岩 译
每个中断有自己的可编程的中断优先级【 有唯一对应的 中断优先级寄存器 】。由于CM3支持 硬件中断嵌套,所以可以有 256 级的可编程优先级和 256级中断嵌套【 书上称:抢占(preempt) 优先级】
所以大家可以设:
IRQ CHANAEL 0 通道 = 2 中断优先级 WWDG 窗口定时器中断
IRQ CHANAEL 1 通道 = 0 中断优先级 PVD 联到EXTI的电源电压检测(PVD)中断
IRQ CHANAEL 3 通道 = 255 中断优先级 RTC 实时时钟(RTC)全局中断
IRQ CHANAEL 6 通道 = 10 中断优先级 EXTI0 EXTI线0中断
。..。.
IRQ CHANAEL 239 通道 = (0
这个实在是太恐怖了! 是的,其实CM3 并没有这样做。
实在的芯片例如STM32等就只有设计来可用才64级可编程优先级和8级中断嵌套。
对 64级中断就是说:( INT0 到 INT63)这个大家比较好理解,其它的64···239就不用了。
IRQ CHANAEL 0
。。。
IRQ CHANAEL 63
而8级中断嵌套这又是何解呢?
是这样的,上面说 一个 【中断】对应 一个【中断优先级寄存器】,而这个寄存器是 8 位的。
当然就是 256级了。而现在就用了 它其中的 BIT7,IT6,BIT5 三位来表示,而且是MSB对齐的。
用了3 个位来表达优先级(MSB 对齐的我们能够使用的8 个优先级为:0x00(最高),0x20,0x40,0x60,0x80,0xA0,0xC0 以及0xE0。)
这样我们在【中断优先级寄存器】就不能按理论的填 0到255之间的数了,而只能填0x00(最高),0x20,0x40,0x60,0x80,0xA0,0xC0 以及0xE0。)
所以大家可以设:
IRQ CHANAEL 0 通道 = 0x20 中断优先级 WWDG 窗口定时器中断
IRQ CHANAEL 1 通道 = 0x40 中断优先级 PVD 联到EXTI的电源电压检测(PVD)中断
IRQ CHANAEL 3 通道 = 0x20 中断优先级 RTC 实时时钟(RTC)全局中断
IRQ CHANAEL 6 通道 = 0xA0 中断优先级 EXTI0 EXTI线0中断
。..。.
IRQ CHANAEL 63 通道 = 【0x00(最高),0x20,0x40,0x60,0x80,0xA0,0xC0 以及0xE0。)】
大家注意到了,上面通道0和通道3 的优先级都是0X20, 这怎么办?
// 如果优先级完全相同的多个异常同时悬起,则先响应异常编号最小的那一个。如IRQ #0会比IRQ #3 先得到响应
而且文中还讲了 【优先级分组】,这又是什么回事?
其实我回头看来,这个【优先级分组】和【抢占优先级】【亚优先级】都毫无意义的。
如果当时用 256级即是 把【中断优先级寄存器】的8位都全用上,就没这个必要了。还什么优先级分组呢!
就是因为厂家现在【偷工减料】,才搞出这个明堂来的。
是这样的,在 应用程序中断及复位控制寄存器(AIRCR) 中的 10:8 位【3位】是表示【优先级分组】
它作用主要是 用于对【中断优先级寄存器】『我们现在中用了BIT7,BIT6,BIT5三位』的功能的说明。
有一个表,在《Cortex-M3 权威指南》的110页, 例如我们把AIRCR的10:8 位设为【5】 ,查表可得【抢占优先级】=【7:6】,【亚优先级】=【5:0】,对于【中断优先级寄存器】只用了BIT7,6,5, 因此我们可以看作是 【7:6】,【5】。那4-0 可以不管。
现在我们的 IRQ0=0X20, IRQ3=0X20, 也就是 【0 0 1 0 】『 bit7=0,bit6=0,bit5=1,bit4=0』
因为大家(IRQ0/IRQ3)的 【抢占优先级】=【7:6】都是0, 说明它们的中断相应级别是一样的。
再继续判断它们哪个更优先的责任就要看【5】,结果连【5】都是一样的!
那就按默认:
// 如果优先级完全相同的多个异常同时悬起,则先响应异常编号最小的那一个。如IRQ #0会比IRQ #3 先得到响应
由于CM3没有 进中断【关全局中断相应】这事,只要是中断通道打开了,就会存在 通道间的 嵌套,即是会发生【抢占】的情况了。
上面就简短的说明,如果要详细理解,可以看《Cortex-M3 权威指南》。
有任何理解不当,请各位多多指教!
补充注意:
“2)抢占式优先级别相同的中断源之间没有嵌套关系;”
所以大家可以设:
IRQ CHANAEL 0 通道 = 0x20 中断优先级 WWDG 窗口定时器中断
IRQ CHANAEL 1 通道 = 0x40 中断优先级 PVD 联到EXTI的电源电压检测(PVD)中断
IRQ CHANAEL 3 通道 = 0x20 中断优先级 RTC 实时时钟(RTC)全局中断
IRQ CHANAEL 6 通道 = 0xA0 中断优先级 EXTI0 EXTI线0中断
这样 0 通道和3 通道就不会有嵌套情况,而是0 通道按默认比3 通道优先高些。
而0 通道与1 通道就会有嵌套情况。
芯片复位后,默认的优先级分组 是 0, 就是 【7:1】表示抢占式优先级,【0】表示亚优先级,这样对于MSB对齐的 8 个优先级为:0x00(最高),0x20,0x40,0x60,0x80,0xA0,0xC0 以及0xE0。)
使用就很方便了,建议大家就用默认的默认的优先级分组 是 0,也就是复位后的值,哈哈!
例如下面的两个按键,都使用外中断方式, 使用了PD.3,和PD.4两个引脚。这两个中断的优先级都是0X20,按默认的优先级分组,它们之间不会发生中断嵌套。
/* Enable the EXTI3 Interrupt on PD.3 */
STM32_Nvic_Regs-》Priority[9].all=0x20; // 中断的优先级是 0X20
STM32_Nvic_Regs-》Enable[0].bit.INT9=1; // 开INT9 中断 IRQ9
/* Enable the EXTI4 Interrupt on PD.4 */
STM32_Nvic_Regs-》Priority[10].all=0x20; // 中断的优先级是 0X20
STM32_Nvic_Regs-》Enable[0].bit.INT10=1; // 开INT10 中断 IRQ10
我也是靠看这本书才弄懂的:
Cortex-M3 权威指南
Joseph Yiu 著
宋岩 译
下载该资料的人也在下载
下载该资料的人还在阅读
更多 >
- 细说STM32的中断控制器(NVIC)那些事
- STM32中断与DMA通信编程
- STM32中断系统
- STM32中断与DMA通信编程
- STM32中断与DMA通信编程
- STM32学习笔记(五)---NVIC
- 基于STM32L4的NVIC中断系统
- STM32中断系统
- stm32f103中断总结很详细
- STM32单片机中断及NVIC的详细资料概述
- 中断是什么?STM32中断系统介绍和中断配置步骤资料免费下载 5次下载
- STM32中断与嵌套NVIC快速入门 20次下载
- STM32中断与嵌套快速入门(NVIC) 41次下载
- STM32中断优先级和开关总中断教程 0次下载
- STM32中断与嵌套NVIC快速入门
- 【GD32 MCU 入门教程】GD32 MCU 常见外设介绍(3)NVIC 介绍 568次阅读
- 不会RTOS,是因为你没搞懂NVIC 1156次阅读
- stm32中断怎么处理的 2664次阅读
- 单片机的NVIC与EXTI中断详解 5732次阅读
- 为什么有些STM32中断没有子优先级? 913次阅读
- STM32中断系统的工作流程 2668次阅读
- Cortex-M3中断优先级的相关知识 2796次阅读
- CKS32F4xx系列产品NVIC中断优先级管理单元讲解 1220次阅读
- stm32定时器中断与误区 2.7w次阅读
- 如何采用STM32单片机中断向量控制器NVIC来分配优先级的数量 3339次阅读
- 51单片机NVIC中断控制设计 1838次阅读
- STM32的Cortex-M3中断异常处理 8313次阅读
- MSP430有哪些可屏蔽中断_MSP430中断的优先级 2955次阅读
- stm32定时器中断程序 1.3w次阅读
- 《振南电子STM32视频教程》第六讲:EXTI和NVIC的配置和使用 987次阅读
下载排行
本周
- 1DH1766系列·三路可编程直流电源技术手册
- 1.93 MB | 3次下载 | 免费
- 2智能蓄电池充放电测试仪 蓄电池放电检测仪专业防护功能
- 0.13 MB | 2次下载 | 免费
- 3GD选型手册
- 6.92 MB | 2次下载 | 免费
- 4FP136 高端电流检测IC芯片说明书
- 0.62 MB | 1次下载 | 免费
- 533A66-B1 rk3399开发板规格书
- 1.15 MB | 1次下载 | 1 积分
- 6FP137 高端电流检测IC芯片说明书
- 0.68 MB | 1次下载 | 免费
- 7HAL9303线性霍尔效应传感器技术手册
- 0.70 MB | 1次下载 | 免费
- 8HC88L051F4低功耗芯片规格书
- 4.76 MB | 1次下载 | 免费
本月
- 1常用电子元器件使用手册
- 2.40 MB | 34次下载 | 免费
- 2高功率密度碳化硅MOSFET软开关三相逆变器损耗分析
- 2.27 MB | 33次下载 | 10 积分
- 3MS1826 HDMI 多功能视频处理器数据手册
- 4.51 MB | 8次下载 | 免费
- 4USB拓展坞PCB图资料
- 0.57 MB | 8次下载 | 免费
- 5经典1000W纯正弦波逆变器原理图资料
- 0.08 MB | 8次下载 | 10 积分
- 6TYPEC电路原理图资料
- 0.14 MB | 7次下载 | 免费
- 7SR520-SR5100肖特基二极管规格书
- 0.11 MB | 4次下载 | 免费
- 8DH1766系列·三路可编程直流电源技术手册
- 1.93 MB | 3次下载 | 免费
总榜
- 1matlab软件下载入口
- 未知 | 935134次下载 | 10 积分
- 2开源硬件-PMP21529.1-4 开关降压/升压双向直流/直流转换器 PCB layout 设计
- 1.48MB | 420064次下载 | 10 积分
- 3Altium DXP2002下载入口
- 未知 | 233089次下载 | 10 积分
- 4电路仿真软件multisim 10.0免费下载
- 340992 | 191424次下载 | 10 积分
- 5十天学会AVR单片机与C语言视频教程 下载
- 158M | 183352次下载 | 10 积分
- 6labview8.5下载
- 未知 | 81600次下载 | 10 积分
- 7Keil工具MDK-Arm免费下载
- 0.02 MB | 73818次下载 | 10 积分
- 8LabVIEW 8.6下载
- 未知 | 65991次下载 | 10 积分
电子发烧友App






创作
发文章
发帖
提问
发资料
发视频
上传资料赚积分
评论