历史上的今天
返回首页

历史上的今天

今天是:2024年08月25日(星期日)

正在发生

2020年08月25日 | ARM Cortex-M4中断优先级和嵌套

2020-08-25 来源:elecfans

坐在上海回北京的高铁上,漫长的旅途着实让人感到无聊(没买到直达的高铁,只能慢悠悠的走一站停一站,晕,都高铁时代了,竟然还这样,想起了大学放假回家站十几个小时绿皮车的时光啊,哈哈),遂有点“写心萌动”,不由感叹——“春”天真是来了,春为啥加引号捏,我相信大家都懂的,哈哈。这样也好,俺又可以慢悠悠的写作抒情了,走着。。。

其实都搞了这么长时间的ARM开发,关于其至关重要的中断优先级问题我早就想跟大家伙分享分享了,可惜一方面想真正的讲清楚这个问题估计又得大费周章和墨水,另一方面自己越来越忙进一步导致写文章倒是越来越懒了,呵呵。所以趁着坐高铁无聊赶紧撸胳膊抹袖子整吧,不然把这么重要的内容放在自己脑子里封存落灰实在是颇为浪费呀,哈哈。那就不多扯淡了,再多扯火车到站了就尴尬了,咳咳。。。


对于中断优先级配置的需求实际上主要体现在系统存在多个可能的中断源情况下,这时为了保证代码的可靠执行,我们不得不考虑很现实的两个问题,一个是如果两个以上中断同时发生,pending请求到CPU,CPU决策该先进哪一个相应的中断服务Routine,第二个问题是CPU当前已经在响应某个中断服务,此时来了另一个中断请求,是否允许其打断当前中断服务转而响应新的中断请求即我们常说的中断嵌套问题,不要告诉我没考虑过哈(如果真是这样,我只能不客气的说,这样搞单片机是不负责任的,很可能给项目带来潜在的风险bug),那样的话俺也白写了,呵呵。那正题来了,对现在红红火火的ARM Cortex-M4和M0+两个核来说,他们是如何解决这两个问题的呢,因为这两个核在中断优先级管理上略有些区别(虽然都是NVIC和SCB两个寄存器来管理),所以下面我分开来说,另外由于中断优先级管理属于内核问题,所以这方面的信息你不会在各大半导体厂家的官方手册中找到,我们只能追根溯源直接到内核的老家ARM官网去找,建议大家有兴趣的到ARM官网把M4和M0+的内核手册下载下来简单瞅瞅,可能会有意想不到的收获哦,呵呵:

ARM Cortex-M0+中断优先级和嵌套

无论是M0+或者是M4内核,实际上他们两个的中断优先级都是由NVIC和SCB两个寄存器来管理的,在这里我默认大家都知道ARM的中断源分为内核中断和IRQ中断了哈(我怕再细讲下去又没完了,呵呵),而对IRQ的中断管理是由NVIC来主导的,内核的中断管理则是由SCB来主导的,我们先讲IRQ中断的优先级问题(关于中断使能和禁能不在本篇讨论范围内哈),打开M0+的内核手册找到NVIC_IPR寄存器(Interrupt Priority Registers)如下图所示:

注意观察我高亮标注的几块,从这几块中可以抽象出核心的几个问题,第一个是NVICIPR一共有8个寄存器,而每个寄存器管理4个IRQ中断,乘法口诀算一下,我们就明白了为啥M0+的IRQ中断源最多只支持32个了,再加上16个内核中断,加法口诀再算一下,也就是说M0+最多就是48个中断源,所以M0+算是比较好搞的了,一会儿讲M4就该头疼了,呵呵;第二个问题是优先级寄存器里面的配置值越低表明相应的中断优先级越高;第三个问题是每个PRIxx的8位中只有最高两位[7:6]有效,也就是说实际上M0+的优先级只有四个即0,1,2,3,4,其中0的优先级是最高的;第四个问题,为啥我放到最后说呢,因为这是比较容易忽略的问题,即word-accessible,也就是说这几个寄存器都只能按字操作,切记不要为了显示我们的编程技巧而使用指向字节的指针只对某个单独中断的优先级进行配置。

至于嵌套的问题,对M0+是比较简单的,即只要相应中断的优先级比较高即可随时抢占比它优先级低的中断服务。至于内核中断,其中断优先级则由SCB模块的SCB_SHPR寄存器来管理如下图所示,实际上我们平时常用的就是systemtick中断,其优先级配置同NVIC,这里就不赘述了。另外,我这里提一下,即如果我们不对优先级进行配置的话,则默认相应中断源的向量号越低其优先级越高,不过如前面我提到的,我是强烈建议在多中断的情况最好把每个用到的中断优先级都根据实际需求进行相应配置,避免潜在的风险。

ARM Cortex-M4中断优先级和嵌套

我前面提到一句,M4虽然指令集是向下兼容M0+的,但是在中断优先级管理上是有区别的,由于M4的中断源比较多(最多允许256),所以其对中断优先级管理是略有些复杂的,不过一定要仔细看下去,因为我们平时会比较常用到,但是我敢肯定不是所有人的用法是正确的,为啥?待我下面继续分解(放心,还没完呢,呵呵),先继续上图:

继续找上图亮点,一个是M4最高支持16+4*60=256个中断源,第二个这60个寄存器是可以按字节操作的(我们可以继续的装逼用指针了,哈哈),第三个跟M0+一样即值越小优先级越高,最后则是最大的区别,即每个寄出去你的8位数据都是可以定义其中断优先级了,说到这里,a question is raised,那是不是意味着M4的优先级最高可以256个级别呢。我只能说,大家想多了,呵呵,继续看下图吧,可见PRIGROUP定义了这8位数据到底该怎么用了,这里出现了两个新名词,即Group Priority和Subpriority,至于这两个优先级是什么意思那大家继续看图2,大家先仔细理解理解,我喝口水先。。。Ok,继续回来,从下面两张图可以看到在M4内核中,其对中断优先级管理是分了两个部分,一个是组优先级一个是子优先级,即组优先级是管理抢占优先级的(即是否能嵌套),即高的组优先级中断(数值低)可以抢占低的组优先级(数值高)中断的,而如果组优先级是一样的,即使子优先级比正在执行的中断的子优先级高也是不能抢占的,那又有同志们要问问题了,那子优先级有啥用?呵呵,正如图2所说,在组优先级一致的情况下,多个中断请求同时发生,这样的情况下子优先级高的可以先执行的,而子优先级低的则只能暂时pending等着了,呵呵。而回到PRIGROUP的作用是用来配置NVIC的8位数据域是如何分配给抢占优先级和子优先级的,而一般情况下,最好是各留4位给这二位大爷和小爷了,即每位爷最多可配16个优先级,而PRIGROUP是从哪来的呢,呵呵,实际上它是SCB_AIRCR寄存器的其中3位如图3所示。

呼。。。终于搞完了,总算把这个问题给写出来了,我脑袋里可以腾出点地方给其他问题了,哈哈。另外实际上我上面写了这么多理论的东西,但是ARM早已在CMSIS库里的头文件中把这部分函数API给出来了(core_cm4.h和core_cm0plus.h),而我之所以不闲麻烦的还是把这个写出来,还是我这个知其然也要知其所以然的思想在作怪了。不过最后,我还是给出M0+和M4的中断优先级配置的两个配置供广大博友参考吧,然后其他就不多聊了,未完待续:

M0+

NVIC_SetPriority(PORTA_IRQn, 1);

NVIC_SetPriority(PORTB_IRQn, 2);

M4+

NVIC_SetPriorityGrouping(0x03); 

NVIC_SetPriority(PORTA_IRQn, NVIC_EncodePriority(0x03,1, 2));

NVIC_SetPriority(PORTB_IRQn, NVIC_EncodePriority(0x03, 2, 2));

推荐阅读

史海拾趣

Desco Tools公司的发展小趣事

随着技术的不断进步,Desco Tools公司不断进行技术创新和产品升级。公司投入大量研发资源,开发出了更加高效、可靠的防静电工具,如新型防静电工作服、无尘室专用工具等。这些产品不仅满足了市场对防静电工具日益增长的需求,还进一步巩固了公司在该领域的领先地位。

GHI Electronics公司的发展小趣事

GHI Electronics公司成立于2003年,总部位于美国密歇根州。公司自创立之初便明确了其使命:为客户提供咨询、制造和解决方案,以降低风险、成本和复杂性。这一清晰的定位使得GHI Electronics能够迅速在电子工程和制造领域站稳脚跟。随着市场需求的不断变化,GHI Electronics不断调整和优化其服务内容,逐渐赢得了客户的信任和市场的认可。

3E SECURITY公司的发展小趣事

3E SECURITY公司自创立之初,便以技术创新为核心竞争力。在电子安全领域,公司不断投入研发,推出了一系列具有自主知识产权的安全产品。其中,一款智能安全监控系统凭借其高度集成和智能化特点,迅速在市场上占据了一席之地。通过不断的技术革新,3E SECURITY逐渐在电子安全行业树立了技术领先的形象,吸引了大量合作伙伴和客户的关注。

台湾富致(FUZETEC)公司的发展小趣事

1962年,Futaba推出了无线电控制设备和冲压金属模用部件,旨在提升工业品质并缩短模具开发周期。这一举措不仅解决了当时工业控制领域中的供应商问题,还引领了模具制造行业的标准。随着技术的不断进步,Futaba开始涉足无线电传输模组(R/C)的生产和销售,并逐渐在无线遥控领域崭露头角。特别是高频无线展频通讯技术的实现,使Futaba的无线遥控技术在工业用机器人和工业控制设备上得到了广泛应用,进一步巩固了其在该领域的领先地位。

ADTech公司的发展小趣事

AdTech公司在成立之初,以其完整的传统半导体器件工艺在通信、激光医疗和激光防卫领域获得了广泛认可。然而,随着技术的不断进步和市场的变化,公司管理层意识到需要转型以维持竞争优势。2008年,经过三年的技术储备,AdTech决定将原有的光电探测器业务剥离,转而专注于量子级联激光器(QCL)的研发和生产。这一决策使公司能够专注于前沿技术,逐渐在QCL领域建立了领先地位,成为美国各大QCL激光设备的核心供应商。

CHERRY公司的发展小趣事

Cherry公司的研发部门一直是其核心竞争力所在。在一位年轻小伙子的带领下,Cherry在1983年成功研发出了具有里程碑意义的MX机械轴。这一创新产品不仅提升了键盘的使用寿命和舒适度,还解决了多个按键同时按下时的冲突问题。MX轴的诞生标志着Cherry在机械键盘领域取得了重大突破,也为公司赢得了更多的市场份额。

问答坊 | AI 解惑

嵌入式Linux系统小型化技术

    摘要:介绍了Linux在嵌入式领域中的应用和宿主机、目标机开发模式,详细地给出了精简内核的实现过程。分析了glibc系统库和ELF文件格式的结构和其中的共享库裁剪技术的原理,提出并实现了一种库裁剪方案。 关键词 嵌入式;Linux;小 ...…

查看全部问答>

关于驱动开发的迷茫……

今年刚毕业,应聘一家公司说是做驱动开发的,但是我应聘的部门是软件部,不是驱动部,工作也主要是用MFC编程。我个人对底层的一些东西还是比较感兴趣的,想做驱动开发。但是不知道在这家公司到底适不适合我……不知道这算不算是在做驱动开发,还请 ...…

查看全部问答>

Accurate Inverter Error Compensation and Related

Accurate Inverter Error Compensation and RelatedSelf-Commissioning Scheme in SensorlessInduction Motor DrivesGianmario Pellegrino, Member, IEEE, Radu Iustin Bojoi, Member, IEEE, Paolo Guglielmi, Member, IEEE,and Francesco Cupertin ...…

查看全部问答>

USART的IAP编程,下载不了程序

我的芯片是stm32f103r8。 demo中我把配置文件修改为 #define USE_STM3210B_EVAL  ,同时把FLASH_SIZE 改为 0x10000 即64K。用.hex和.bin文件下载,都没成功过。 我是用IAR生成.hex和.bin。  ...…

查看全部问答>

430F149键盘中断问题,急!!

键盘采用中断方式,可是我按键盘后,程序没反映,跟踪时有键盘的值, 在P1键盘中断中,先判断键盘的值,再做标志位,然后在主程序根据标志位来完成任务! 现在不知道是什么问题,多按几下却能够得到响应的希望结果,现在请问专家和高手们,你们的 ...…

查看全部问答>

收到MSP430 LaunchPad 开发板后,发现串口例程调试不通?

自从参加TI论坛的活动,获得LaunchPad 开发板后,本想利用MSP430G2553芯片做个小控制设备。因为需要用到串口,就随便调试了一下TI提供的几个串口例程,结果用串口调试助手调试时,发现没有收到发出的数据,不过,那个定时器模拟串口的例子可以调通 ...…

查看全部问答>

个人闲置 Jlink v8仿真器 9.5成新

jlink V8仿真器 j-link ARM9 STM32 ARM仿真器 9.5成新,买来后没有用一直放着。 有需要的朋友来看下。 http://item.taobao.com/item.htm? ... AuHN&id=37162726692 同时还有两本书: 嵌入式Linux应用开发完全手册(附CD光盘)书 韦东山 ...…

查看全部问答>

《视频4》R7F0C802下载hex文件(付方法)-Renesas Flash Programmer 和CubeSuite+

本帖最后由 kejoy 于 2014-10-3 22:33 编辑 R7F0C802下载hex文件的问题,其实在很早的帖子里面就有提到参看:https://bbs.eeworld.com.cn/thread-444254-1-1.html,但是一直没有发现问题的原因。也与坛友讨论过,最终在瑞萨FAE的帮助下找到了原因 ...…

查看全部问答>

【Nucleo心得】+ 8x8点阵驱动 (EX01)

本帖最后由 slotg 于 2014-10-5 18:21 编辑 Nucleo板的开发方式有很多种,除了大家所熟悉的KEIL,IAR等工具之外,我选择使用MBED的开发方式,这是一个全新的体验,选择MBED的原因是在这种开发环境下的编程方式就如同Arduino系统一样省略了很多对M ...…

查看全部问答>