0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

如何理解STM32(Cortex-M3)中的抢占优先级与响应优先级

MCU开发加油站 来源:未知 作者:佚名 2017-12-22 06:25 次阅读

很多人在配置STM32中断时对固件库中的这个函数NVIC_PriorityGroupConfig()——配置优先级分组方式,会很不理解,尤其是看中文翻译版的,因为中文翻译版里把这里翻译成“先占优先级和从优先级”这样翻译其实是不对的,很容易让人误解。
为了便于大家理解,有必要先解释两个概念:

抢占式优先级/响应优先级:

STM32(Cortex-M3)中有两个优先级的概念——抢占式优先级和响应优先级,有人把响应优先级称作'亚优先级'或'副优先级',每个中断源都需要被指定这两种优先级。

具有高抢占式优先级的中断可以在具有低抢占式优先级的中断处理过程中被响应,即中断嵌套,或者说高抢占式优先级的中断可以嵌套在低抢占式优先级的中断中。

当两个中断源的抢占式优先级相同时,这两个中断将没有嵌套关系,当一个中断到来后,如果正在处理另一个中断,这个后到来的中断就要等到前一个中断处理完之后才能被处理。如果这两个中断同时到达,则中断控制器根据他们的响应优先级高低来决定先处理哪一个;如果他们的抢占式优先级和响应优先级都相等,则根据他们在中断表中的排位顺序决定先处理哪一个。

看了上面的介绍后,相信大家都明白了这里面的关系了,总结下便是:抢占式优先级>响应优先级>中断表中的排位顺序(其中“>”理解为比较的方向)。

正是因为每个中断源都需要被指定这两种优先级,就需要有相应的寄存器位记录每个中断的优先级;在Cortex-M3中定义了8个比特位用于设置中断源的优先级,这8个比特位可以有8种分配方式,如下:

1.所有8位用于指定响应优先级

2.最高1位用于指定抢占式优先级,最低7位用于指定响应优先级

3.最高2位用于指定抢占式优先级,最低6位用于指定响应优先级

4.最高3位用于指定抢占式优先级,最低5位用于指定响应优先级

5.最高4位用于指定抢占式优先级,最低4位用于指定响应优先级

6.最高5位用于指定抢占式优先级,最低3位用于指定响应优先级

7.最高6位用于指定抢占式优先级,最低2位用于指定响应优先级

8.最高7位用于指定抢占式优先级,最低1位用于指定响应优先级

以上便是优先级分组的概念,但是Cortex-M3允许具有较少中断源时使用较少的寄存器位指定中断源的优先级,因此STM32把指定中断优先级的寄存器位减少到4位,这4个寄存器位的分组方式如下:

第0组:所有4位用于指定响应优先级

第1组:最高1位用于指定抢占式优先级,最低3位用于指定响应优先级

第2组:最高2位用于指定抢占式优先级,最低2位用于指定响应优先级

第3组:最高3位用于指定抢占式优先级,最低1位用于指定响应优先级

第4组:所有4位用于指定抢占式优先级

这里便对于于文章最前提到的固件库里相关的函数了——NVIC_PriorityGroupConfig(u32NVIC_PriorityGroup),函数的参数共有5种:

这个函数的参数(NVIC_PriorityGroup值)有下列5种:

NVIC_PriorityGroup_0 =>选择第0组

NVIC_PriorityGroup_1 =>选择第1组

NVIC_PriorityGroup_2 =>选择第2组

NVIC_PriorityGroup_3 =>选择第3组

NVIC_PriorityGroup_4 =>选择第4组

这其实也很好理解,比如选择NVIC_PriorityGroup_1,那么抢占式优先级便占一位,也就是说可以有2^1个级别,可以设置为0和1,而响应优先级则占3位,也就是说可以有2^3个选择,可以设置为0~7;总共来说就可以区别>16种优先级(为什么大于而不是等于,想想就应该明白了)

举个例子吧,假如现在有4个外部中断,还有一个EXTI9_5中断,那么如果选择优先级分组为第1组,那么抢占式优先级便只有两种,5个中断就至少有3个在抢占式优先级上是相同的优先级上,其他两个在另一优先级别。接着设置响应优先级可以有8种选择(即每个中断都要设计 抢占优先级 及响应优先级);假如现在同时有两个抢占式优先级别相同的中断发生,那么处理的顺序是谁的响应优先级高则谁优先进入中断,另外这点是需要注意的,如果此时进入这个中断之后又来了一个抢占式优先级相同但是响应优先级更高的中断,这时也是不会打断已有的中断的。

声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • STM32
    +关注

    关注

    2239

    文章

    10669

    浏览量

    348709
  • Cortex_M3
    +关注

    关注

    0

    文章

    11

    浏览量

    5297

原文标题:STM32(Cortex-M3)中的优先级理解

文章出处:【微信号:mcugeek,微信公众号:MCU开发加油站】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    [转] STN32抢占优先级与副优先级及中断优先级NVIC理解

    的四个中断分别设置,个人觉得可以分别独立配置表2真值表就是具体配置STM32优先级别了。表2来自ST官方资料,STM32F10xxx
    发表于 04-15 14:14

    stm32的NVIC抢占响应优先级

    stm32的NVIC的响应优先级的意思是,在同一抢占优先级的前提下,正在执行一个优先级低的中
    发表于 04-15 17:07

    STM32优先级彻底讲解

    优先级设置 8bit 的高 4 位)和16个抢占优先级(因为抢占优先级最多可以有四位数)。 二:优先级判断
    发表于 07-06 03:27

    stm32优先级理解

    请教大家个小白问题,中断优先级组为2,就是说所有60个中断每个中断的中断优先寄存器的高4为重的最高2位是抢占优先级(可设置抢占优先级位0-3
    发表于 06-24 04:35

    优先级判断STM32

    最多可以有四位数)。二:优先级判断STM32(Cortex-M3)中有两个优先级的概念——抢占优先级
    发表于 08-13 06:50

    浅析stm32的中断嵌套优先级

    stm32的中断嵌套优先级stm32NVIC优先级分组中断优先级配置寄存器NVIC_IPRx描述抢占优先
    发表于 08-13 09:45

    详解STM32优先级

    一:综述 STM32 目前支持的中断共为 84 个(16 个内核+68 个外部), 16 可编程中断优先级 的设置(仅使用中断优先级设置 8bit
    发表于 08-13 07:08

    STM32(Cortex-M3)优先级概念

    一、中断优先级STM32(Cortex-M3)优先级概念STM32(
    发表于 08-16 07:21

    STM32之何为占先式优先级

    STM32 (Cortex-M3) 优先级概念STM32(Cortex-M3)中有两个
    发表于 08-16 06:49

    STM32优先级和开关总中断

    STM32优先级和开关总中断一,中断优先级STM32(Cortex-M3)
    发表于 08-16 07:05

    STM32优先级和开关总中断

    STM32优先级和开关总中断一,中断优先级STM32(Cortex-M3)
    发表于 08-23 07:06

    STM32F407抢占优先级响应优先级有何区别

    STM32F407断有几个优先级抢占优先级响应优先级有何区别?
    发表于 10-19 09:03

    STM32F抢占优先级/响应优先级的区别是什么

    STM32F抢占优先级/响应优先级的区别是什么
    发表于 11-16 07:16

    探讨一下STM32优先级和开关总中断

    STM32优先级和开关总中断一,中断优先级STM32(Cortex-M3)
    发表于 01-14 07:43

    cortex M抢占优先级和子优先级有什么用

    Cortex M内核每个中断都有一个8位的优先级设置寄存器这个8位的寄存器可以分为抢占优先级和子优先级
    发表于 01-25 06:07