.align彙編指令的用法
先看以下程式碼:
mov r1,r0mov 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
這段程式碼在編譯時不會出現任何問題,但是實際在執行中並不會按照預定的要求執行;
編譯連結後,通過反彙編如下:
30008000: e1a01000 mov r1, r0
30008004: e3a0000c mov r0, #12
30008008: e59f400c ldr r4, [pc, #12] ; 3000801c <str1>
3000800c: e59f3018 ldr r3, [pc, #24] ; 3000802c <reset+0x6>
30008010: e59f5008 ldr r5, [pc, #8] ; 30008020 <str>
30008014: e59f6014 ldr r6, [pc, #20] ; 30008030 <reset+0xa>
30008018: e59f7000 ldr r7, [pc, #0] ; 30008020 <str>
3000801c <str1>:
3000801c: 00001e61 .word 0x00001e61
30008020 <str>:
30008020: 33f80000 .word 0x33f80000
30008024: 7788 .short 0x7788
30008026 <reset>:
30008026: e3a08000 mov r8, #0
3000802a: 0000 .short 0x0000
3000802c: 3000801c .word 0x3000801c
30008030: 30008020 .word 0x30008020
通過反彙編我們可以看出,前面所有的指令都是4的倍數,而在reset這個地址處的指令卻不是4的倍數,我們知道ARM是32位處理器,如果在ARM指令狀態下,所有指令的執行都是按照4的倍數進行執行的,而到reset這個地址處時,發現地址為30008026不是4的倍數,於是就自動歸到30008024處執行,當然會出錯了。
在指令出現非對齊情況下,可以在下面插入.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
通過編譯後反彙編如下:
30008000: e1a01000 mov r1, r0
30008004: e3a0000c mov r0, #12
30008008: e59f400c ldr r4, [pc, #12] ; 3000801c <str1>
3000800c: e59f3018 ldr r3, [pc, #24] ; 3000802c <reset+0x4>
30008010: e59f5008 ldr r5, [pc, #8] ; 30008020 <str>
30008014: e59f6014 ldr r6, [pc, #20] ; 30008030 <reset+0x8>
30008018: e59f7000 ldr r7, [pc, #0] ; 30008020 <str>
3000801c <str1>:
3000801c: 00001e61 .word 0x00001e61
30008020 <str>:
30008020: 33f80000 .word 0x33f80000
30008024: 7788 .short 0x7788
...
30008028 <reset>:
30008028: e3a08000 mov r8, #0
3000802c: 3000801c .word 0x3000801c
30008030: 30008020 .word 0x30008020
加上.align彙編語句後,指令就對齊!
.align $