<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>

新聞中心

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

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

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

對齊偽指令ALIGN
對齊偽指令格式:

ALIGN Num

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

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

如果下一個(gè)地址正好能被Num整除,那么,該偽指令不起作用,否則,匯編程序將空出若干個(gè)字節,直到下一個(gè)地址能被Num整除為止。

本文引用地址:http://dyxdggzs.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ì )出現任何問(wèn)題,但是實(shí)際在執行中并不會(huì )按照預定的要求執行;

編譯鏈接后,通過(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的倍數,而在reset這個(gè)地址處的指令卻不是4的倍數,我們知道ARM是32位處理器,如果在A(yíng)RM指令狀態(tài)下,所有指令的執行都是按照4的倍數進(jìn)行執行的,而到reset這個(gè)地址處時(shí),發(fā)現地址為30008026不是4的倍數,于是就自動(dòng)歸到30008024處執行,當然會(huì )出錯了。

在指令出現非對齊情況下,可以在下面插入.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ǔ)句后,指令就對齊!

.align $



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

評論


技術(shù)專(zhuān)區

關(guān)閉
国产精品自在自线亚洲|国产精品无圣光一区二区|国产日产欧洲无码视频|久久久一本精品99久久K精品66|欧美人与动牲交片免费播放
<dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><small id="yhprb"></small><dfn id="yhprb"></dfn><small id="yhprb"><delect id="yhprb"></delect></small><small id="yhprb"></small><small id="yhprb"></small> <delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"></dfn><dfn id="yhprb"></dfn><s id="yhprb"><noframes id="yhprb"><small id="yhprb"><dfn id="yhprb"></dfn></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><small id="yhprb"></small><dfn id="yhprb"><delect id="yhprb"></delect></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn> <small id="yhprb"></small><delect id="yhprb"><strike id="yhprb"></strike></delect><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn><dfn id="yhprb"><s id="yhprb"><strike id="yhprb"></strike></s></dfn><dfn id="yhprb"><s id="yhprb"></s></dfn>