cortex-m3的操作模式及特权级别

发布时间:2024-01-10  

STM32是cortex-m3内核芯片,拥有cortex-m3的特性,以下介绍了cortex-m3的特权级别。


1、先来说一下操作模式:

cortex-m3有两种操作模式:笔者觉得也可以称为代码执行模式,线程模式(thread mode)和异常模式(handler mode),用于表示处理器在执行什么代码。

thread mode:执行非异常代码,也就是用户代码。

handler mode:执行异常代码,如中断服务程序。

2、再来说一下特权级别:

cortex-m3有两种权利级别:特权级(Privilege)和用户级(user)。这两种模式主要用于阻止对硬件的异常访问,比如存储资源、关键寄存器等。

特权级别:能够访问硬件所有存储资源,能够执行所有指令。

用户级别:禁止使用MSR和MRS访问特殊功能寄存器(APSR除外),不能使用CPS指令。对系统控制空间的访问有限制,即,不能访问system tick、NVIC、system control block(SCB)。

如何才能在这两个级别切换呢?答案是修改寄存器CONTROL[0]。这个寄存器只能在特权级别下修改,用户级别下是不能修改此寄存器的,要想从用户级别转到特权级别,只能进入异常/中断,然后在异常/中断中修改寄存器,因为在异常/中断中总是特权级别。

在线程模式,可以是特权级,也可以是用户级。handler模式总是特权级的。在复位后,处理器处于线程模式+特权级。

3、介绍一下系统控制空间(SCS):

系统控制空间(system control space):在地址空间的位置,如下图所示,地址区间0xE000E000-0xE000F000,这部分区域包含:System control block、system tick、Nested Vectored Interrupt Controller(NVIC)、PMU等。这些寄存器是处理器能够工作的根本,必须有相应权限才能修改,即,特权级才能修改。

poYBAGP-v3aAQ9rNAAMZjpHl_GA060.png

System control block(SCB)包含了系统相关的寄存器,如下:

poYBAGP-v4yARrPiAAK40gAfTJA273.png

4、总结:

特权级有特权,权利大,能访问所有资源,用户级权利小,不能所有资源。说实话这权利级别一般不做修改,即,保持默认的特权级别。因为cortex-M3内核是个低端内核,很大一部分应用都是无操作系统的裸机执行程序,在没有特殊安全要求的前提下没必要切来切去的,比较麻烦。

5、题外话:

我们在使用STM32跑实时操作系统的时候经常使用systick作为操作系统的心跳,很多人不知道这个systick和普通的定时器有什么区别,通过上面介绍这个systick相关寄存器位于系统控制空间(SCS),用户级别不能访问systick寄存器,防止用户级别代码误操作,篡改systick寄存器威胁系统安全。


文章来源于:电子工程世界    原文链接
本站所有转载文章系出于传递更多信息之目的,且明确注明来源,不希望被转载的媒体或个人可与我们联系,我们将立即进行删除处理。

相关文章

    什么?8位MCU还在增长?;我们经常讨论8位、 16位、 32位和 64位处理器,但不知道现在年轻的工程师们是否知道,第一个商业微处理器 Intel 4004是一台 4位机器。本文引用地址:微处理器也称为微处理器......
    机除了具备八位的CPU之外,实际上它有两个,它还有一个位处理器,一个字节处理器,所以呢,51单片机可以进行自己处理,还可以进行位处理,是因为它内部还有一个为处理器,除了字节处理数据的处理器,又有位处理器,有很多的处理都是借助于位处理......
    实现门数少),至少不输于32位的处理器。误解 78位MCU的能效低于32位MCU 曾经看过ARM公司的权威工程师写的一本书,书中观点是32位处理器的能效比高于8位的MCU,理由是32位处理器能快速处理......
    访问;桥会自动将 16 位或者 8 位的数据扩展以配合 32 位的宽度。 4.2. 存储器映射 此 32 位处理器采用同一套总线来读取指令和加载/存储数据。指令代码和数据都位于相同的存储器地址空间,但在......
    ,它集成了双核Arm®Cortex-A55@1.2GHz CPU和Cortex-M33副核,支持图形加速、编码和解码功能。 MYZR-RZG2UL-EK200搭载瑞萨RZ/G2UL 64位处理器,它集......
    更大了。 二是处理效率。64位与32位处理器的效率也是不同的,32位一次运算需要4个寄存器,64位只需要2个。 任何时间,人类对于性能的追求都是永无止境的,MPU亦如此,随着工业4.0和AI的到......
    期增速高于全球半导体平均增幅。 如何跑赢全球市场?嵌入式处理芯片就是发力方向之一。TI推出新系列MSPM0,丰富自己的阵营。想想看,从早晨睁开眼睛开始,用咖啡机喝咖啡、用扫地机器人扫地……32位处理器几乎无处不在,适用......
    将有可能同时检测数百人或识别超速汽车的车牌,而无需再将大量数据传输到云端,影响处理的实时性。  为什么采用 64 位处理技术至关重要? 通过迁移至 64 位处理技术,可以更好地利用先进的64位CPU 硬件与身俱来的更高性能和效率。最重......
    www.picocom.com 关于晶心 过去15年,因应快速发展的全球嵌入式系统应用,晶心科技致力成为创新高效能、低功耗32及64位处理器核心和相关开发环境的世界级创建者。晶心是RISC-V国际......
    棋正式为外人所知是iPhone 5S发布时候。 那是2013年的9月,5S的一大卖点是64位双核苹果A7处理器。但在当时,其实64位和32位处理器对比并没有什么优势,“64位”的概念不仅是换个处理器,应该......

我们与500+贴片厂合作,完美满足客户的定制需求。为品牌提供定制化的推广方案、专属产品特色页,多渠道推广,SEM/SEO精准营销以及与公众号的联合推广...详细>>

利用葫芦芯平台的卓越技术服务和新产品推广能力,原厂代理能轻松打入消费物联网(IOT)、信息与通信(ICT)、汽车及新能源汽车、工业自动化及工业物联网、装备及功率电子...详细>>

充分利用其强大的电子元器件采购流量,创新性地为这些物料提供了一个全新的窗口。我们的高效数字营销技术,不仅可以助你轻松识别与连接到需求方,更能够极大地提高“闲置物料”的处理能力,通过葫芦芯平台...详细>>

我们的目标很明确:构建一个全方位的半导体产业生态系统。成为一家全球领先的半导体互联网生态公司。目前,我们已成功打造了智能汽车、智能家居、大健康医疗、机器人和材料等五大生态领域。更为重要的是...详细>>

我们深知加工与定制类服务商的价值和重要性,因此,我们倾力为您提供最顶尖的营销资源。在我们的平台上,您可以直接接触到100万的研发工程师和采购工程师,以及10万的活跃客户群体...详细>>

凭借我们强大的专业流量和尖端的互联网数字营销技术,我们承诺为原厂提供免费的产品资料推广服务。无论是最新的资讯、技术动态还是创新产品,都可以通过我们的平台迅速传达给目标客户...详细>>

我们不止于将线索转化为潜在客户。葫芦芯平台致力于形成业务闭环,从引流、宣传到最终销售,全程跟进,确保每一个potential lead都得到妥善处理,从而大幅提高转化率。不仅如此...详细>>