[DSP编程] 2812 DSP外扩ram

[复制链接]
1646|5
 楼主| liangyanqun1004 发表于 2016-7-13 10:40 | 显示全部楼层 |阅读模式
DSP使用的是TMS320F2812   程序中用到了外扩ram和flash,ram使用zone6,flash使用zone2。在读到这两句时,搞不懂了:
Uint16 *ExRam=(Uint16 *)0x3000;
unsigned int *flashstart=(unsigned int *)0x80000;
下面的一句是外扩flash的首地址,上面一句 看着不像外扩ram的首地址啊(zone6首地址是0x100000),
(Uint16 *)0x3000 将0x3000这个数字转化为一个指向uint16数据类型的指针,不明白这句话目的是什么?  
特来求助,小弟不胜感谢
JY-DX-JY 发表于 2016-7-13 16:35 | 显示全部楼层
程序谁写的?
玄德 发表于 2016-7-13 20:21 | 显示全部楼层

也许使用的时候还会加上BaseAdd,
也许这个RAM是其他用途,比如RAM调试、仿真。

评分

参与人数 1威望 +1 收起 理由
liangyanqun1004 + 1 谢谢

查看全部评分

zhangmangui 发表于 2016-7-13 22:36 | 显示全部楼层
恩  楼上说的很对     这个操作一般是基地址+偏移地址
一般基地址是映射区的首地址    然后加上偏移量
重点要看看你的整体代码
 楼主| liangyanqun1004 发表于 2016-7-17 22:56 | 显示全部楼层
zhangmangui 发表于 2016-7-13 22:36
恩  楼上说的很对     这个操作一般是基地址+偏移地址
一般基地址是映射区的首地址    然后加上偏移量
重 ...

我最终搞明白了:由于使用外部RAM读取MAX11046芯片的数据使用的是DSP读取外部数据的片选信号,所以程序上设计时该存储地址必须是DSP系统资源中对应的外部RAM地址范围内,且不能与DSP本身外部RAM扩展范围重合,否则会导致数据采集错乱。这里zone0是满足的。
zhangmangui 发表于 2016-7-18 22:09 | 显示全部楼层
liangyanqun1004 发表于 2016-7-17 22:56
我最终搞明白了:由于使用外部RAM读取MAX11046芯片的数据使用的是DSP读取外部数据的片选信号,所以程序上 ...

感谢分享
您需要登录后才可以回帖 登录 | 注册

本版积分规则

2

主题

3

帖子

0

粉丝
快速回复 在线客服 返回列表 返回顶部