<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數據處理指令

ARM數據處理指令

作者: 時(shí)間:2016-11-21 來(lái)源:網(wǎng)絡(luò ) 收藏
ARM數據處理指令只訪(fǎng)問(wèn)寄存器,是ARM指令集中唯一可以修改數據值的指令。所有的操作數都是32位,結果也是32位,被放到寄存器中。

寄存器傳送指令
移位指令
算術(shù)運算指令
邏輯運算指令
比較指令
乘法指令

1. 掌握寄存器傳送指令、算術(shù)運算指令,并理解標志位S的作用。
實(shí)驗一:
根據提示信息完成程序并運行驗證。(exp5_1_1.s)
AREA lab1,CODE,READONLY
ENTRY
START
MOV R0,#0x3F
MOV R1,#0x2C
MOV R2,#0x10
MOV R3,#0x5
;(1)計算R4=R0+R1
;(2)計算R5=R0-R1并更新標志位
;(3)計算R6=R1-R0并更新標志位
;(4)計算R7=R2+8*R3
STOP
B STOP
END

思考題:
a) 在程序中執行
SUBS R4,R0,R1
SUBS R4,R1,R0
后,程序狀態(tài)寄存器CPSR的標志位各有何變化?為什么?
b) 在程序中執行
SUB R4,R0,R1
SUB R4,R1,R0
后,程序狀態(tài)寄存器CPSR的標志位各有何變化?為什么?


實(shí)驗二:
編寫(xiě)ARM匯編程序。有兩個(gè)128位數,第一個(gè)數0x00000004000000c3000000b2000000a1由高到低存放在寄存器R7~R4中,第二個(gè)數0x00000008000000c7000000b6000000a5由高到低存放在寄存器R11~R8中,實(shí)現第一個(gè)數和第二個(gè)數的相減,運算結果由高到低存放到寄存器R3~R0中。(exp5_1_5.s)

2. 掌握乘法指令
實(shí)驗六:根據提示信息完成程序并運行驗證。(exp5_1_6.s)
AREA lab3,CODE,READONLY
ENTRY
START
MOV R0,#0x3F
MOV R1,#0x3D
MOV R2,#0xFF000000
MOV R3,#0x3FC0

;32位無(wú)符號乘法計算R0*R1,R4存結果
;32位無(wú)符號乘加計算R0*R1+R0,R5存結果
;32 位無(wú)符號乘法計算R2*R3,R6存結果
;64位無(wú)符號乘法計算R2*R3,R7存低32位,R8存高32位
STOP
B STOP
END

思考題:
在上述程序中,執行語(yǔ)句
MUL R6,R2,R3
UMULL R7,R8,R2,R3
SMULL R9,R10,R2,R3
后,解析個(gè)寄存器的值。


3. 掌握比較測試指令,懂得使用ARM指令的條件域來(lái)標注指令執行的條件。
實(shí)驗三:
根據提示信息完成程序并運行驗證。(exp)
AREA lab1,CODE,READONLY
ENTRY
START
MOV R0,#0xFF
;反轉R0的0,1位,其余位保持不變,存到R1中
;保留寄存器R0的0,1位,其余位清零,存到R1中
;比較寄存器R0和R1的值是否相等,并根據結果修改CPSR的標志位
MOV R0,#0xFB
;測試寄存器R0中的第2位是否為1,并根據結果修改CPSR的標志位(若是,跳轉到START)
END

實(shí)驗四:
編寫(xiě)簡(jiǎn)單的匯編語(yǔ)言程序,功能是計算1+2+3+。。。。+n的值,并把累加的結果存儲到寄存器中。 (exp3_1_1)

4. 掌握邏輯運算指令
實(shí)驗五:
將0x3FC0的第4~11位用0xDD替換,變成0x3DD0。根據提示信息完成程序并運行驗證。 (exp)
AREA lab2,CODE,READONLY
ENTRY
START
MOV R1,#0x3FC0
MOV R2,#0xFF0
MOV R3,#0xDD
;清除R1=0x3FC0中對應的位,使其成為0x3000
;通過(guò)移位,將0x3DD0與要替換的位域對齊
;將對應位置寫(xiě)入目的操作數R1
STOP
B STOP
END

思考:
在上述程序中,如果將0x3FC0替換為0xCFC0,應該如何修改程序?


關(guān)鍵詞: ARM數據處理指

評論


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