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空间。
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)
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮