DSP

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

2019-07-13 17:30发布

  快乐虾 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)    欢迎转载,但请保留作者信息 若您对本文有兴趣,可到http://www.bfin-tools.org/bbs/viewthread.php?tid=16&extra=参与讨论!     有一个链接错误: [Error li1021]  The following symbols referenced in processor 'p0' could not be resolved:         '_ebss_b_l1 [__ebss_b_l1]' referenced from 'arch-mm.dlb[blackfin_sram.doj]'         '_sdata_b_l1 [__sdata_b_l1]' referenced from 'arch-mm.dlb[blackfin_sram.doj]' 这里出现的两个符号均在vmlinux.lds.s中定义:      .data_b_l1 L1_DATA_B_START : AT(LOADADDR(.data_l1) + SIZEOF(.data_l1))      {          . = ALIGN(4);          __sdata_b_l1 = .;          LDS_L1_B_DATA          __edata_b_l1 = .;            . = ALIGN(4);          __sbss_b_l1 = .;          LDS_L1_B_BSS            . = ALIGN(4);          __ebss_b_l1 = .;      } 即它们定义了B核的L1中数据区被内核使用的起始位置和结束位置,使用这两个变量的位置在arch/blackfin/mm/blackfin_sram.c文件中: void __init l1_data_sram_init(void) { …………………… #if L1_DATA_B_LENGTH != 0      printk(KERN_INFO "Blackfin DATA_B SRAM: %d KB/n",          L1_DATA_B_LENGTH >> 10);      for (cpu = 0; cpu < NR_CPUS; ++cpu) {          memset(&per_cpu(l1sram, cpu).l1_data_B_sram, 0x00, sizeof(per_cpu(l1sram, cpu).l1_data_B_sram));          per_cpu(l1sram, cpu).l1_data_B_sram[0].paddr = (void *)get_l1_data_b_start_cpu(cpu)+(_ebss_b_l1 - _sdata_b_l1);           per_cpu(l1sram, cpu).l1_data_B_sram[0].size = L1_DATA_B_LENGTH-(_ebss_b_l1 - _sdata_b_l1);          per_cpu(l1sram, cpu).l1_data_B_sram[0].flag = SRAM_SLT_FREE;      } #endif ………………………… } 这段代码将把B核中可用的L1空间的起始位置和结束位置记录下来,供动态分配使用。但由于这段代码将在A核中执行,在vdsp中是不会链接p1里面定义的符号的。为此,先把这里的(_ebss_b_l1 - _sdata_b_l1)设置为0,即让它使用B核所有的L1 data空间。    

1       参考资料

uclinux-2008R1.5-RC3(bf561)VDSP5的移植(60)KBUILD_MODNAME(2009-2-10) uclinux-2008R1.5-RC3(bf561)VDSP5的移植(61)__builtin_constant_p(2009-2-11) uclinux-2008R1.5-RC3(bf561)VDSP5的移植(62)__builtin_return_address(2009-2-11) uclinux-2008R1.5-RC3(bf561)VDSP5的移植(63)_NSIG_WORDS_is_unsupported_size(2009-2-11)