在使用之前我们要先学**H7的内存分布,之前可能接触过ST的程序员没有发现有内存分布的特性,这可能是在M7系列新加的特性。- Y9 f+ T, W ^" H4 i" u0 z TCM : Tightly-Coupled Memory 紧密耦合内存 。ITCM 用于指令,DTCM 用于数据,特点是跟内7 S1 \: g$ s! u& w; l 核速度一样,而片上 RAM 的速度基本都达不到这个速度。 + ?& Y+ X# X0 c. w ITCM 和 DTCM& W! o$ y, a3 S$ _2 y 这两个是直连 CPU 的。 7 y8 S+ @. k8 i) o" [ TCM 区6 z' p4 c- k5 d9 B- K# z0 Z TCM : Tightly-Coupled Memory 紧密耦合内存 。ITCM 用于运行指令,也就是程序代码,DTCM' s8 x5 c( _0 Q. ]* {/ b# e 用于数据存取,特点是跟内核速度一样,而片上 RAM 的速度基本都达不到这个速度,所以有降频处* M7 v' `. ?1 @) S- e: U+ [0 ?+ {' L 理。( o. R4 B! _7 K0 U6 [" ?! z* F7 u% Z 速度:400MHz。 DTCM 地址:0x2000 0000,大小 128KB。 ITCM 地址:0x0000 0000,大小 64KB。" o( g5 A+ t; l4 T2 \ k AXI SRAM 区 位于 D1 域,数据带宽是 64bit,挂在 AXI 总线上。除了 D3 域中的 BDMB 主控不能访问,其它都可 以访问此 RAM 区。 速度:200MHz。# q5 Z$ o w3 j# S 地址:0x2400 0000,大小 512KB。* \5 w! b# @0 X1 y 用途:用途不限,可以用于用户应用数据存储或者 LCD 显存。* t/ y: N V, N; C; A SRAM1,SRAM2 和 SRAM3 区 SRAM1:地址 0x3000 0000,大小 128KB,用途不限,可用于 D2 域中的 DMA 缓冲,也可以当1 A4 F8 x8 B' P3 S! W D1 域断电后用于运行程序代码。 SRAM2:地址 0x3002 0000,大小 128KB,用途不限,可用于 D2 域中的 DMA 缓冲,也可以用于 用户数据存取。 SRAM3:地址 0x3004 0000,大小 32KB,用途不限,主要用于以太网和 USB 的缓冲。" p8 }; |0 R/ W. N5 }5 z) ?% j, f SRAM4 区+ M/ a! }) T5 p M* g: u' j 位于 D3 域,数据带宽是 32bit,挂在 AHB 总线上,大部分主控都能访这块 SRAM 区。 速度:200MHz。$ ~* v7 X T g7 a' o 地址:0x3800 0000,大小 64KB。 用途:用途不限,可以用于 D3 域中的 DMA 缓冲,也可以当 D1 和 D2 域进入 DStandby 待机方式: `0 R8 }0 ?, E7 j B 后,继续保存用户数据。' \5 V# a, L) n# m8 @- t! j Backup SRAM 区 备份 RAM 区,位于 D3 域,数据带宽是 32bit,挂在 AHB 总线上,大部分主控都能访问这块 SRAM 区。/ A# |, K, }6 X9 x 速度:200MHz。9 o9 u" s' f) R$ f4 U 地址:0x3880 0000,大小 4KB。: Z2 n& D }8 S' n# I: L& V$ z 用途:用途不限,主要用于系统进入低功耗模式后,继续保存数据(Vbat 引脚外接电池)。 + S% l% N1 y" Z 各块 RAM 的 DMA 问题 之前写了一个空闲中断+DMA的例子,在F4的板子稳定运行,可是在H7上跑不通,所以才注意到了内存分布对DMA的影响 DTCM 和 ITCM 不支持 DMA1,DMA2 和 BDMA,仅支持 MDMA。 AXI SRAM,SRAM1,SRAM2,SRAM3 不支持 BDMA,支持 MDMA,DMA1 和 DMA2。 SRAM4 支持所有 DMA,即 MDMA,DMA1,DMA2 和 BDMA。* [4 K- N, ]# h4 ]+ }" z) W7 A2 d, Z 鉴于 DTCM 是 400MHz 的,而其它的 RAM 都是 200MHz,推荐工程的主 RAM 空间采用 TCM,而8 F& |# v; |3 L9 f E 其它需要大 RAM 或者 DMA 的场合,使用剩余 RAM 空间。 本教程配套的例子基本都是采用的这个方案,让 TCM 的性能得到最大发挥。1 e2 H' C) T+ C; `; D # z4 f; _/ l5 V. Y) p |
stm32使用定时器触发dma传输,启动dma没反应的几种情况的解决方法
【Wio Lite AI视觉开发套件】+cube.ai与食物识别
【STM32H7S78-DK】汽车仪表系统
【STM32H7S78-DK】基于 rtthread 适配 lcd 驱动移植 lvgl
【STM32H7S78-DK评测】TouchGFX (QR Code)二维码生成器
【STM32H7S78-DK】rtthread 增加 psram 内存管理
【STM32H7S78-DK】开箱与rtthread工程初体验
【STM32H7S78-DK评测】-5 LVGL&DMA2D DEMO测试
【STM32H7S78-DK评测】-4 LTDC&DMA2D 基本测试
【STM32H7S78-DK评测】CoreMark移植和优化--兼记printf重定向实现方法及常见问题