STM32H7的Cache与Buffer TCM和Cache的区别4 E/ s$ y; o ^% k% g, ^( A7 \2 a …使用lwip用到了mpu,对于内存管理产生了很多的疑问,需要统一解决一下,不然用起来总有些不安。 STM32H7使用的内存不是连续的,而是被划分为多段。
TCM内存段是和CPU同频率的,不需要也不能用Cache。用好TCM的优先级应该排在用好Cache的前面。6 ]; a; [4 y; ]: A$ X) H Cache处于核心里面,作为低速内存加速器使用,获得增益最大的是位于AXI总线上的比如内部Flash、内部SRAM、通过FMC或者QSPI控制器连接的外部sram。Cache使得低速Sram获取与高速TCM差不多的速度。使用Cache加速很有意义,不然400M的cpu变200M,相当于H7变F4,选择H7的cpu将变得没有意义。# P4 u% W7 p- v* R4 |& R( \ " ]+ g! X- y! ]$ M0 I& a3 M 内存类型 内存类型分为Normal以及Device和Strongly-ordered, U6 Q1 `/ t* x, `( E% u* c Write-buffer是什么?2 k7 I1 _ I# n$ Y+ F5 `9 F Device和Strongly-Ordered类型时候提到了write-buffer,它属于cpu核心,cache经常与write-buffer一起使用,使用writer-buffer的目的是将处理器和cache从较慢的对主存的写操作中脱离出来。0 S4 o: [- v, t# ] Write buffer可以缓存8个word的数据和4个独立的地址,可以enable或者disable使用ARM核心控制寄存器 W的bit3。同时还要受到内存管理页表的一个bit控制,所以使用Write-Buffer,MMU必须已经使能(控制寄存器的bit0)。MMU-Memory Management Unit 通常情况下的配置都是主内存允许bufferable,但是I/O 空间 unbufferable 当CPU执行一个写操作时,根据配置情况执行写入操作。 3 I+ s. r( b6 {& w 0 ]5 v6 ~! ]. w% t$ b% |. o 如果程序中使用DMB and DSB,处理器会等到write-buffer内指令完成,再进行后续指令操作,如果过程中发生中断,中断返回后继续write-buffer清空等待。 DMB或者DSB被称为 显式限制操作 explicit barrier。 ; h' l/ \' G8 I: @* F( b Memory Attrabute Normal模式下可以设定的几种; x1 ?" q; p% v - l8 y, p6 n- i! _! J Shareable属性: k6 ]& U# @8 r, z2 v2 } 共享属性设计的意义在于,多个bus master读写情况下需要cache保持同步,对于CortexM7,只有L1-Cache,如果设置了Shared相当于non-cacheable。& G# Q4 s' J1 \3 P 内核操作函数" I# p' V* G3 i3 ?, F, I 内核操作函数包含以下几种,主要包含两种操作:clean和invalidate。 clean:将cache中的信息写到sram,相当于用cache信息覆盖sram;+ {9 H6 C2 ]3 _8 \ invalidate:使cache失效,相当于用sram信息覆盖cache; 二者为相反的操作。 % d% t1 ]' T. w- k & n' G! m) v* Q% l 内存对齐问题( \0 d1 P& B$ Z8 @4 X4 ]3 n# u 使用cache时,dma的buffer必须32byte对齐,不然可能会出现问题。比如下面的情况:: S* ~5 D- p3 {+ B! P2 G7 \ 2 f" I, e7 D0 P% h
: [6 s6 o O0 G 如果DMA的buffer只有16字节,DMA读取操作后,DMA控制器将接收到的数据写到了sram里面,然后进入DMA接收中断函数,cpu把成功读取的标识bool变量写为true,实际上写操作只是写在D-Cache里面,暂时没有写到sram。' g8 b! } E. i1 d% [ 如果此时cpu需要读取dma内容,需要对Dcache进行invalid操作,32个字节将一起更新,bool变量旧值0将覆盖新值1。cpu读不到中断函数写的bool变量信息。 , k) N- t# `2 p$ E0 B 可见:( j1 q$ }* ?7 O* \8 P clean操作或者Invalidate操作都可能丢东西,使用上需要注意。经验是如果一段内存用来写dma外设,就不要读它,保证随时都可以clean;同样如果一段内存用来接收DMA外设传入信息,就不要用cpu写它,保证随时都可以invalidate。 6 P( x' Z5 Z& h+ X5 r2 ?6 i , o j) f1 M/ ~ * U; U; A9 z6 v0 D |
【经验分享】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位定时设置注意事项