CCM - 极致发挥STM32F4性能的利器
2016-04-01 10:30
155 查看
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 关键词.
把原先 placein RAM_region {...} 的命令改为如下2句:
place in RAM_region { readwrite };
place in CCMRAM_region { block CSTACK, block HEAP };
搞定!
特别是运行RTOS的时候,此类堆栈可以作为特权资源进行管理, 安全和性能得到同步提升.
2. 做高速运算缓冲
对于运算密集型的应用, 同样可以通过定制链接脚本,在CCM中划分出专用的全速运算缓冲区.
比如: FOC模型解耦, 网络SSL,JPEG编码/解码...
这时的F4内核才真正能够发挥出最高的运算性能.
本文转自自苗爸的博客,http://blog.sina.com.cn/miaobaa。转载请注明出处。
由于其地址空间和常规的SRAM不连续, 加之DMA和外设也无法直接使用它们,就使得一般的用户程序完全视而不见这64KB全速RAM, 罪过啊
...
言归正传, 既然是全速又专用的SRAM, 可以这么使用来充分发挥F4性能:
1. 作堆栈.
修改链接脚本, 找到 CCMRAM_region,block CSTACK 和 block HEAP 关键词.
把原先 placein RAM_region {...} 的命令改为如下2句:
place in RAM_region { readwrite };
place in CCMRAM_region { block CSTACK, block HEAP };
搞定!
特别是运行RTOS的时候,此类堆栈可以作为特权资源进行管理, 安全和性能得到同步提升.
2. 做高速运算缓冲
对于运算密集型的应用, 同样可以通过定制链接脚本,在CCM中划分出专用的全速运算缓冲区.
比如: FOC模型解耦, 网络SSL,JPEG编码/解码...
这时的F4内核才真正能够发挥出最高的运算性能.
本文转自自苗爸的博客,http://blog.sina.com.cn/miaobaa。转载请注明出处。
相关文章推荐
- php的PDO
- 浏览器插件之ActiveX开发(一)
- 操作系统常见内存分配算法及优缺点
- RK3288的gpio设置
- Coursera《machine learning》--(2)单变量线性回归(Linear Regression with One Variable)
- 应该如何入门deep learning呢?从UFLDL开始!
- (转载)深度学习三十年创新路
- Coursera《machine learning》--(8)神经网络表述
- 卷积神经网络
- (转载)卷积神经网络
- 机器学习、深度学习的相关资料
- (转载)KL距离,Kullback-Leibler Divergence
- (转载)图像处理(卷积)
- (转载)Convolutional Neural Networks卷积神经网络
- 卷积神经网络 cnnff.m程序 中的前向传播算法 数据 分步解析
- UFLDL教程之(一)sparseae_exercise
- 全连接的BP神经网络
- Coursera《machine learning》--(14)数据降维
- matlab函数之bsxfun
- matlab的常用快捷键