ARM Cortex M3 /M4 NVIC 优先级

本文介绍了微控制器如STM32和S32K如何管理中断优先级。中断优先级分为抢占优先级和响应优先级,前者决定是否能抢占当前执行的任务,后者用于在抢占优先级相同的情况下确定哪个中断先被响应。STM32和S32K都支持16级优先级,并通过SCB的配置来设定优先级分组,不同的分组会影响抢占和响应优先级的分配。注意STM32的分组序号与Cortex的分组序号不完全对应,需要正确理解以避免混淆。
摘要由CSDN通过智能技术生成

目录

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, 也是为没有抢断的,都为同一抢断优先级,不同响应优先级。

 

 

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值