您的位置: OpenADSP社区论坛 -> SHARC/TigerSHARC专区 -> 技术讨论区 -> LDF文件中的WIDTH如何确定?
本帖共有1001个阅读者
发表帖子 发表投票 回复主题
LDF文件中的WIDTH如何确定?
zchong(论坛新手)
zchong
头衔:社区公民
帮派:无帮无派
帖数:19
金钱:350
积分:26
注册时间:2012/7/8
楼主信息 | 留言 | Email | 主页 | 编辑 | 管理 | 离线
LDF文件中的WIDTH如何确定?

最近了解了一下LDF文件,基本明白了是怎么一回事,但有一处细节一直没搞清楚,如下:


sdram、sram和flash看上去比较好理解,和外部连接的数据总线一致,如下

// ------------------------- SDRAM (DDR2) ------------------------------------
  // 0x0020 0000 to 0x021F FFFF  Short word (16) Space (124MB RAM)

  seg_ext_swco  { TYPE(SW RAM) START(0x00600000) END(0x0065FFFD) WIDTH(16) }
  seg_ext_nwco  { TYPE(PM RAM) START(0x00220000) END(0x005FFFFF) WIDTH(16) }
  seg_ext_dmda  { TYPE(DM RAM) START(0x00900000) END(0x01DFFFFD) WIDTH(16) }
  seg_ext_pmda  { TYPE(DM RAM) START(0x01E00000) END(0x032FFFFD) WIDTH(16) }

  seg_sram  { TYPE(DM RAM) START(0x0C000000) LENGTH(0x00100000) WIDTH(16) }
  seg_flash { TYPE(DM RAM) START(0x08000000) END(0x083FFFFF) WIDTH(8) }

内部的不是很明白了,如下:

seg_rth { TYPE(PM RAM) START(0x0008c000) END(0x0008c0ff) WIDTH(48) }
seg_int_code { TYPE(SW RAM) START(0x00124300) END(0x0013BFFF) WIDTH(16) }

具体这个数据宽度WIDTH是由什么决定的呢?

Thanks,
zchong


这家伙很懒,什么也没有留下!
等级:论坛新手 参考IP地址:*.*.*.*
2012/11/28 8:52:47
尊贵身份标志
andy(论坛版主)
andy
头衔:社区公民
帮派:无帮无派
帖数:2287
金钱:11132
积分:2263
注册时间:2011/6/8
1信息 | 留言 | Email | 主页 | 编辑 | 管理 | 离线

这个是sharc内核中已经固定死了的,你看数据手册中的SHARC Core Block Diadram ,可以看到PM的数据总线宽度为48位。


这家伙很懒,什么也没有留下!
等级:论坛版主 参考IP地址:*.*.*.*
2012/11/28 9:55:59
zchong(论坛新手)
zchong
头衔:社区公民
帮派:无帮无派
帖数:19
金钱:350
积分:26
注册时间:2012/7/8
2信息 | 留言 | Email | 主页 | 编辑 | 管理 | 离线

有疑问

seg_int_code中按道理也是存放的代码指令,为什么可以设置成16位呢?

Thanks,
zchong


这家伙很懒,什么也没有留下!
等级:论坛新手 参考IP地址:*.*.*.*
2012/11/28 11:22:55
尊贵身份标志
andy(论坛版主)
andy
头衔:社区公民
帮派:无帮无派
帖数:2287
金钱:11132
积分:2263
注册时间:2011/6/8
3信息 | 留言 | Email | 主页 | 编辑 | 管理 | 离线

因为其类型是SW,SW我没有发现内部专门的模块名词,我的理解是 Short word 。


这家伙很懒,什么也没有留下!
等级:论坛版主 参考IP地址:*.*.*.*
2012/11/29 12:15:51
zchong(论坛新手)
zchong
头衔:社区公民
帮派:无帮无派
帖数:19
金钱:350
积分:26
注册时间:2012/7/8
4信息 | 留言 | Email | 主页 | 编辑 | 管理 | 离线

关于LDF这方面的问题找不到太详细的文档,很多要靠自己理解
就拿这个SW来说,很可能是short world,但是seg_int_code明显是存放代码的,为什么TYPE要设置成 SW RAM而不是PM RAM呢?
andy有相关的文档吗?
个人觉得Linker and Utilities Manual 上说的也不够细致,其它就很少有文档提到这块了。


这家伙很懒,什么也没有留下!
等级:论坛新手 参考IP地址:*.*.*.*
2012/11/30 11:00:02
尊贵身份标志
andy(论坛版主)
andy
头衔:社区公民
帮派:无帮无派
帖数:2287
金钱:11132
积分:2263
注册时间:2011/6/8
5信息 | 留言 | Email | 主页 | 编辑 | 管理 | 离线

这家伙很懒,什么也没有留下!
等级:论坛版主 参考IP地址:*.*.*.*
2012/11/30 23:21:57
Powered by OpenADSP Copyright © 2010 www.Openadsp.com. All rights reserved.154101 Call, 1 Queries, Processed in 0.015625 second(s),