OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 18692|回复: 3

菜鸟提问,CCM内存和SRAM内存使用起来有什么区别吗??

[复制链接]

10

主题

16

帖子

0

精华

初级会员

Rank: 2

积分
84
金钱
84
注册时间
2015-4-6
在线时间
2 小时
发表于 2015-6-10 22:16:47 | 显示全部楼层 |阅读模式
5金钱
RT

最佳答案

查看完整内容[请看2#楼]

CCM只可以CPU访问,SRAM的话CPU和DMA等外设都可以访问。
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165371
金钱
165371
注册时间
2010-12-1
在线时间
2110 小时
发表于 2015-6-10 22:16:48 | 显示全部楼层
CCM只可以CPU访问,SRAM的话CPU和DMA等外设都可以访问。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

2

主题

84

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
214
金钱
214
注册时间
2014-12-29
在线时间
36 小时
发表于 2015-6-11 19:48:14 | 显示全部楼层
CCM存储器DMA不能访问,理论是访问速度比SRAM更快
以IAR环境下为例,可以这样定义内存link文件,IAR下对应的是*.icf文件
在Memory Regions下添加
/*-Memory Regions-*/
………………………………
………………………………
//定义CCM的起止范围
define symbol __ICFEDIT_region_CCMRAM_start__ = 0x10000000;
define symbol __ICFEDIT_region_CCMRAM_end__   = 0x1000FFFF;

//然后定义regiom
define region CCMRAM_region   = mem:[from __ICFEDIT_region_CCMRAM_start__   to __ICFEDIT_region_CCMRAM_end__];

//定义一个控制标志
place in CCMRAM_region { section .ccmram          };                           //使用方法 定义的变量后面加  @ ".ccmram";

/********************************/

如此修改icf文件后,当你定义变量的时候,如此操作:

例:
uint32_t  i @".ccmram";

此时,i就被定义在CCM中.

也可以修改*icf中关于堆栈的配置项目
place in CCMRAM_region    { readwrite, block CSTACK, block HEAP };

将堆栈配置带ccmram中。

编译后产看map文件可以看到你的变量或堆栈都到了ccm中了
回复

使用道具 举报

2

主题

84

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
214
金钱
214
注册时间
2014-12-29
在线时间
36 小时
发表于 2015-6-11 19:54:56 | 显示全部楼层
回复【3楼】hhlh2l:
---------------------------------
补充,也可以类似操作通过FSMC扩展的外部ram
//添加外置RAM到region
define region EXTRAM_region   = mem:[from __ICFEDIT_region_EXTRAM_start__   to __ICFEDIT_region_EXTRAM_end__];
//定义使用标记
place in EXTRAM_region { section .extram          };
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-2-24 18:37

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表