在线看毛片网站电影-亚洲国产欧美日韩精品一区二区三区,国产欧美乱夫不卡无乱码,国产精品欧美久久久天天影视,精品一区二区三区视频在线观看,亚洲国产精品人成乱码天天看,日韩久久久一区,91精品国产91免费

<menu id="6qfwx"><li id="6qfwx"></li></menu>
    1. <menu id="6qfwx"><dl id="6qfwx"></dl></menu>

      <label id="6qfwx"><ol id="6qfwx"></ol></label><menu id="6qfwx"></menu><object id="6qfwx"><strike id="6qfwx"><noscript id="6qfwx"></noscript></strike></object>
        1. <center id="6qfwx"><dl id="6qfwx"></dl></center>

            新聞中心

            EEPW首頁(yè) > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > ARM微處理器的指令集概述四——MOV和LDR的區(qū)別

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

            作者: 時(shí)間:2016-11-20 來源:網(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
            以上三條匯編語句的功能是將數(shù)值0x00004000存儲(chǔ)到以0x56000010為地址的存儲(chǔ)單元中。

            其反匯編代碼如下

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

            二 再看

            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 被轉(zhuǎn)換成mov r0, #1442840576

            也就是說LDR偽指令是根據(jù)后面的數(shù)據(jù)值來決定轉(zhuǎn)換為ldr指令或MOV指令執(zhí)行。

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

            三 由此可見MOV和LDR的區(qū)別

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

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

            四 再舉例如下:

            mov R0,#0x101mov R0,#0xFF1
            以上兩條指令都不正確,因?yàn)榱⒓磾?shù)不合法。

            這樣的話用MOV指令是比較麻煩的,因?yàn)橛行┖?jiǎn)單的數(shù)據(jù)比較容易看出來,有些數(shù)據(jù)即不容易看出來是否是合法數(shù)據(jù)。

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

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

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

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

            mvn r1,#0

            原來如此。




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

            評(píng)論


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

            關(guān)閉