arm中LDR與MOV的區別

2021-07-24 19:20:55 字數 2689 閱讀 1025

mov 是把立即數賦給乙個暫存器,但對立即數的範圍有要求。只能是由8bit連續有效位通過偶數次移位能得到的數。如果立即數超出這個範圍,就沒辦法用一條mov指令給暫存器賦值。

ldr除了普通的讀數之外,也有給暫存器賦立即數的功能。

你只要寫 ldr r0,=0xabcdef

它沒有立即數範圍的限制。因為這是一條偽指令。如果立即數在mov的要求內,那就用一條彙編來實現。如果不在mov的範圍內,就用其它方式實現,如變成兩條指令,或從pc偏移位址讀乙個32位數給暫存器。

mov是從乙個暫存器或者移位的暫存器或者立即數的值傳遞到另外乙個暫存器

從本質上是暫存器到暫存器的傳遞,為什麼會有立即數,其實也是有限制的立即數,不是所有立即數都可以傳遞的

這個立即數要符合乙個8位數迴圈右移偶數字的取值

原因是,mov本身就是一條32bit指令,除了指令碼本身,它不可能再帶乙個可以表示32bit的數字,所以用了其中的12bit來表示立即數,其中4bit表示移位的位數(迴圈右移,且數值x2),8bit用來表示要移位的乙個基數。

還有一點是關於ldr的,其實ldr可以裝載乙個32bit立即數的說法並不確切,因為實際上並不是這一條語句裝載了乙個32bit立即數,比如

ldr r1, =0x12345678

其實真正的彙編**是將某個位址的值傳遞給r1,就是說需要乙個位址存放0x12345678這個立即數,實際上可以看作是一條偽指令

而且如果這個立即數可以用mov指令的形式來表達,會被編譯器實際用mov來代替

比如:ldr r1,=0x10

會變成mov r1,#0x10

arm是risc結構,資料從記憶體到cpu之間的移動只能通過l/s指令來完成,也就是ldr/str指令。想把資料從記憶體中某處讀取到暫存器中,只能使用ldr。比如:

ldr r0, 0x12345678

就是把0x12345678這個位址中的值存放到r0中。

而mov不能幹這個活,mov只能在暫存器之間移動資料,或者把立即數移動到暫存器中,這個和x86這種cisc架構的晶元區別最大的地方。 x86中沒有ldr這種指令,因為x86的mov指令可以將資料從記憶體中移動到暫存器中。

另外還有乙個就是ldr偽指令,雖然ldr偽指令和arm的ldr指令很像,但是作用不太一樣。ldr偽指令可以在立即數前加上=,以表示把乙個位址寫到某暫存器中,比如:

ldr r0, =0x12345678

這樣,就把0x12345678這個位址寫到r0中了。所以,ldr偽指令和mov是比較相似的。只不過mov指令限制了立即數的長度為8位,也就是不能超過512。而ldr偽指令沒有這個限制。如果使用ldr偽指令時,後面跟的立即數沒有超過8位,那麼在實際彙編的時候該ldr偽指令是被轉換為mov指令的。

ldr偽指令和ldr指令不是乙個同東西。

mov 是把立即數賦給乙個暫存器,但對立即數的範圍有要求。只能是由8bit連續有效位通過偶數次移位能得到的數。如果立即數超出這個範圍,就沒辦法用一條mov指令給暫存器賦值。

ldr除了普通的讀數之外,也有給暫存器賦立即數的功能。

你只要寫 ldr r0,=0xabcdef

它沒有立即數範圍的限制。因為這是一條偽指令。如果立即數在mov的要求內,那就用一條彙編來實現。如果不在mov的範圍內,就用其它方式實現,如變成兩條指令,或從pc偏移位址讀乙個32位數給暫存器。

mov是從乙個暫存器或者移位的暫存器或者立即數的值傳遞到另外乙個暫存器

從本質上是暫存器到暫存器的傳遞,為什麼會有立即數,其實也是有限制的立即數,不是所有立即數都可以傳遞的

這個立即數要符合乙個8位數迴圈右移偶數字的取值

原因是,mov本身就是一條32bit指令,除了指令碼本身,它不可能再帶乙個可以表示32bit的數字,所以用了其中的12bit來表示立即數,其中4bit表示移位的位數(迴圈右移,且數值x2),8bit用來表示要移位的乙個基數。

還有一點是關於ldr的,其實ldr可以裝載乙個32bit立即數的說法並不確切,因為實際上並不是這一條語句裝載了乙個32bit立即數,比如

ldr r1, =0x12345678

其實真正的彙編**是將某個位址的值傳遞給r1,就是說需要乙個位址存放0x12345678這個立即數,實際上可以看作是一條偽指令

而且如果這個立即數可以用mov指令的形式來表達,會被編譯器實際用mov來代替

比如:ldr r1,=0x10

會變成mov r1,#0x10

arm是risc結構,資料從記憶體到cpu之間的移動只能通過l/s指令來完成,也就是ldr/str指令。想把資料從記憶體中某處讀取到暫存器中,只能使用ldr。比如:

ldr r0, 0x12345678

就是把0x12345678這個位址中的值存放到r0中。

而mov不能幹這個活,mov只能在暫存器之間移動資料,或者把立即數移動到暫存器中,這個和x86這種cisc架構的晶元區別最大的地方。 x86中沒有ldr這種指令,因為x86的mov指令可以將資料從記憶體中移動到暫存器中。

另外還有乙個就是ldr偽指令,雖然ldr偽指令和arm的ldr指令很像,但是作用不太一樣。ldr偽指令可以在立即數前加上=,以表示把乙個位址寫到某暫存器中,比如:

ldr r0, =0x12345678

這樣,就把0x12345678這個位址寫到r0中了。所以,ldr偽指令和mov是比較相似的。只不過mov指令限制了立即數的長度為8位,也就是不能超過512。而ldr偽指令沒有這個限制。如果使用ldr偽指令時,後面跟的立即數沒有超過8位,那麼在實際彙編的時候該ldr偽指令是被轉換為mov指令的。

ldr偽指令和ldr指令不是乙個同東西。

ARM中MOV與LDR的區別

分類 arm 2010 11 24 18 35 850人閱讀收藏 舉報arm是risc結構,資料從記憶體到cpu之間的移動只能通過l s指令來完成,也就是ldr str指令。比如想把資料從記憶體中某處讀取到暫存器中,只能使用ldr 比如 ldr r0,0x12345678 就是把0x12345678...

ARM中MOV與LDR的區別

from arm是risc結構,資料從記憶體到cpu之間的移動只能通過l s指令來完成,也就是ldr str指令。比如想把資料從記憶體中某處讀取到暫存器中,只能使用ldr 比如 ldr r0,0x12345678 就是把0x12345678這個 位址中的值 存放到r0中。而mov不能幹這個活,mov...

arm中ldr與mov指令的區別

arm是risc結構,資料從記憶體到cpu之間的移動只能通過l s指令來完成,也就是ldr str指令。比如想把資料從記憶體中某處讀取到暫存器中,只能使用ldr 比如 ldr r0,0x12345678 就是把0x12345678這個位址中的值存放到r0中。而mov不能幹這個活,mov只能在暫存器之...