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

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

3天内不再提示

操作BASEPRI特殊功能寄存器时无效解决方法(下)

麦辣鸡腿堡 来源:茶话MCU 作者:茶话MCU 2023-06-21 16:08 次阅读

这里优先级分组选择的是将优先级的4位控制位全部用作抢占优先级的配置,响应优先级都一样,即不做特别配置。那么上图中SYSTICK/TIM2/TIM3/TIM4的中断的抢占优先级数据0、2、3、4其实是站在中断优先级寄存器的高4位而言的,那么放到整个8位优先级寄存器来看的话,他们的优先级应该是0x00,0x20,0x30,0x40【其实,低4位值是多少无关紧要,反正无效位】。

前面提过了,现在BASEPRI寄存器也只用到高4位,低4位保留。显然,如果在给BASEPRI寄存器赋值时按照基于高4位得到数字往里面写的话肯定都是无效的。

比方,我们期望在主程序里将上面TIM2/TIM3/TIM4的几个中断都屏蔽掉,若代码像下面截图里这样写肯定达不到目的。我这里开启了TIM2/TIM3/TIM4的周期性更新中断。【本文代码编译、调试基于ARM

MDK IDE】

图片

图片

经过测试也的确没有达到目的。我写__set_BASEPRI(2)的本意是想屏蔽掉那几个定时器的中断响应,结果发现根本没作用。BASEPRI寄存器也没正确写入,因为数据2只能写到BASEPRI寄存器的低4位,这几位恰好是无效位。不难理解,当我们改写成__set_BASEPRI(0x20)时就可以达到目的了。

图片

此时,BASEPRI被正确写入,TIM2/TIM3/TIM4的中断不能得到响应,倒是SYSTICK中断可以不被影响地得到响应,因为它的优先级是0,BASEPRI的配置屏蔽不了它。也就是说,通过配置BASEPRI寄存器来设置中断响应门槛的话,是阻止不了优先级为0或更高优先级的中断的响应的。如果对BASEPRI写0表示放弃其设置的中断门槛的功能。

如果希望对包括0优先级在内的所有可配置中断进行关闭或屏蔽,能否做得到呢?若可以,如何操作?

STM32芯片里的中断如果按中断源是来自ST外设还是ARM核处理器可以分为异常和中断,比方下图中灰色部分的就是异常,其它为中断。【截图来自STM32G4系列参考手册】

图片

平常我们统称二者为中断,不做区分。如果说把所有中断按其优先级是否可以配置,又可以将中断分为优先级固定和优先级可配置的中断。其中,优先级固定的中断在上面表格中都明确标示了fixed字样,优先级可配置的都加注了settable字样。结合前面提到的优先级寄存器的特性,可配置的优先级是不会高于0级,即配置的数字不会小于0的。

若我们期望对所有可配置中断进行关闭或屏蔽,可以操作另一个叫PRIMASK的寄存器,它只有1位有效控制位。

图片

我们通过对PARMASK写1,令CPU对所有优先级可配置的中断不做响应;若对其写0表示放弃屏蔽功能。比方,我们还是接着前面的演示代码来看看效果。

图片

这时,前面提到的4个定时器中断都不能得到响应了,虽打了断点但过不去。我们还可以借助调试工具看到这几个中断的响应情况【SYSTICK位置离得远,单独截取后插进图中的】。

图片

对于上图的部分信息我这里稍微解释下。

图形上方的字母E、P、A是下方Eable/Pending/Active单词的首字母。Enable表示相应中断是否在NVIC端得到响应允许;Pending表示中断等待CPU的执行;Active表示中断服务程序正在被执行。从图中可以看出,SYSTICK/TIM2/TIM3/TIM4的中断响应都虽得到允许,但都处于Pending期待执行状态。既然没有得到执行,Active位自然也是0。

上图中优先级的数字显然是按照高4位结合优先级分组后来看的,那个S表示SubPriority的意思。为了看得更清晰点,我不妨将优先级分组采用下面的做法重新配置下,保持原抢占优先级都不动,增加1位响应优先级【即子优先级】配置。目前4位优先级配置位拆分为3位抢占优先级配置位和1位响应优先级配置位。当前测试代码也保持不动。

图片

显然,上图中的抢占优先级编号2、3、4是站在分组后的高3位单独来看的,响应优先级是站在分组后剩下的1位单独来看的。如果我们把两类优先级的配置合在高4位一起看,优先级数字应该分别是十进制数1、5、6、9。【这个地方要弄清楚,否则下面调试结果看不明白。】

图片

基于前面测试代码和现有配置,我们看看运行后的中断响应情况。

图片

刚才虽然调整了优先级的分组配置,但这几个中断的抢占优先级都没改变,所以在PRIMASK为1的情况下都不能得到响应。我们可以发现这几个中断的优先级站在高4位的角度来看而得出的优先级数字跟我上面分析的基本一致,除了SYSTICK的。

按理此时此处SYSTICK的优先级应该是1而不是0。为什么会这样呢?原因就在于我基于CubeMx组织的代码,这个过程中如果使用SYSTICK做库代码的TICK时钟,其中断优先级的配置使用默认配置,没有理睬CubeMx这边针对它子优先级的配置。Cube库在配置SYSTICK优先级时,默认使用全部4位用作抢占优先级的配置,同时将子优先级配置为0。当然,我们可以针对性地调整来适应我们的需求。主要是下面这个weak特性的初始函数,我们可以手动修改这个函数里关于中断优先级的配置。

图片

关于使用PRIMASK屏蔽所有可配置中断的做法还有其它等效动作,比如使用CPSID指令和CPSIE指令或调用相关CMSIS函数。【参见下图】

图片

它们的作用一样,也就是我们平常所说的开、关总中断,准确点说是屏蔽所有优先级可配置中断的响应或者放弃屏蔽功能。对于开、关总中断的说法,从实现屏蔽效果来看勉强可以说能关总中断。但整体上讲,个人觉得这个说法不太合适,还很容易给人带来误解,颇具误导性。其实,不论是操作PRIMASK还是BASEPRI寄存器,并没有对被屏蔽中断的原有参数和配置做任何改变。即那些暂时被屏蔽的中断的中断响应允许位、中断请求使能位、中断触发事件等都不会因为暂时的被屏蔽而发生改变。打个形象而不是特别贴切的比方。当你开着豪车愉快地跑在某条道上,听着歌哼着曲。突然前方有交警在对道路做临时管制,你和其它一干人车都被拦停下来。原因是有一行高级别的人物要保障优先通行。你等虽被拦停下来,既没人说你无证驾驶、也没人告知你无权走这条道,证照都在,行路权也有,就是此刻级别不够。一旦放行,你依然可以一如既往地行使。

我倒觉得ARM技术手册提到的优先级提升更好理解和接受些。即通过对BASEPRI、PRIMASK这些寄存器编程提升当前执行程序的优先级,使得低于当前优先级的中断暂时得不到响应。适当时候放弃优先级升级功能,恢复原状。

可能有人知道,还有个可以关闭或屏蔽优先级高至-1级的HardFault异常的控制寄存器,就是FAULTMASK,也是1位有效位,操作跟PRIMASK类似。有兴趣的话,可以自行进一步研究下。

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

    关注

    2274

    文章

    10929

    浏览量

    358004
  • 控制
    +关注

    关注

    4

    文章

    1016

    浏览量

    122804
收藏 人收藏

    评论

    相关推荐

    在C语言环境访问特殊功能寄存器sfr的经验

    单片机的特殊功能寄存器SFR,是SRAM地址已经确定的SRAM单元,在C语言环境对其访问归纳起来有两种方法
    的头像 发表于 11-10 09:46 9545次阅读
    在C语言环境<b class='flag-5'>下</b>访问<b class='flag-5'>特殊功能</b><b class='flag-5'>寄存器</b>sfr的经验

    硬件特殊功能寄存器编程思路和RAM使用的问题求解?

    着RAM。 而以前弄51,AVR,PIC的时候硬件特殊功能寄存器都是一个一个设置。 请教一这两个方法各有什么有点和缺点。
    发表于 05-17 12:24

    关于三星2410A处理特殊功能寄存器问题

    会有这些特殊功能寄存器的地址的实际地址。哪FLASH里面地址和芯片的特殊功能寄存器的实际地址是什么关系了?如何去实际操作这些
    发表于 10-02 21:56

    特殊功能寄存器

    MCS-51单片机的特殊功能寄存器总是不能灵活运用额。。比如TMOD、TCON、什么的,在做定时中断的时候老是不理解,各位帮指点指点呀!
    发表于 02-06 23:09

    特殊功能寄存器位置及功能是什么

    特殊功能寄存器(SFR)位置及功能
    发表于 01-05 07:07

    【硬见小百科】单片机的特殊功能寄存器

    在单片机中有一些独立的存储单元是用来控制这些器件的,被称之为特殊功能寄存器(SFR)。 特殊功能寄存器地址映象表(一) 特殊功能
    的头像 发表于 01-16 13:45 5475次阅读

    51单片机的21个特殊功能寄存器的详细资料说明

    学习51单片机的过程中,其实就是学习怎么用它的特殊功能寄存器(有些寄存器是我们看不到的),特殊功能寄存器是 80C51单片机中各
    发表于 09-10 17:26 14次下载
    51单片机的21个<b class='flag-5'>特殊功能</b><b class='flag-5'>寄存器</b>的详细资料说明

    51单片机的21个特殊功能寄存器详细资料概述

    在80C51单片机中设置了与片内RAM统一编址的21个特殊功能寄存器(SFR)。访问SFR只允许使用直接寻址方式。特殊功能寄存器(SFR)每一位的定义和作用与单片机各部件直接相关。
    发表于 07-09 17:40 8次下载
    51单片机的21个<b class='flag-5'>特殊功能</b><b class='flag-5'>寄存器</b>详细资料概述

    7课:单片机的特殊功能寄存器 2020/11/15

    7课:单片机的特殊功能寄存器 2020/11/15
    发表于 11-20 12:51 7次下载
    7课:单片机的<b class='flag-5'>特殊功能</b><b class='flag-5'>寄存器</b> 2020/11/15

    51单片机的特殊功能寄存器到底在哪,为何51子系列没有高128B仍然有特殊功能寄存器

    简单来说,就是片内RAM和特殊功能寄存器在物理上是相互独立的。就像51子系列内部RAM没有高128B,但它任然有特殊功能寄存器,因为特殊功能
    发表于 11-23 16:51 22次下载
    51单片机的<b class='flag-5'>特殊功能</b><b class='flag-5'>寄存器</b>到底在哪,为何51子系列没有高128B仍然有<b class='flag-5'>特殊功能</b><b class='flag-5'>寄存器</b>

    【硬见小百科】单片机的特殊功能寄存器

    在单片机中有一些独立的存储单元是用来控制这些器件的,被称之为特殊功能寄存器(SFR)。<特殊功能寄存器地址映象表(一)><特殊功能
    发表于 12-20 19:15 14次下载
    【硬见小百科】单片机的<b class='flag-5'>特殊功能</b><b class='flag-5'>寄存器</b>

    STC单片机常用特殊功能寄存器速查

    STC单片机常用特殊功能寄存器速查(STC-SFR2-b9正式版)
    发表于 09-30 17:20 0次下载

    为何修改BASEPRI寄存器无效

    有STM32用户发现在操作BASEPRI特殊功能寄存器时,根本不起作用。比方,它目前配置了几个中断,优先级各不相同,按照STM32CubeMx里的配置分别为2、3、4不等,当他在
    的头像 发表于 04-26 09:16 2542次阅读
    为何修改<b class='flag-5'>BASEPRI</b><b class='flag-5'>寄存器</b><b class='flag-5'>无效</b>?

    操作BASEPRI特殊功能寄存器无效解决方法(上)

    有STM32用户发现在操作BASEPRI特殊功能寄存器时,根本不起作用。比方,它目前配置了几个中断,优先级各不相同,按照STM32CubeMx里的配置分别为2、3、4不等,当他在
    的头像 发表于 06-21 16:04 1731次阅读
    <b class='flag-5'>操作</b><b class='flag-5'>BASEPRI</b><b class='flag-5'>特殊功能</b><b class='flag-5'>寄存器</b>时<b class='flag-5'>无效</b><b class='flag-5'>解决方法</b>(上)

    特殊功能寄存器的解释整理汇总

    电子发烧友网站提供《特殊功能寄存器的解释整理汇总.pdf》资料免费下载
    发表于 05-09 14:27 7次下载