网站公告列表

  没有公告

加入收藏
设为首页
联系本站
您现在的位置: AnalogCN安诺电子 >> 文章 >> 技术交流 >> 文章正文
  U-boot-1.1.6-2008R1到vdsp5(bf561)的移植记录(7):改造u-boot.lds.s         ★★★ 【字体:
U-boot-1.1.6-2008R1到vdsp5(bf561)的移植记录(7):改造u-boot.lds.s
作者:快乐虾    文章来源:http://blog.csdn.net/lights_joy    点击数:    更新时间:2008-4-18    
u-boot的链接文件为u-boot-1.1.6-2008R1\board\bf561-ezkit\u-boot.lds.s,在其中定义了各段的布局,而VDSP5则使用u-boot.ldf做为链接文件,下面就是对它的移植。当然,我们可以根据自己的需要随时进行调整,在此只是尽可能与原文件保持一致。
1             包含配置文件
u-boot的配置文件为include\configs\bf561-ezkit.h,为此在u-boot.ldf的第一行加上:
#include <config.h>
其中的config.h放在include目录下,本身是在linux下用make bf561-ezkit时自动生成的,其内容其实很简单,就是包含指定平台的配置文件。
/* Automatically generated - do not edit */
#include <configs/bf561-ezkit.h>
当然,添加后要在project options -> ldf preprocessing中将include的路径添加进来,顺便在预定义一栏加上__ASSEMBLY__的宏定义,因为对ldf文件的处理同样不支持在宏中使用64位整数(参见《#if》一文)。
2             定义内存区
因为在使用向导生成u-boot工程的时候,没有选择对SDRAM进行划分,所以生成的LDF文件中包含的代码就是:
   MEM_SDRAM               { TYPE(RAM) START(0x00000004) END(0x03ffffff) WIDTH(8) }
而u-boot.lds.s的定义是:
     ram     : ORIGIN = CFG_MONITOR_BASE, LENGTH = CFG_MONITOR_LEN
很遗憾不能在LDF中START(CFG_MONITOR_BASE)这样的语句,但从bf561-ezkit.h可以很容易看出,u-boot将其自身放在SDRAM最高的256K中,因此只要直接在START和END中指定这个范围就OK了。
修改后的代码为:
   MEM_SDRAM               { TYPE(RAM) START(0x03fc0000) END(0x03ffffff) WIDTH(8) }
3             添加对u-boot库的定义
因为VDSP5不支持同一工程中有同名的文件,即使文件不在同一个目录下也不行,因此只能为u-boot下每一个子目录生成一个dlb文件。在LDF中为这些dlb文件添加一个定义:
$LIBRARIES_UBOOT =
       ;  
目前什么也没有,只是一个空壳。
4             对原有SDRAM中内容的处理
在VDSP5向导生成的LDF文件中,默认在SDRAM中放了不少的东西,细节此处不表,反正准备在u-boot中使用VDSP的库,就此保留,如果空间不够再开大点,俺反正有64M的SDRAM,呵呵!
5             对.text的转换
在gcc下编译的程序,默认的程序段名称是.text,所以在u-boot.lds.s中的第一个段就是:
     .text :
     {
#ifdef ENV_IS_EMBEDDED
         /* WARNING - the following is hand-optimized to fit within
          * the sector before the environment sector. If it throws
          * an error during compilation remove an object here to get
          * it linked after the configuration sector.
          */
 
         cpu/blackfin/start.o        (.text)
         cpu/blackfin/traps.o        (.text)
         cpu/blackfin/interrupt.o    (.text)
         cpu/blackfin/serial.o       (.text)
         common/dlmalloc.o      (.text)
          lib_generic/crc32.o         (.text)
         lib_generic/zlib.o     (.text)
         board/bf561-ezkit/bf561-ezkit.o      (.text)
 
         . = DEFINED(env_offset) ? env_offset : .;
         common/environment.o   (.text)
#endif
 
         *(.text)
     } >ram
不太明白为什么将这些指定的代码放在前面会达到优化的效果,在此就先暂时抛弃它,改写后如下:
       .text
       {
         INPUT_SECTION_ALIGN(4)
#ifdef ENV_IS_EMBEDDED
              /* WARNING - the following is hand-optimized to fit within
               * the sector before the environment sector. If it throws
               * an error during compilation remove an object here to get
               * it linked after the configuration sector.
               */
 
              cpu/blackfin/start.o        (.text)
              cpu/blackfin/traps.o              (.text)
              cpu/blackfin/interrupt.o (.text)
              cpu/blackfin/serial.o              (.text)
              common/dlmalloc.o              (.text)
              lib_generic/crc32.o        (.text)
              lib_generic/zlib.o           (.text)
              board/bf561-ezkit/bf561-ezkit.o           (.text)
 
              . = DEFINED(env_offset) ? env_offset : .;
              common/environment.o (.text)
#endif
 
              INPUT_SECTIONS($LIBRARIES_UBOOT(program))
       } > MEM_SDRAM
因为没有定义ENV_IS_EMBEDDED,所以中间代码有错误也没有关系,后面再修正。
至于其它段,碰到后到进行添加。
文章录入:admin    责任编辑:admin 
  • 上一篇文章:

  • 下一篇文章:
  • 发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
    最新热点 最新推荐 相关文章
    前置放大器在移动医疗服务系
    便携式多通道大容量生理信号
    防腐监测仪的设计与应用
    基于AD1674的酶标仪的设计
    基于C/S模式的JRTPLIB库的测
    ffmpeg与jrtplib相结合应用
    blackfin模拟摄像头驱动中的
    可编程逻辑在数字信号处理系
    发现VDSP4.5一个BUG:单步调
    VDSP5.0双核工程下sml3中的变
      网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)
    版权所有:AnalogCN安诺电子 湘ICP备06016315号