STM32有43个channel的settable的中断源:AIRC(Application Interrupt and Reset Register)寄存器中有用于指定优先级的4位。这4个bits用于分配pre-emption优先级和sub优先级。
前者为抢占优先级 后者为响应优先级,也称为副优先级。
具有高抢占式优先级的中断可以在具有低抢占式优先级的中断处理过程中被响应,即中断嵌套,或者说高抢占式优先级的中断可以嵌套在低抢占式优先级的中断中。当两个中断源的抢占式优先级相同时,这两个中断将没有嵌套关系,当一个中断到来后,如果正在处理另一个中断,这个后到来的中断就要等到前一个中断处理完之后才能被处理。如果这两个中断同时到达,则中断控制器根据他们的响应优先级高低来决定先处理哪一个;如果他们的抢占式优先级和响应优先级都相等,则根据他们在中断表中的排位顺序决定先处理哪一个。
看了上面的介绍后,相信大家都明白了这里面的关系了,总结下便是:抢占式优先级>响应优先级>中断表中的排位顺序(其中“>”理解为比较的方向)。
高抢占式优先级的中断可以打断低抢占式优先级的中断。 但是,抢占式优先级相同时,后来的中断只能在前一个中断处理完成后才被处理,不能打断。如果两个同时来临,先处理高响应优先级的中断。如果两个优先级都相同,则按中断向量表顺序决定先处理那一个。
也就是抢占式优先级>响应优先级>中断表中的排位顺序(其中“>”理解为比较的方向)。
在STM32的固件库中定义如下:
//——————————-Preemption Priority Group ————————————————
#define NVIC_PriorityGroup_0 ((u32)0x700) //0 bits for pre-emption priority 4 bits for subpriority
#define NVIC_PriorityGroup_1 ((u32)0x600) //1 bits for pre-emption priority 3 bits for subpriority
#define NVIC_PriorityGroup_2 ((u32)0x500) //2 bits for pre-emption priority 2 bits for subpriority
#define NVIC_PriorityGroup_3 ((u32)0x400) // 3 bits for pre-emption priority 1 bits for subpriority
#define NVIC_PriorityGroup_4 ((u32)0x300) //4 bits for pre-emption priority 0 bits for subpriority
NVIC_PriorityGroup_0 代表 4BIT位都是响应优先级,共16个,无抢占优先级,所有中断不能被打断,同时来临时最高相应优先级先处理。即NVIC_IRQChannelPreemptionPriority无效,NVIC_IRQChannelSubPriority可以赋值为0~15.
NVIC_PriorityGroup_1 代表有两位抢占优先级,8个响应优先级,抢占优先级能够打断响应优先级。即NVIC_IRQChannelPreemptionPriority可以为0或1,NVIC_IRQChannelSubPriority可以赋值为0~7
NVIC_PriorityGroup_2 代表有4个抢占优先级,4个响应优先级。即NVIC_IRQChannelPreemptionPriority可以为0~3,NVIC_IRQChannelSubPriority可以赋值为0~3
NVIC_PriorityGroup_3 代表有8个抢占优先级和2个响应优先级。即NVIC_IRQChannelPreemptionPriority可以为0~7,NVIC_IRQChannelSubPriority可以赋值为0或1
NVIC_PriorityGroup_4 有16个抢占优先级,无响应优先级,高抢占优先级可以打断低抢占优先级。即NVIC_IRQChannelPreemptionPriority可以为0~15,NVIC_IRQChannelSubPriority无效。
今天的文章stm32抢占优先级和响应优先级_nvic中断优先级分享到此就结束了,感谢您的阅读。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
如需转载请保留出处:https://bianchenghao.cn/88161.html