CCM - 极致发挥STM32F4性能的利器

今天与同事聊起之前使用过的stm32f4的一款处理器,说起关于ram的部分,其中对于CCM了解还不是很清楚,之前只是把它作为一块特殊的、快速的ram使用。今天查询汇总了一下,觉得如下描述还是比较清晰的。

CCM(Core Coupled Memory)是给F4内核专用的全速64KB RAM, 它们没有经过总线矩阵, F4内核与之直接相连, 地址空间在0x1000_0000 ~ 0x1000_FFFF.

由于其地址空间和常规的SRAM不连续, 加之DMA和外设也无法直接使用它们, 就使得一般的用户程序完全视而不见这64KB全速RAM。

言归正传, 既然是全速又专用的SRAM, 可以这么使用来充分发挥F4性能:

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 };

   搞定!

   特别是运行RTOS的时候, 此类堆栈可以作为特权资源进行管理, 安全和性能得到同步提升. 

这种使用方式也是我之前主要的使用方式。还有一种就是把它与普通的ram合并,作为普通的ram使用,这就有点浪费了

2. 做高速运算缓冲

   对于运算密集型的应用, 同样可以通过定制链接脚本, 在CCM中划分出专用的全速运算缓冲区.

   比如: FOC模型解耦, 网络SSL, JPEG编码/解码...

   这时的F4内核才真正能够发挥出最高的运算性能.

上一篇:STM32F4学习指南


下一篇:西门子 S7-300 以太网模块连接 WINCC方案