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

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

3天内不再提示

Cortex-M内核的MPU内存保护单元

黄工的嵌入式技术圈 ? 来源:黄工的嵌入式技术圈 ? 2020-03-04 11:17 ? 次阅读
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

估计大家经常看见MCU、MPU、MMU等这类缩写词,你们了解MPU吗?

1写在前面

不知道大家有没有关注过Cortex-M内核的一些内容,在STM32大部分型号中都有MPU。

MPU是Cortex-M的选配件,拿STM32F1来说,STM32F10X_XL系列的芯片才具有这个MPU存储保护单元,而其他STM32F1芯片没有。

可能很多人都处于简单知道,或认识MPU的阶段,今天就写点关于MPU的内容,让大家进一步认识和了解MPU。

2

认识MPU,及作用

MPU:Memory Protection Unit,内存保护单元。

MPU存储器保护单元,它可以实施对存储器(主要是内存和外设寄存器)的保护,以使软件更加健壮和可靠。在使用前,必须根据需要对其编程。如果没有启用MPU,则等同于系统中没有配MPU。

MPU有如下的能力可以提高系统的可靠性:

阻止用户应用程序破坏操作系统使用的数据。

阻止一个任务访问其它任务的数据区,从而把任务隔开。

可以把关键数据区设置为只读,从根本上消除了被破坏的可能。

检测意外的存储访问,如,堆栈溢出,数组越界。

此外,还可以通过MPU设置存储器regions的其它访问属性,比如,是否缓区,是否缓冲等。

3

了解野指针

上面简单认识了一下MPU的功能,其实它有个重要的功能就是对指针访问的内存具有保护作用。所以,这里让大家认识一下指针和野指针。

回顾一下, 什么是指针?指针在内存中实际上是一个无符号整数(unsigned int),但是它的值被赋予特殊的解释:表示变量或函数的地址。所以才被形象地称为“指针”,就好像指向谁家似的。 在使用指针前, 都必须先让它指向有意义的, 并且允许由程序使用的实体——数据和代码。 而所谓“野指针”, 就是指某个指针变量的值因故超出合法的范围, 使其“枪口” 乱指。 程序逻辑错误、 数组越界、 堆栈溢出、 指针未经初始化、 对缓存与缓冲的处理不当、 多任务环境中的紊乱条件, 甚至是恶意地破坏等, 都可以制造出野指针。 如果使用野指针去读取或修改内存, 则被读取或修改的位置是不可预料的。 前者导致读回来的都是乱掉的数据, 后者则会破坏未知用途的数据。 这常常导致系统发生莫名其妙的功能紊乱, 严重时会使系统毫无征兆,没有理由地失控、死机。

野指针就像“肉里的刺, 酱里的蛆” 一般: 一个野指针就足以毁掉整个系统, 而且极其隐蔽, 很难通过症状来找出是哪里存在野指针, 甚至都不能判定症状是否因野指针造成(程序大了其它 bug 也很多,并且也能导致相同的症状)。对于通常的单片机系统,是没有任何办法来防止野指针的破坏的, 完全靠程序员的素质和自律。 但智者千虑, 必有一失。 尤其是当程序规模变得很大时,复杂度会呈指数上升,千头万绪纠缠不清, 就算是谨慎如诸葛亮,聪明如比尔?盖茨的天才,也不敢保证没有漏网之鱼。

---来自CM3内核翻译作者

4

进一步了解MPU

MPU在执行其功能时,是以所谓的“region区域”为单位的。一个region其实就是一段连续的地址,只是它们的位置和范围都要满足一些限制(对齐方式,最小容量等)。

CM3的MPU共支持8个regions,还允许把每个region进一步划分成更小的“子region”。此外,还允许启用一个“背景region”(即没有MPU时的全部地址空间),不过它是只能由特权级享用。在启用MPU后,就不得再访问定义之外的地址区间,也不得访问未经授权的region。否则,将以“访问违例”处理,触发MemManage fault。

MPU定义的regions可以相互交迭。如果某块内存落在多个region中,则访问属性和权限将由编号最大的region来决定。比如,若1号region与4号region交迭,则交迭的部分受4号region控制。

MPU可用于保护多达16个内存区域。如果区域至少为256字节,那么这些区域可以有8个子区域。子区域的大小总是相等的,可以通过子区域号启用或禁用。因为最小区域大小是由缓存行长度(32字节)驱动的,所以8个32字节的子区域对应256字节大小。

5

MPU学习资料

上面只是进一步让大家了解了MPU内存保护单元,对于想要深入理解的朋友就需要参看更多相关资料。

对学习MPU编程,就需要对MPU相关寄存器进行掌握,MPU的寄存器其实相对来说也不多,这里再Cotex-M内核技术参考手册,以及STM32应用笔记Managing memory protection unit (MPU) in STM32 MCUs、编程手册中都有讲述关于MPU的知识。

为方便大家,这里也简单说几点。

1.STM32内存映射

2.MPU 的寄存器组

操作MPU是就如操作普通STM32外设一样,通过访问它的若干寄存器来实现的,MPU寄存器如下表所示。

MPU寄存器看起来比较复杂,那是自然了,毕竟已经上升到存储器管理的高度。但如果我们胸有成竹——已经想好了对存储器如何划分,这就只是一些繁琐和考验细心的体力活。典型情况下,在启用MPU的系统中,都会有下列的regions。

特权级的程序代码(如OS内核和异常服务例程)

?用户级的程序代码

?特权级程序的数据存储器,位于代码区中(data_stack)

?用户级程序的数据存储器,位于代码区中(data_stack)

?通用的数据存储器,位于其它存储器区域中(如, SRAM

?系统设备区,只允许特权级访问,如NVIC和MPU的寄存器所有的地址区间

?常规外设区,如UARTADC

3.Cube HAL配置MPU例子

void MPU_RegionConfig(void){ MPU_Region_InitTypeDef MPU_InitStruct; /* Disable MPU */ HAL_MPU_Disable(); /* Configure RAM region as Region N°0, 8kB of size and R/W region */ MPU_InitStruct.Enable = MPU_REGION_ENABLE; MPU_InitStruct.BaseAddress = 0x20000000; MPU_InitStruct.Size = MPU_REGION_SIZE_8KB; MPU_InitStruct.AccessPermission = MPU_REGION_FULL_ACCESS; MPU_InitStruct.IsBufferable = MPU_ACCESS_NOT_BUFFERABLE; MPU_InitStruct.IsCacheable = MPU_ACCESS_CACHEABLE; MPU_InitStruct.IsShareable = MPU_ACCESS_SHAREABLE; MPU_InitStruct.Number = MPU_REGION_NUMBER0; MPU_InitStruct.TypeExtField = MPU_TEX_LEVEL0; MPU_InitStruct.SubRegionDisable = 0x00; MPU_InitStruct.DisableExec = MPU_INSTRUCTION_ACCESS_ENABLE; HAL_MPU_ConfigRegion(&MPU_InitStruct); /* Configure FLASH region as REGION N°1, 1MB of size and R/W region */ MPU_InitStruct.BaseAddress = 0x08000000; MPU_InitStruct.Size = MPU_REGION_SIZE_1MB; MPU_InitStruct.IsShareable = MPU_ACCESS_NOT_SHAREABLE; MPU_InitStruct.Number = MPU_REGION_NUMBER1; HAL_MPU_ConfigRegion(&MPU_InitStruct); /* Configure FMC region as REGION N°2, 0.5GB of size, R/W region */ MPU_InitStruct.BaseAddress = 0x60000000; MPU_InitStruct.Size = MPU_REGION_SIZE_512MB; MPU_InitStruct.IsShareable = MPU_ACCESS_SHAREABLE; MPU_InitStruct.Number = MPU_REGION_NUMBER2; HAL_MPU_ConfigRegion(&MPU_InitStruct); /* Enable MPU */ HAL_MPU_Enable(MPU_PRIVILEGED_DEFAULT);}

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

    关注

    146

    文章

    18032

    浏览量

    369337
  • MPU
    MPU
    +关注

    关注

    0

    文章

    420

    浏览量

    50041
  • MMU
    MMU
    +关注

    关注

    0

    文章

    92

    浏览量

    18800
  • Cortex-M
    +关注

    关注

    2

    文章

    231

    浏览量

    30446
收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    瑞萨RZ/A3M HMI MPU介绍

    对于高质量图形显示的应用要求,用户通常采用功能强大及搭载DDR高速接口的MPU来实现更多功能和更流畅的画面。但在开发过程会遇到DDR高速总线设计的难题,同时Linux系统难以实现类似MCU的快速启动性能。瑞萨新推出的RZ/A3M HMI
    的头像 发表于 05-27 16:14 ?479次阅读
    瑞萨RZ/A3<b class='flag-5'>M</b> HMI <b class='flag-5'>MPU</b>介绍

    RZ/T2H MPU数据手册和产品介绍#集成了强大的应用处理能力和精确的实时控制功能

    。Renesas Electronics RZ/T2H MPU具有多达四个ARM? Cortex?-A55内核(运行频率为1.2GHz)和两个ARM Cortex-R52
    的头像 发表于 05-21 10:24 ?548次阅读
    RZ/T2H <b class='flag-5'>MPU</b>数据手册和产品介绍#集成了强大的应用处理能力和精确的实时控制功能

    HOLTEK推出全新单片机HT32F49041

    内存保护单元(MPU),增强数值运算效能与应用安全性。该单片机具备多种节能模式,特别适合各应用场景诸如嵌入式系统、计算机周边、工业自动化、电机控制、物联网、消费性电子等领域,为Cortex-
    的头像 发表于 05-10 10:43 ?907次阅读

    瑞萨RA8快速上手指南:Cortex-M85内核瑞萨RA8开发环境搭建 并点亮一个LED

    因为Cortex-M内核,瑞萨RA8系列单片机支持多种市面上常见的开发环境,像Keil MDK、IAR EWARM等,而本文讲述的是瑞萨自家官方的IDE(e2 studio)。
    的头像 发表于 03-17 14:35 ?1083次阅读
    瑞萨RA8快速上手指南:<b class='flag-5'>Cortex-M</b>85<b class='flag-5'>内核</b>瑞萨RA8开发环境搭建 并点亮一个LED

    可实现工业 AC Servo 和控制器高速处理的多功能 MPU RZ/T2M 数据手册

    ? Cortex?-R52 内核,可进行实时控制,而且还拥有能够与 CPU 直接连接的大容量紧密耦合内存(576KB),以实现高性能实时处理。 此外,它还可以将电机控制的外设布置到能直接连接至 CPU
    的头像 发表于 03-14 15:39 ?576次阅读
    可实现工业 AC Servo 和控制器高速处理的多功能 <b class='flag-5'>MPU</b> RZ/T2<b class='flag-5'>M</b> 数据手册

    通过EtherCAT实现高速、高精度实时控制的高性能MPU RZ/T2L数据手册

    RZ/T2L 是一款高性能 MPU,可通过 EtherCAT 实现高速、高精度的实时控制。 RZ/T2L 搭载最大频率为 800MHz 的 Arm? Cortex?-R52 内核以及与 CPU 紧密
    的头像 发表于 03-14 15:07 ?488次阅读
    通过EtherCAT实现高速、高精度实时控制的高性能<b class='flag-5'>MPU</b> RZ/T2L数据手册

    东芝推出七款基于Arm Cortex-M4内核的32位微控制器

    东芝电子元件及存储装置株式会社(“东芝”)宣布,最新推出七款配备Cortex-M4内核的32位微控制器,进一步扩大其电机控制微控制器产品线。其中,六款产品组成新的产品组合——M4K组(1)[1],另外一款产品加入
    的头像 发表于 01-22 18:05 ?899次阅读
    东芝推出七款基于Arm <b class='flag-5'>Cortex-M</b>4<b class='flag-5'>内核</b>的32位微控制器

    MPU的性能评估方法

    MPU(Microprocessor Unit,微处理器单元)的性能评估是确保其在实际应用中能够满足需求的重要环节。以下是一些常用的MPU性能评估方法: 一、基准测试(Benchmark
    的头像 发表于 01-08 09:39 ?829次阅读

    MPU与数字信号处理的关系

    ,特别是在音频、视频和通信领域。 MPU的定义与功能 微处理器单元MPU)是一种集成电路,它集成了中央处理单元(CPU)、内存、输入/输出
    的头像 发表于 01-08 09:29 ?670次阅读

    MPU与MCU的区别

    和应用上存在显著差异。 MPU与MCU的定义 微处理器单元MPU) : MPU是一种通用的中央处理单元,它主要设计用于执行复杂的计算任务。
    的头像 发表于 01-08 09:25 ?1669次阅读

    MPU微处理器的工作原理

    在现代电子设备中,微处理器(MPU)扮演着至关重要的角色。从个人电脑到智能手机,再到嵌入式系统,MPU都是实现复杂计算任务的关键。 MPU的基本结构 MPU的核心是中央处理
    的头像 发表于 01-07 18:08 ?1549次阅读

    如何使用Ozone分析Cortex-M异常

    Ozone可以帮助用户快速分析和查找导致CPU故障的软件bug。本文解释如何使用Ozone的调试功能,深入了解Cortex-M架构上的这些错误。
    的头像 发表于 11-29 11:14 ?1808次阅读
    如何使用Ozone分析<b class='flag-5'>Cortex-M</b>异常

    兆易创新推出基于Arm Cortex-M33内核的GD32G5系列高性能微控制器

    近日,业界领先的半导体器件供应商兆易创新GigaDevice (股票代码 603986) 宣布,正式推出基于Arm Cortex-M33内核的GD32G5系列高性能微控制器。
    的头像 发表于 11-13 17:24 ?1861次阅读
    兆易创新推出基于Arm <b class='flag-5'>Cortex-M</b>33<b class='flag-5'>内核</b>的GD32G5系列高性能微控制器

    实际项目开发中为何选择ARM? Cortex?-M4 内核的HK32MCU?

    ?Cortex?-M4内核的HK32F407芯片的深度知识,并围绕各类实际案例详细解读了如何选型,为何选择ARM?Cortex?-M4
    的头像 发表于 10-22 17:19 ?943次阅读
    实际项目开发中为何选择ARM? <b class='flag-5'>Cortex</b>?-<b class='flag-5'>M</b>4 <b class='flag-5'>内核</b>的HK32MCU?

    瑞萨电子基于Arm Cortex-A55和双Cortex-M33 MPU的SOM方案 加速物联网设计

    基于Arm Cortex-A55(1.1GHz)和双Cortex-M33(250MHz)MPU的SOM(系统模块)方案,该方案可加快物联网应用的开发进程,并降低其设计风险。 系统框图 方案介绍 本方案由一个多功能OSM载板和一个
    的头像 发表于 08-15 17:23 ?2443次阅读
    瑞萨电子基于Arm <b class='flag-5'>Cortex</b>-A55和双<b class='flag-5'>Cortex-M</b>33 <b class='flag-5'>MPU</b>的SOM方案 加速物联网设计