stm32f4的RAM和FLASH
stm32f407zgt6芯片手册中ram为196KB=128KB IRAM1 +64KB IRAM2 +4KB BACKED RAM1.但一般sct文件都是用的128KB IRAM1,那IRAM2什么时候用,怎么用?
CCM(Core Coupled Memory)是给F4内核专用的全速64KB RAM, 它们没有经过总线矩阵, F4内核与之直接相连, 地址空间在0x1000_0000 ~ 0x1000_FFFF.由于其地址空间和常规的SRAM不连续, DMA和外设也无法直接使用它们.
如文章中所说,IRAM2一般作为高速运算缓冲BUF(网络,存储,显示,FOC模型解耦, 网络SSL, JPEG编码/解码),或堆栈可以作为特权资源进行管理, 安全和性能得到同步提升.提高效率,在IRAM1不够用的情况下也可以开启,可以通过MAP文件将指定模块的目标文件或静态数组BUF放在IRAM2中。
1. 作堆栈时如何使用.
修改链接脚本, 找到 CCMRAM_region, block CSTACK 和 block HEAP 关键词.
把原先 place in RAM_region {...} 的命令改为如下2句:
place in RAM_region { readwrite };
place in CCMRAM_region { block CSTACK, block HEAP };
2.如何优先使用64KCCRAM:
Keil的设置选项,将IRAM1/IRAM2打勾,将IRAM1改为0x10000000,这样,编译器就会优先分配CCM内存;在SCT中修改同样。