uclinux-2008R1.5-RC3(bf561)到VDSP5的移植(20):bf53x_relocate_l1_mem

 

快乐虾

http://blog.csdn.net/lights_joy/

lights@hb165.com

 

本文适用于

ADI bf561 DSP

优视BF561EVB开发板

uclinux-2008r1.5-rc3(smp patch)

Visual DSP++ 5.0(update 5)

 

欢迎转载,但请保留作者信息

 

 

uclinux初始化的时候有一段代码:

       /* Put The Code for PLL Programming and SDRAM Programming in L1 ISRAM */

       call _bf53x_relocate_l1_mem;

bf53x_relocate_l1_mem这个函数的实现在arch/blackfin/kernel/setup.c中,其作用是将设置SDRAMPLL的代码从SDRAM或者Flash复制到L1中,如下所示:

 

void __init bf53x_relocate_l1_mem(void)

{

     unsigned long l1_code_length;

     unsigned long l1_data_a_length;

     unsigned long l1_data_b_length;

 

     l1_code_length = _etext_l1 - _stext_l1;

     if (l1_code_length > L1_CODE_LENGTH)

         l1_code_length = L1_CODE_LENGTH;

     /* cannot complain as printk is not available as yet.

      * But we can continue booting and complain later!

      */

 

     /* Copy _stext_l1 to _etext_l1 to L1 instruction SRAM */

     dma_memcpy(_stext_l1, _l1_lma_start, l1_code_length);

 

     l1_data_a_length = _ebss_l1 - _sdata_l1;

     if (l1_data_a_length > L1_DATA_A_LENGTH)

         l1_data_a_length = L1_DATA_A_LENGTH;

 

     /* Copy _sdata_l1 to _ebss_l1 to L1 data bank A SRAM */

     dma_memcpy(_sdata_l1, _l1_lma_start + l1_code_length, l1_data_a_length);

 

     l1_data_b_length = _ebss_b_l1 - _sdata_b_l1;

     if (l1_data_b_length > L1_DATA_B_LENGTH)

         l1_data_b_length = L1_DATA_B_LENGTH;

 

     /* Copy _sdata_b_l1 to _ebss_b_l1 to L1 data bank B SRAM */

     dma_memcpy(_sdata_b_l1, _l1_lma_start + l1_code_length +

              l1_data_a_length, l1_data_b_length);

 

}

 

但是由于在VDSP下使用方式1进行启动,且在LDF文件中直接将设置PLL这部分代码放在了L1中,因此并不需要再复制一次,所以直接注释掉这行语句,即不调用bf53x_relocate_l1_mem这个函数,自然也不需要这个函数的实现。

 

1       参考资料

uclinux-2008R1.5-RC3(bf561)到VDSP5的移植(1):前言(2009-1-12)

uclinux-2008R1.5-RC3(bf561)到VDSP5的移植(2):代码注释(2009-1-12)

uclinux-2008R1.5-RC3(bf561)到VDSP5的移植(3):vdsp项目创建(2009-1-12)

uclinux-2008R1.5-RC3(bf561)到VDSP5的移植(4):目录差异(2009-1-12)

uclinux-2008R1.5-RC3(bf561)到VDSP5的移植(5):'bf561.h'的问题(2009-1-12)

uclinux-2008R1.5-RC3(bf561)到VDSP5的移植(6)CONFIG_BFIN_KERNEL_CLOCK(2009-1-12)

uclinux-2008R1.5-RC3(bf561)到VDSP5的移植(7)CONFIG_MEM_MT48LC16M16A2TG_75(2009-1-12)

uclinux-2008R1.5-RC3(bf561)到VDSP5的移植(8):CONFIG_CLKIN_HZ(2009-1-12)

uclinux-2008R1.5-RC3(bf561)到VDSP5的移植(9):CONFIG_MEM_SIZE(2009-1-12)

uclinux-2008R1.5-RC3(bf561)到VDSP5的移植(10):CONFIG_FLASH_SPEED_BTT(2009-1-13)

uclinux-2008R1.5-RC3(bf561)到VDSP5的移植(11):__INIT(2009-1-13)

uclinux-2008R1.5-RC3(bf561)到VDSP5的移植(12):trace_buffer_init(2009-1-13)

uclinux-2008R1.5-RC3(bf561)到VDSP5的移植(13):ENDPROC(2009-1-13)

uclinux-2008R1.5-RC3(bf561)VDSP5的移植(14)__FINIT(2009-1-13)

uclinux-2008R1.5-RC3(bf561)VDSP5的移植(15)CONFIG_BANK_x(2009-1-13)

uclinux-2008R1.5-RC3(bf561)VDSP5的移植(16):使用head.s做为入口点(2009-1-13)

uclinux-2008R1.5-RC3(bf561)VDSP5的移植(17)__bss_start(2009-1-13)

uclinux-2008R1.5-RC3(bf561)VDSP5的移植(18)_sdata(2009-1-14)

uclinux-2008R1.5-RC3(bf561)VDSP5的移植(19)_stext(2009-1-14)

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

嵌云阁主

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值