ARM Cortex M3 /M4 NVIC 优先级

目录

1、优先级的定义

 2、优先级构成

1、优先级的定义

     CM3 允许的最少使用位数为3 个位,亦即至少要支持8 级优先级

例如:

STM32: 支持16级优先级

见《【野火_】零死角玩转STM32—F103指南者.pdf》 page148

S32K: 支持16级优先级

见《S32K1xx Series Reference Manual》 page116

 2、优先级构成

       按位分成高低两段,分别是抢占优先级和响应优先级

抢占优先级决定了抢占行为:当系统正在响应某异常L 时,如果来了抢占优先级更高的
异常H,则H 可以抢占L。

响应优先级则处理“内务”:当抢占优先级相同的异常有不止一个悬起时,就优先响应优先级最高的异常。

 默认分组如下:优先级分组 在 SCB配置(系统控制块中优先级分组配置寄存器)

例子:

PS: 注意STM32 中的分组序号与Cortex 的分组序号不是同步的

序号STM32分组Cortex分组S32K 分组备注(以16级优先级为例
0-0016级抢断,0级响应
1-1116级抢断,0级响应
2-2216级抢断,0级响应
343316级抢断,0级响应
43448级抢断,2级响应
52554级抢断,4级响应
61662级抢断,8级响应
70770级抢断,16级响应

注意:网上参考了【STM32】NVIC 中断优先级管理,没有理解清优先级分组 0,错误认为S32K 对应的 优先级分组0, 也是为没有抢断的,都为同一抢断优先级,不同响应优先级。

 

 

 

 

 

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
NVIC(Nested Vectored Interrupt Controller,嵌套向量中断控制器)是ARM Cortex-M系列微控制器中常用的一种中断控制器。在NVIC中,有16个不同的中断优先级,它们被分为若干个组。分组的目的是为了方便中断的管理和响应。 在ARM Cortex-M系列中,中断优先级是由8位的寄存器来控制的,最高优先级为0,最低优先级为255。NVIC根据中断优先级寄存器的值来确定哪个中断应该被处理。NVIC支持若干种分组方式,包括: 1. 分组0:将所有中断分为一组,优先级值越小的中断优先级越高。这种方式不允许优先级抢占,因此可能会导致低优先级的中断被长时间阻塞。 2. 分组1:将中断分为两组,第一组包含最高优先级的中断,第二组包含剩余的中断。这种方式允许抢占,但是可能会导致优先级反转问题。 3. 分组2:将中断分为若干组,每组之间的优先级差为相邻的2的整数次幂。例如,当分为4组时,第一组包含优先级为0到3的中断,第二组包含优先级为4到7的中断,以此类推。这种方式既允许抢占,又避免了优先级反转问题。 4. 分组3:将中断分为若干组,每组只包含一个中断。这种方式也允许抢占,同时也避免了优先级反转问题,但是需要消耗更多的中断向量表空间。 选择合适的分组方式应该根据具体的应用场景和中断处理要求来决定。常用的分组方式是分组2。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

红黄蓝白依米

你的鼓励将是我创作的最大动力

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值