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

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

3天内不再提示

STM32中断及FreeRTOS中断优先级配置

黄工的嵌入式技术圈 来源:黄工的嵌入式技术圈 2020-03-04 11:45 次阅读

很多朋友对中断的一些知识还是不了解,今天就写点关于Cortex-M3处理器中断相关,以及FreeRTOS中断优先级配置的内容。

1写在前面

写本文之前,先写点相关的扩展内容。

STM32属于ARM中Cortex-M系列处理器,比如:STM32F1数据Cortex-M3,STM32F7数据Cortex-M7。

可以参看我之前分享文章:从Cortex-M到Cortex-A认识ARM处理器,了解一下关于ARM处理器的种类。

本文主要结合Cortex-M3下面STM32F1系列处理器为例来讲述中断控制相关内容。而Cortex-M其它系列,或者说STM32其它系列关于中断的内容类似。

Cortex-M3只是STM32F1的一个内核。反过来说STM32F1是在Cortex-M3基础上增加了一些外设(如:USART、AD等)的芯片

2

STM32中断控制

NVIC:Nested Vectored Interrupt Controller,即嵌套向量中断控制器

STM32中NVIC我们比较熟悉,编程的时候使用中断都会对NVIC进行配置。

而STM32F1中的NVIC是属于Cortex-M3中的一部分,而不是STM32增加的外设。

NVIC向量中断控制器是Cortex‐M3不可分离的一部分,它与 CM3 内核的逻辑紧密耦合,有一部分甚至水乳交融在一起。

所以,NVIC相关的寄存器位于Cortex-M手册中。讲述STM32的中断控制,还得从Cortex-M3的NVIC讲起,

1.中断输入向量表

Cortex-M3的NVIC支持1至240个中断输入,比如STM32中xxxIRQs,也就是中断向量表,具体的数值由芯片厂商在设计芯片时决定。

比如STM32F1的中断和异常向量表:

2.中断和异常区别

很多初学的朋友不知道什么是中断?什么是异常?甚至有人直接把中断和异常笼统称为“中断”。

中断和异常其实有差异,也有关联,我们常说的中断其实是包含了异常。异常可以理解为MCU,或者程序处于了某种异常状态。

这么区分吧,看上面向量表,上部分有灰色背景的为异常,下部分白色的为中断。

异常属于Cortex‐M3内核的一部分,而中断属于MCU(STM32)的一部分(由厂家决定)。

所以:

1.站在Cortex‐M3内核角度,像STM32中USART这类中断,属于外部中断。

2.站在STM32角度,EXTI外部引脚中断才属于中断。

3.优先级

对于Cortex-M3来说,每个外部中断都有一个对应的优先级寄存器。

每个寄存器占用8位,但是允许最少只使用最高3位,在STM32F1中使用了高4位。(也就是我们可以分16个优先级)

优先级可以被分为高低两个位段,分别是抢占优先级和亚(响应)优先级。

提示:

1.STM32中断优先级数值越小,优先级越大。

2.优先级分组:Cortex-M3,M4具有分组功能,即存在抢占优先级和响应优先级,如下图:

而有的内核就没有,如Cortex-M0就没有。

3.参考资料

可以参看《Cortex-M3权威指南》

STM32的内核编程手册:

http://www.st.com/stonline/products/literature/pm/15491.pdf

3

FreeRTOS中断优先级配置

本节内容讲述一下FreeRTOS最大中断优先级配置问题,也就是FreeRTOSConfig.h配置文件中的:

configMAX_SYSCALL_INTERRUPT_PRIORITY

你们知道配置数值的含义吗?

这里就需要结合NVIC相关的内容来理解。

上面说了,在STM32中,使用了NVIC优先级的高4位,而我们配置时需要对高4位进行配置(低4位未使用)。

看上图,明白了吗,上面这个数值就是95,但代表的优先级为5。

这个配置数值的含义,大概意思是:你代码中使用的中断(比如USART1_IRQn)优先级需要大于5才可行。

如下面配置,优先级为2就不行(当然,有分组的还牵涉到分组问题)。

关于FreeRTOS最大优先级配置的内容可以参考:

https://www.freertos.org/RTOS-Cortex-M3-M4.html

提示:

FreeRTOS任务优先级是数值越大,优先级越高。需要和中断优先级区分开来。

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

    关注

    68

    文章

    18184

    浏览量

    221893
  • STM32
    +关注

    关注

    2239

    文章

    10662

    浏览量

    348411
  • FreeRTOS
    +关注

    关注

    12

    文章

    473

    浏览量

    61330
  • Cortex-M3
    +关注

    关注

    9

    文章

    268

    浏览量

    59151
收藏 人收藏

    评论

    相关推荐

    STM32中断分组及外部中断配置过程分享

    STM32中断分组   STM32 的每一个GPIO都能配置成一个外部中断触发源,这点也是 STM32
    发表于 04-08 08:05

    Hightec对芯片中断优先级分配时,中断号越高中断优先级越高吗?

    请问大佬,Hightec对芯片中断优先级分配时,中断号越高中断优先级越高吗?看网上的帖子说中断
    发表于 02-27 06:13

    M0516中断优先级怎么设置?

    新唐M0516中断优先级的设置,有没有示例,没找到相关接口,谢谢!
    发表于 01-16 07:25

    GD32如何配置中断优先级分组以及中断优先级

    使用GD32 MCU的过程中,大家可能会有以下疑问:中断优先级如何配置和使用?
    的头像 发表于 01-10 10:30 937次阅读
    GD32如何<b class='flag-5'>配置</b><b class='flag-5'>中断</b><b class='flag-5'>优先级</b>分组以及<b class='flag-5'>中断</b><b class='flag-5'>优先级</b>

    FreeRTOS中断测试避坑指南

    任何调用中断安全FreeRTOS API函数的中断服务例程都可以使用的最高中断优先级。不要从任何优先级
    的头像 发表于 12-21 09:04 430次阅读
    <b class='flag-5'>FreeRTOS</b><b class='flag-5'>中断</b>测试避坑指南

    STM8单片机的中断优先级如何配置

    STM8单片机的中断优先级如何配置,STM8刚开始接触,而且相关资料比较少。 麻烦用过的大佬答疑一下。
    发表于 11-08 06:56

    单片机中断优先级应用案例

    若单片机同时接收到几个中断请求时,单片机对中断请求的响应顺序是如何确定的?实际上,单片机是通过中断优先级来确定中断响应顺序的。
    发表于 10-31 14:42 515次阅读
    单片机<b class='flag-5'>中断</b><b class='flag-5'>优先级</b>应用案例

    STM8中断优先级怎么设置?

    STM8中断优先级怎么设置
    发表于 10-25 06:49

    为什么有些STM32中断没有子优先级

    看到一个交流群在讨论关于【关于STM32中断优先级的话题】,其中就有小伙伴提到:为什么有些STM32中断没有【子
    的头像 发表于 10-17 15:50 398次阅读
    为什么有些<b class='flag-5'>STM32</b><b class='flag-5'>中断</b>没有子<b class='flag-5'>优先级</b>?

    STM32中断没有子优先级

    比如,有时候你在使用STM32CubeMX配置时,你会发现只有Preemption Priority【抢占优先级】,而没有Sub Priority【次优先级
    的头像 发表于 10-17 15:50 409次阅读
    <b class='flag-5'>STM32</b><b class='flag-5'>中断</b>没有子<b class='flag-5'>优先级</b>?

    STM32中断优先级相关概念与使用笔记

    ARM cortex_m3 内核支持 256 个中断(16 个内核+240 外部)和可编程 256 中断优先级的设置,与其相关的中断控制和
    发表于 10-11 06:53

    STM32 MCU通过STM32CubeMx配置NVIC怎么没有中断优先级选项

    时,不难发现一个问题,那就是怎么没有中断优先级【或称响应优先级、副优先级等】的配置?!【当然,很多时候我们或许没有关注子
    发表于 09-09 09:25 769次阅读
    <b class='flag-5'>STM32</b> MCU通过<b class='flag-5'>STM32</b>CubeMx<b class='flag-5'>配置</b>NVIC怎么没有<b class='flag-5'>中断</b>子<b class='flag-5'>优先级</b>选项

    求助,新唐M0516中断优先级的设置有没有示例?

    新唐M0516中断优先级的设置,有没有示例,没找到相关接口,谢谢!
    发表于 08-24 07:29

    AMD Xilinx AXI Interrupt Controller中断优先级

    AXI Interrupt Controller支持中断优先级。 在Vivado Block Design中, bit-0连接的中断优先级最高
    的头像 发表于 07-11 17:03 660次阅读
    AMD Xilinx AXI Interrupt Controller<b class='flag-5'>中断</b><b class='flag-5'>优先级</b>

    M0516中断优先级的设置,有没有示例,没找到相关接口?

    新唐M0516中断优先级的设置,有没有示例,没找到相关接口,谢谢!
    发表于 06-16 08:51