<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

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

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

          作者: 時間:2016-11-20 來源:網(wǎng)絡(luò) 收藏
          匯編語言中標(biāo)號表示的是地址,但是C中要取得該標(biāo)號處的數(shù)據(jù),卻是直接使用該標(biāo)號,不是應(yīng)該對該地址進(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)號處,保存了_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ū)別,就會認(rèn)為monitor_flash_len=_bss_start - _armboot_start=0xa1700048 - 0xa1700044 = 4
          其實(shí)
          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ù)睦?,如果在匯編語言中也可以有類似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ù)進(jìn)行操作,所以默認(rèn)是取得變量對應(yīng)內(nèi)存單元中的數(shù)據(jù);而對于復(fù)雜數(shù)據(jù)類型及函數(shù)來說,利用一個地址取得全部數(shù)據(jù)是不可能的,所以就用標(biāo)明首地址的方式,加上地址的線性連續(xù),便可以通過首地址取得全部數(shù)據(jù),這是通過對指針(地址)的操作來實(shí)現(xiàn)的。

          本文引用地址:http://www.ex-cimer.com/article/201611/318790.htm


          關(guān)鍵詞: GUNARM匯編標(biāo)號C語

          評論


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

          關(guān)閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();