![]() |
|
||||||||||||||
| | 首页 | 新闻 | 文库 | 方案 | 技术 | 独家 | 座谈 | 下载 | 图库 | 开发板 | 仿真器 | 邮购 | VIP会员 | 芯片代购 | 客户评价 | | ||
|
||
|
|||||
| uclinux-2008R1-RC8(bf561)到VDSP5的移植(39):链接重排 | |||||
作者:快乐虾 文章来源:http://blog.csdn.net/lights_joy 点击数: 更新时间:2008-5-22 ![]() |
|||||
|
在以前的实现中,没有手工对SDRAM分段,当内核小时还没有发现问题,但当内核越来越大时,就开始出现问题了。主要表现为vdsp5在链接时,会自动将一些比较小的变量或者代码段塞到空隙的地方,即使在output_section中加上FORCE_CONTIGUITY也没有效果。
比如
___per_cpu_start = .;
INPUT_SECTIONS($LIBRARIES_UCLINUX(.data.percpu))
___per_cpu_end = .;
最后发现.data.percpu里面的这些内容被转移到其它的角落里去了,而__per_cpu_start和__per_cpu_end则完全指向同一个地方,这样必然造成内核运行的失败。
为解决这个问题,直接在LDF文件中手工对SDRAM进行分段:
MEM_SDRAM_TEXT { TYPE(RAM) START(0x00004000) END(0x00013fff) WIDTH(8) }
MEM_SDRAM_RODATA { TYPE(RAM) START(0x00014000) END(0x00023fff) WIDTH(8) }
MEM_SDRAM_DATA { TYPE(RAM) START(0x00034000) END(0x00043fff) WIDTH(8) }
MEM_SDRAM_INIT_TEXT { TYPE(RAM) START(0x00044000) END(0x00053fff) WIDTH(8) }
MEM_SDRAM_INIT_PERCPU { TYPE(RAM) START(0x00054000) END(0x00063fff) WIDTH(8) }
MEM_SDRAM { TYPE(RAM) START(0x00064000) END(0x03ffffff) WIDTH(8) }
再将这些段的代码或者数据放到相应的内存空间去。
当内核增大时,手工调整以上的内存范围。
|
|||||
| 文章录入:admin 责任编辑:admin | |||||
| 【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口】 | |||||
| 最新热点 | 最新推荐 | 相关文章 | ||
| 前置放大器在移动医疗服务系 便携式多通道大容量生理信号 防腐监测仪的设计与应用 基于AD1674的酶标仪的设计 基于C/S模式的JRTPLIB库的测 ffmpeg与jrtplib相结合应用 blackfin模拟摄像头驱动中的 可编程逻辑在数字信号处理系 发现VDSP4.5一个BUG:单步调 VDSP5.0双核工程下sml3中的变 |
| 网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!) |
| | 本站介绍 | 合作联络 | 欢迎投稿 | 广告业务 | 网站地图 | 设为首页 | 加入收藏 | 友情链接 | 网站公告 | 联系我们 | | |||
|