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

快乐虾

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

[email protected]

本文适用于

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)

你可能感兴趣的:(PHP,.net,Blog,bbs)