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

          新聞中心

          EEPW首頁(yè) > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > ARM匯編指令:.align理解和用法

          ARM匯編指令:.align理解和用法

          作者: 時(shí)間:2016-11-21 來(lái)源:網(wǎng)絡(luò) 收藏

          對(duì)齊偽指令A(yù)LIGN
          對(duì)齊偽指令格式:

          ALIGN Num

          其中:Num必須是2的冪,如:2、4、8和16等。

          偽指令的作用是:告訴匯編程序,本偽指令下面的內(nèi)存變量必須從下一個(gè)能被Num整除的地址開(kāi)始分配。

          如果下一個(gè)地址正好能被Num整除,那么,該偽指令不起作用,否則,匯編程序?qū)⒖粘鋈舾蓚€(gè)字節(jié),直到下一個(gè)地址能被Num整除為止。

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

          先看以下代碼:

          mov r1,r0
          mov r0,#12
          ldr r4,str1
          ldr r3, =str1

          ldr r5,str
          ldr r6,=str
          ldr r7,str

          str1:
          .word 7777
          str:
          .word 0x33f80000
          .byte 0x88
          .byte 0x77
          reset:

          mov r8,#0

          這段代碼在編譯時(shí)不會(huì)出現(xiàn)任何問(wèn)題,但是實(shí)際在執(zhí)行中并不會(huì)按照預(yù)定的要求執(zhí)行;

          編譯鏈接后,通過(guò)反匯編如下:

          30008000: e1a01000 mov r1, r0
          30008004: e3a0000c mov r0, #12
          30008008: e59f400c ldr r4, [pc, #12] ; 3000801c
          3000800c: e59f3018 ldr r3, [pc, #24] ; 3000802c
          30008010: e59f5008 ldr r5, [pc, #8] ; 30008020
          30008014: e59f6014 ldr r6, [pc, #20] ; 30008030
          30008018: e59f7000 ldr r7, [pc, #0] ; 30008020

          3000801c :
          3000801c: 00001e61 .word 0x00001e61

          30008020 :
          30008020: 33f80000 .word 0x33f80000
          30008024: 7788 .short 0x7788

          30008026 :
          30008026: e3a08000 mov r8, #0
          3000802a: 0000 .short 0x0000
          3000802c: 3000801c .word 0x3000801c
          30008030: 30008020 .word 0x30008020

          通過(guò)反匯編我們可以看出,前面所有的指令都是4的倍數(shù),而在reset這個(gè)地址處的指令卻不是4的倍數(shù),我們知道ARM是32位處理器,如果在ARM指令狀態(tài)下,所有指令的執(zhí)行都是按照4的倍數(shù)進(jìn)行執(zhí)行的,而到reset這個(gè)地址處時(shí),發(fā)現(xiàn)地址為30008026不是4的倍數(shù),于是就自動(dòng)歸到30008024處執(zhí)行,當(dāng)然會(huì)出錯(cuò)了。

          在指令出現(xiàn)非對(duì)齊情況下,可以在下面插入.align偽指令,如下:

          mov r1,r0
          mov r0,#12
          ldr r4,str1
          ldr r3, =str1

          ldr r5,str
          ldr r6,=str
          ldr r7,str

          str1:
          .word 7777
          str:
          .word 0x33f80000
          .byte 0x88
          .byte 0x77
          .align
          reset:
          mov r8,#0

          通過(guò)編譯后反匯編如下:

          30008000: e1a01000 mov r1, r0
          30008004: e3a0000c mov r0, #12
          30008008: e59f400c ldr r4, [pc, #12] ; 3000801c
          3000800c: e59f3018 ldr r3, [pc, #24] ; 3000802c
          30008010: e59f5008 ldr r5, [pc, #8] ; 30008020
          30008014: e59f6014 ldr r6, [pc, #20] ; 30008030
          30008018: e59f7000 ldr r7, [pc, #0] ; 30008020

          3000801c :
          3000801c: 00001e61 .word 0x00001e61

          30008020 :
          30008020: 33f80000 .word 0x33f80000
          30008024: 7788 .short 0x7788
          ...

          30008028 :
          30008028: e3a08000 mov r8, #0
          3000802c: 3000801c .word 0x3000801c
          30008030: 30008020 .word 0x30008020

          加上.align匯編語(yǔ)句后,指令就對(duì)齊!

          .align $



          關(guān)鍵詞: ARM匯編指令alig

          評(píng)論


          技術(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); })();