网站公告列表

  没有公告

加入收藏
设为首页
联系本站
您现在的位置: AnalogCN安诺电子 >> 文章 >> 技术交流 >> 文章正文
  uclinux-2008R1-RC8(bf561)到VDSP5的移植(39):链接重排           ★★★ 【字体:
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条。评论内容只代表网友观点,与本站立场无关!)
    版权所有:AnalogCN安诺电子 湘ICP备06016315号