新聞中心

EEPW首頁(yè) > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > GUN ARM匯編中標(biāo)號(hào)的引用在匯編和C語(yǔ)言中區(qū)別

GUN ARM匯編中標(biāo)號(hào)的引用在匯編和C語(yǔ)言中區(qū)別

作者: 時(shí)間:2016-11-20 來(lái)源:網(wǎng)絡(luò) 收藏
匯編語(yǔ)言中標(biāo)號(hào)表示的是地址,但是C中要取得該標(biāo)號(hào)處的數(shù)據(jù),卻是直接使用該標(biāo)號(hào),不是應(yīng)該對(duì)該地址進(jìn)行取值運(yùn)算(*指針地址)嗎?其實(shí)不是的。

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)號(hào)處,保存了_start的值,也就是說(shuō),_armboot_start是存放_(tái)start的地址,該地址對(duì)應(yīng)的存儲(chǔ)單元內(nèi)容是0xa170 0000*/
/*
* These are defined in the board-specific linker script. 下面的定義與上面應(yīng)該是一個(gè)意思。
*/
.globl _bss_start
_bss_start:
.word __bss_start
===============================================
在C入口函數(shù)start_armboot()中(對(duì)應(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語(yǔ)言中對(duì)匯編標(biāo)號(hào)的引用的區(qū)別,就會(huì)認(rèn)為monitor_flash_len=_bss_start - _armboot_start=0xa1700048 - 0xa1700044 = 4
其實(shí)
monitor_flash_len = _bss_start - _armboot_start = a171b070 - a1700000 = 1b070

===============================================
下邊總結(jié)一下,匯編語(yǔ)言和C語(yǔ)言中對(duì)匯編中的全局標(biāo)號(hà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)號(hào)==地址,對(duì)標(biāo)號(hào)的引用就是對(duì)標(biāo)號(hào)對(duì)應(yīng)的地址操作,如_armboot_start,其值就是a1700044,如果想取得其對(duì)應(yīng)內(nèi)存地址中的數(shù)據(jù),就需要ldr等指令。舉個(gè)不恰當(dāng)?shù)睦樱绻趨R編語(yǔ)言中也可以有類似x-y的操作的話
monitor_flash_len=_bss_start - _armboot_start=0xa1700048 - 0xa1700044 = 4
這是完全正確的。

然而,在C語(yǔ)言中,其結(jié)果卻不是這樣的。在C中,對(duì)匯編中的全局標(biāo)號(hào)的引用,其值不再是地址,而是地址對(duì)應(yīng)內(nèi)存單元中的數(shù)據(jù),所以對(duì)于C語(yǔ)言
monitor_flash_len = _bss_start - _armboot_start = a171b070 - a1700000 = 1b070

在C語(yǔ)言中,對(duì)基本數(shù)據(jù)類型變量的引用,其值就是對(duì)應(yīng)內(nèi)存中的數(shù)據(jù),而對(duì)于復(fù)雜數(shù)據(jù)類型及函數(shù),其標(biāo)識(shí)符名是指向首地址的指針,其值是它們的首地址。
或許可以這樣理解,由于對(duì)于基本數(shù)據(jù)類型來(lái)說(shuō),其地址和對(duì)應(yīng)內(nèi)存單元中的數(shù)據(jù)剛好是一一對(duì)應(yīng)的,對(duì)變量的引用目的也是希望對(duì)內(nèi)存中的數(shù)據(jù)進(jìn)行操作,所以默認(rèn)是取得變量對(duì)應(yīng)內(nèi)存單元中的數(shù)據(jù);而對(duì)于復(fù)雜數(shù)據(jù)類型及函數(shù)來(lái)說(shuō),利用一個(gè)地址取得全部數(shù)據(jù)是不可能的,所以就用標(biāo)明首地址的方式,加上地址的線性連續(xù),便可以通過(guò)首地址取得全部數(shù)據(jù),這是通過(guò)對(duì)指針(地址)的操作來(lái)實(shí)現(xiàn)的。

本文引用地址:http://butianyuan.cn/article/201611/318790.htm


評(píng)論


技術(shù)專區(qū)

關(guān)閉