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

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

3天内不再提示

因STM32移植而引发的两个小疑问

茶话MCU 来源:茶话MCU 2023-11-18 14:12 次阅读

STM32用户将基于STM32F0芯片的代码移植到STM32F4系列时遇到了些麻烦。其中有个问题跟中断处理有关。有个中断服务程序代码在STM32F0芯片里运行正常,移植到STM32F4芯片并使用同样的程序代码却明显异常,感觉每次中断都进了两次。

经过他一番网上搜索,大致找到了问题原因和解决办法。原因就是他在中断服务程序里做中断请求标志清零的代码放在服务程序的结尾处了,将其挪至服务程序的入口处就可以了。

问题是解决了,但依然还是有两个小疑问如鲠在喉。

第一个疑问,为什么同样的操作在F0系列正常,而在F4系列却异常呢?仅仅是因为F4系列跑得快?

其实,这里的主要原因是内核差异导致的。STM32F0系列芯片是基于ARM Cortex-M0内核的微处理器,STM32F4系列芯片是基于ARM Cortex-M4内核的微处理器,二者在内核上存在一些差异,其中一个差异就是,M4内核相比M0内核多了针对写操作的写缓冲以及相应执行机构,这里不妨称之为“缓冲写”单元。

847cb746-85d1-11ee-939d-92fbcf53809c.png

对于F0系列,由于没有“缓冲写单元”,CPU在做中断请求标志清零时需全程执行直到清零完成才能做中断返回。对于F4系列,由于有“缓冲写单元”协助,在做中断请求标志清零时CPU只需执行相应程序,交代清楚写些什么到哪里即可,具体的写操作就交给“缓冲写”单元完成,然后继续执行后续程序,后面跟F0系列就有点不一样了。由于清零操作代码执行时刻与准备出栈时刻太接近,“缓冲写”单元尚未完成对标志的清零,CPU因而再次进了一次中断服务程序。显然程序再运行一次后,一般来讲那个标志的清零都会完成了。因此,类似情况我们往往最多也就看到进了两次中断。

第二个疑问呢?

用户发现在使用STM32F4芯片时,即使清中断标志代码放在服务程序的结尾,一般只需在其后面追加3到4个NOP操作后就保证不会发生1次事件进入2次中断服务程序的情况。也就是说,在清中断标志代码后面稍加延时3~5个时钟就能保证清零完成。

对于Cortex-M内核的芯片,中断出栈不会少于12系统时钟。这样说来,即使不加那几个NOP操作延时,这12个时钟也足以让清零完成。这意味着出栈后中断请求标志早已完成清零,那么第2次再进中断是依据什么而响应的呢?

这里就涉及到ARM Cortex-M内核的中断响应咬尾机制。简单点说,当CPU刚执行完某中断服务程序准备出栈返回时,若内核硬件发现外边正有嗷嗷待哺的其它中断请求候着时,就果断决定不做出栈了,立马响应新的中断请求并执行相应服务程序。

具体到这里,当STM32F4的中断服务程序里最后一行清中断标志代码执行完后(具体写操作交给“缓冲写单元”了),CPU准备做出栈返回时,由于写缓冲单元尚未完成清零,硬件发现有个中断请求存在,于是乎果断决定放弃出栈,稍作准备后也不做压栈就执行当前中断请求所对应的服务程序,这里就是把刚才的中断服务程序再跑一次。

看到这里,我们应该明白了,中断再进一次的关键是CPU准备出栈时发现还有中断请求存在,至于出栈时间多长多短已经不重要,因为这时压根就不做出栈操作了。这也就可以解除上面提到的疑惑了。

下图就是示意中断前后两次执行的情况。【假定中断第一次是打断主程序或强占其它进来的】

8496280c-85d1-11ee-939d-92fbcf53809c.png

第一次进中断时,发生了压栈。第二次进中断是紧跟着第一次中断服务程序之后,未做出栈稍加准备后就开始执行服务程序,之后才做出栈操作。

看到这里,或许有人会问上面提到的稍加准备难道不要时间吗?也是要的,如果Flash访问取指延时为0等待的话,最短6个时钟。

84a3e820-85d1-11ee-939d-92fbcf53809c.png

或许有人继续问,这个6个时钟跟平常压栈的10来个时钟是什么关系呢?

当有压栈时,这个6个时钟就包含于压栈时间里了,它大致用来做中断向量的提取、Exc_return值的拟定等,这些操作跟压栈操作是并行重叠的,有压栈时就不提这几个时钟的时间了,只说压栈时间。

对于前面提到的第2次基于咬尾机制进中断的情形,如果希望得到较为直观地体验、感受,可以借助断点,观察栈帧的变化来满足。我们可以明显地观察到中断服务程序运行了两次,压栈只发生一次。

好,今天的话题就分享到这里,供君参考。下次再聊。

审核编辑:汤梓红

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

    关注

    146

    文章

    16017

    浏览量

    343631
  • STM32
    +关注

    关注

    2239

    文章

    10671

    浏览量

    348755
  • 微处理器
    +关注

    关注

    11

    文章

    2131

    浏览量

    81413
  • 移植
    +关注

    关注

    1

    文章

    367

    浏览量

    27854
  • 中断
    +关注

    关注

    5

    文章

    884

    浏览量

    41023

原文标题:因STM32移植而引发的两个小疑问

文章出处:【微信号:stmcu832,微信公众号:茶话MCU】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    multisim 如何叠加两个两个信号

    的)那么接下来就为了验证这个电路到底能不能滤除两个信号中的一信号,以及再放大这个信号。那么~~~~那么~~~~那么是不是就需要一混合了两个信号的信号(比如
    发表于 03-03 17:55

    stm32怎么与两个液晶相连

    stm32怎么与两个液晶相连
    发表于 03-15 09:02

    怎么进行两个stm32之间的通讯?

    求大神我拿两个32rxtx反接发送的板子我只写了USART_SendData(USART1,1);接受的板子我写了data=USART_ReceiveData(USART1);printf("%c",data);不行求大神教教我如何实现
    发表于 08-15 16:53

    同步从站FIFO时序要引发额外的两个周期延迟吗?

    使用当前线程标志,除了专用线程标志所示的两个周期延迟之外,是否还要引发额外的两个周期延迟?如果不是,这者之间的时差是多少? 以上来自于百度翻译 以下为原文I'm trying
    发表于 05-07 12:17

    两个STM32服务器如何连接做客户端的stm32

    通信如图所示。三stm32是在一板子上的,wifi 为esp8266模块。两个stm32做服务器和一
    发表于 05-13 03:23

    ewin移植出现TF5206 INIT SCAN这两个函数没定义

    ewin移植出现 TF5206 INITSCAN这两个函数没定义 (移植文件里 定义了 )为什么 。。
    发表于 06-14 04:35

    请问stm32f103ze和stm32f103rb(vb)两个移植模板什么区别?

    micrim公司官网提供的STM32移植版的UCOSII,有stm32f103ze和stm32f103rb(vb)两个
    发表于 07-05 03:50

    请问多出的这个两个汇编函数是从哪移植过来的?

    exception (causes context switch) LDRR1, =NVIC_PENDSVSET STRR1, [R0] BXLRAGE 请问多出的这个两个汇编函数,是从哪移植过来的呢?求教!
    发表于 07-29 04:35

    为什么移植ucosii进入hardfault会引发异常?

    移植完ucosii后,运行了一下,发现在任务调度时进入hardfault异常经过调试后发现是在OS_Sched()函数运行结束时引发的异常,这个是调试截图,好像是在出栈指令pop引发的,但是不知道为什么,求大神指点一下。
    发表于 08-29 04:35

    STM32的中断向量具有两个属性

    STM32 的中断向量具有两个属性,一为抢占属性,另一为响应属性,其属性编号越小,表明它的优先级别越高。 抢占,是指打断其他中断的属性,即因为具有这个属性会出现嵌套中断(在执行中断
    发表于 08-16 07:11

    STM32F103的两个串口简要分析

    一.STM32F103有两个串口图中 TXD/RXD 是相对 CH340G 来说的,也就是 USB 串口的发送和接收引脚。 USART1_RX 和 USART1_TX 则是相对于
    发表于 01-14 07:37

    STM32F072与STM32F070这两个MCU的USB有什么差异?

    STM32F072与STM32F070这两个MCU的USB有什么差异?stm32f103移植到f0_USB库的过程是怎样的?
    发表于 02-21 07:02

    小白求助ARM移植实验中的两个问题

    我在移植实验中想到了两个问题,如下:1.Debug 和 Release 以及 DebugRel 有什么不同?为什么在作 2104 移植实验时,要用Release?2.在 Release 中为什么要将 RW Base 设置为 0x
    发表于 10-17 15:44

    调用派生自两个基类的类的虚函数硬故障崩溃怎么解决?

    两个基类派生类时,我发现了一问题。类BaseA{民众: 基础A(){} 虚拟 int GetNumber () const {返回 42;}};类BaseB{民众: 基地B
    发表于 01-12 08:14

    STM32_UCOS移植

    STM32 UCOS移植 STM32 UCOS移植 STM32 UCOS移植
    发表于 07-13 17:31 28次下载