STM32H7-MPU1 u: z7 J! h' [2 U! T& }& ?" j 一、MPU的作用 防止不受信用的应用程序访问受保护的内存区域 防止用户应用程序破坏操作系统使用的数据 通过阻止任务访问其他任务的数据区" m3 r( I( x5 j! q0 H 允许将内存区域定义为只读,以便保护重要数据。 检测意外的内存访问 简单来说,就是内存保护、外设保护和代码访问保护。, r% N2 `+ g; s6 g 二、MPU的功能实现 J' q2 ]" b$ U! _4 O; n MPU可以配置保护16个内存区域,每个区域都是独立配置的。每个区域的最小要求是32字节,同时每个区域还可以配置为8个子区域,通过寄存器对应的bit来使能。) g v# b( z; o' m2 u9 Z1 P MPU可配置的16个内存区的序号范围是0-15,还有一个默认区(背景区)序号为-1,这些内存区可以重叠以及嵌套——序号为15的优先级最高、背景区的优先级最低。例如下图,共有七个内存区:一个背景区+序号为0-5的内存区。内存区4和内存区0、1有重叠部分,则重叠部分按照内存区4的配置规则执行;内存区5被完全包含在内存区3里面,则这部分内存区的配置按照内存区5的配置规则进行。 # @8 P1 }* B# |8 {' H! ~ 三、MPU常用的寄存器(RASR寄存器和控制寄存器) + s/ h) \0 j! R! r9 }/ M3 D # K5 h( X7 F! l3 V XN位:表示是否使能指令的提取& d8 J2 Z5 X/ n2 | XN=0:使能指令提取,即这块内存可以执行程序代码 XN=1:禁止指令提取,机这块内存禁止执行程序代码" F% x1 ]# J1 R3 e+ k AP位:设置指定区域的访问权限类型 : T6 M+ w$ ]% \+ g. f TEX、C、B、S位:用于配置Cache的策略 C位:用于使能或者禁止Cache B位:用于配合C位实现Cache下是否使用缓冲 S位:用于解决多总线或者多核访问的共享问题" l- G. o! J8 Z, l2 I ; `6 }& W2 k5 ]( G6 M * U! X2 Q+ K# [ A read/write-through/back/allocate的区别:2 Q! A) a+ n x( k4 k) h 一、CPU读Cache7 b8 b$ ]# e. y( ]+ m3 v2 k Read through:直接从内存区读取数据 Read allocate:先把数据读取到Cache中,再从Cache中读取数据 二、CPU写Cache 若hit命中,有两种处理方式: 4 X4 P/ `4 E; r' [ J% J! c Write-through:在数据更新时,把数据同时写入Cache和存储区4 R% ?% b A8 _5 _/ p0 u( }, { 操作简单,但是写入速度慢" Q6 P* B( W) C2 C Write-back:只有在数据被替换出缓存时,被修改的缓存数据才会被写到后端存储。 写入速度快,但是一旦更新后的数据未被写入时出现断电,则数据无法找回4 h6 l" f7 t4 s$ @+ Y 若miss,有两种处理方式:& ?7 D( ?0 f2 B! K7 [6 D/ a Write allocate:先把要写的数据载入到Cache中,写Cache,然后再通过flush的方式写入到内存中。 No-write allocate:并不将写入位置读入缓存,直接把要写的数据写入到内存中。$ B0 c- X" Z; z9 X/ v. z$ ? 什么叫hit/miss:" @. @, h+ \( z& i5 T! b 一、读操作3 K6 k# e+ w( `- M 如果CPU要读取的SRAM区数据在Cache中已经加载好,这就叫读命 中(Cache hit),如果Cache里面没有怎么办,这就是所谓的读Cache Miss。 J+ R6 P5 N3 F* K ! a: R% u6 P' P; z' R 二、写操作 如果CPU要写的SRAM区数据在Cache中已经开辟了对应的区域(专业词汇叫Cache Line,以32字节为单位),这就叫写命中(Cache hit),如果Cache里面没有开辟对应的区域怎么办,这就是所谓的写Cache Miss。1 P7 u9 ~8 U* `5 \ SRD位:用于控制内存区的子区域,一共有8bit,一个bit控制一个子区域,一般都开启 SIZE位:配置保护的内存的大小 0 {4 ^8 c$ Z5 [ 四、MPU的HAL库配置函数, S: O9 Q$ D3 h, S* \ HAL_MPU_Disable:配置前要禁止MPU# I j( p9 y# V( B3 [; ?2 ]2 ^ HAL_MPU_Enable:使能 一般使用参数MPU_PRIVILEGED_DEFAULT1 H: i: B C- R HAL_MPU_ConfigRegion:配置MPU
( _% T% P% T% h1 j8 T1 T2 M |
【经验分享】STM32_H7_ADC
STM32H7R/S高性能MCU:安全性,大存储和优异图显赋能更多应用创新
Stm32H7XX GCC下分散加载实现
【银杏科技ARM+FPGA双核心应用】STM32H7系列10——ADC
DIY-STM32H750核心板
[nucleo-H7A3ZI-Q]1-点亮一个皮皮灯
DIY-STM32H743核心板
【银杏科技ARM+FPGA双核心应用】STM32H7系列57——MDK_FLM
1月10日有奖直播 | 基于STM32 的CODESYS智能自动化解决方案
STM32的CAN FD位定时设置注意事项