<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微處理器的指令集概述四——MOV和LDR的區別

ARM微處理器的指令集概述四——MOV和LDR的區別

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

一 先讓我們看一段匯編代碼

LDR R0,=0x56000010 #R0 is set to be register GPBCON and is used to select pin function for Port B #in,out special function and others MOV R1,#0x00004000 STR R1,[R0] #pin GPB7 is set to be output port
以上三條匯編語(yǔ)句的功能是將數值0x00004000存儲到以0x56000010為地址的存儲單元中。

其反匯編代碼如下

本文引用地址:http://dyxdggzs.com/article/201611/318740.htm
0:   e59f0044        ldr     r0, [pc, #68]   ; 0x4c4:   e3a01901        mov     r1, #16384      ; 0x40008:   e5801000        str     r1, [r0]......4c:   56000010        undefined
可見(jiàn)LDR R0,=0x56000010 被轉換成ldr指令來(lái)執行

二 再看

LDR R0,=0x56000000  MOV R1,#0x00004000STR R1,[R0]  
其反匯編代碼如下

0:   e3a00456        mov     r0, #1442840576 ; 0x560000004:   e3a01901        mov     r1, #16384      ; 0x40008:   e5801000        str     r1, [r0]

這里L(fēng)DR R0,=0x56000000 被轉換成mov r0, #1442840576

也就是說(shuō)LDR偽指令是根據后面的數據值來(lái)決定轉換為ldr指令或MOV指令執行。

那么同樣是給R0賦值,LDR R0,=0x56000010 能否用mov r0, #0x56000010來(lái)代替呢,

三 由此可見(jiàn)MOV和LDR的區別

mov指令后面的立即數是有限制的,這個(gè)立即數必須由一個(gè)8位的二進(jìn)制數經(jīng)過(guò)偶數次右移后得到才合法數據

LDR R0,=0x56000000 被轉換成mov r0, #0x56000000,其中立即數0x56000000是可以由0x56經(jīng)過(guò)循環(huán)右移得到的,而0x56000010無(wú)法通過(guò)一個(gè)8位的二進(jìn)制數經(jīng)過(guò)偶數次右移后得到,所以無(wú)法轉換成mov指令來(lái)實(shí)現。

四 再舉例如下:

mov R0,#0x101mov R0,#0xFF1
以上兩條指令都不正確,因為立即數不合法。

這樣的話(huà)用MOV指令是比較麻煩的,因為有些簡(jiǎn)單的數據比較容易看出來(lái),有些數據即不容易看出來(lái)是否是合法數據。

五 使用ldr偽指令解決這個(gè)問(wèn)題

為了解決這個(gè)問(wèn)題,我們可以用LDR偽指令來(lái)實(shí)現,根據后面的立即數來(lái)決定轉換為ldr指令或MOV指令執行,符合MOV指令的立即數合法性要求就轉換為MOV指令,不符合的話(huà)就轉換為L(cháng)DR加載指令來(lái)實(shí)現。

在Uboot源碼中看到這樣一條指令 MOV r1,#0xFFFFFFFF

有點(diǎn)費解,查看反匯編代碼如下

mvn r1,#0

原來(lái)如此。




關(guān)鍵詞: ARM微處理器指令集MOVLD

評論


技術(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>