GUN ARM匯編中標(biāo)號的引用在匯編和C語言中區(qū)別
u-boot/cpu/xx/start.S中:
_TEXT_BASE:
.word TEXT_BASE/*uboot映像在SDRAM中的重定位地址,我設(shè)置為0xa170 0000 */
.globl _armboot_start
_armboot_start:
.word _start/*_start是程序入口,鏈接完畢它的值應(yīng)該是0xa170 0000=TEXT_BASE*/
/* 這句話的意思應(yīng)該是在_armboot_start標(biāo)號處,保存了_start的值,也就是說,_armboot_start是存放_start的地址,該地址對應(yīng)的存儲單元內(nèi)容是0xa170 0000*/
/*
* These are defined in the board-specific linker script. 下面的定義與上面應(yīng)該是一個意思。
*/
.globl _bss_start
_bss_start:
.word __bss_start
===============================================
在C入口函數(shù)start_armboot()中(對應(yīng)文件為lib_arm/board.c),有如下代碼:
void start_armboot (void)
{
.........
gd = (gd_t*)(_armboot_start - CFG_MALLOC_LEN - sizeof(gd_t));//第一句話
..........
monitor_flash_len = _bss_start - _armboot_start;//第二句話
...............
mem_malloc_init (_armboot_start - CFG_MALLOC_LEN);//第三句話
..........
}
在這里,如果混淆了在匯編中和C語言中對匯編標(biāo)號的引用的區(qū)別,就會認為monitor_flash_len=_bss_start - _armboot_start=0xa1700048 - 0xa1700044 = 4
其實
monitor_flash_len = _bss_start - _armboot_start = a171b070 - a1700000 = 1b070
===============================================
下邊總結(jié)一下,匯編語言和C語言中對匯編中的全局標(biāo)號的引用的區(qū)別:
1018: a1700048 0 NOTYPE GLOBAL DEFAULT 1 _bss_start
1083: a1700044 0 NOTYPE GLOBAL DEFAULT 1 _armboot_start
1142: a1700000 0 NOTYPE GLOBAL DEFAULT 1 _start
1197: a171b070 0 NOTYPE GLOBAL DEFAULT ABS __bss_start
在匯編中,標(biāo)號==地址,對標(biāo)號的引用就是對標(biāo)號對應(yīng)的地址操作,如_armboot_start,其值就是a1700044,如果想取得其對應(yīng)內(nèi)存地址中的數(shù)據(jù),就需要ldr等指令。舉個不恰當(dāng)?shù)睦樱绻趨R編語言中也可以有類似x-y的操作的話
monitor_flash_len=_bss_start - _armboot_start=0xa1700048 - 0xa1700044 = 4
這是完全正確的。
然而,在C語言中,其結(jié)果卻不是這樣的。在C中,對匯編中的全局標(biāo)號的引用,其值不再是地址,而是地址對應(yīng)內(nèi)存單元中的數(shù)據(jù),所以對于C語言
monitor_flash_len = _bss_start - _armboot_start = a171b070 - a1700000 = 1b070
在C語言中,對基本數(shù)據(jù)類型變量的引用,其值就是對應(yīng)內(nèi)存中的數(shù)據(jù),而對于復(fù)雜數(shù)據(jù)類型及函數(shù),其標(biāo)識符名是指向首地址的指針,其值是它們的首地址。
或許可以這樣理解,由于對于基本數(shù)據(jù)類型來說,其地址和對應(yīng)內(nèi)存單元中的數(shù)據(jù)剛好是一一對應(yīng)的,對變量的引用目的也是希望對內(nèi)存中的數(shù)據(jù)進行操作,所以默認是取得變量對應(yīng)內(nèi)存單元中的數(shù)據(jù);而對于復(fù)雜數(shù)據(jù)類型及函數(shù)來說,利用一個地址取得全部數(shù)據(jù)是不可能的,所以就用標(biāo)明首地址的方式,加上地址的線性連續(xù),便可以通過首地址取得全部數(shù)據(jù),這是通過對指針(地址)的操作來實現(xiàn)的。
評論