ARM的数据处理指令只拜访寄存器,是ARM指令会集仅有能够修正数据值的指令。一切的操作数都是32位,成果也是32位,被放到寄存器中。
寄存器传送指令
移位指令
算术运算指令
逻辑运算指令
比较指令
乘法指令
1.
试验一:
依据提示信息完结程序并运转验证。(exp5_1_1.s)
AREA lab1,CODE,READONLY
START
STOP
考虑题:
a)
SUBS R4,R0,R1
SUBS R4,R1,R0
后,程序状况寄存器CPSR的标志位各有何改变?为什么?
b)
SUB R4,R0,R1
SUB R4,R1,R0
后,程序状况寄存器CPSR的标志位各有何改变?为什么?
试验二:
编写ARM汇编程序。有两个128位数,榜首个数0x00000004000000c3000000
2.
试验六:依据提示信息完结程序并运转验证。(exp5_1_6.s)
AREA lab3,CODE,READONLY
START
;32位无符号乘加核算R0*R1+R0,R5存成果
;32 位无符号乘法核算R2*R3,R6存成果
;64位无符号乘法核算R2*R3,R7存低32位,R8存高32位
STOP
考虑题:
在上述程序中,履行句子
MUL R6,R2,R3
UMULL R7,R8,R2,R3
SMULL R9,R10,R2,R3
后,解析个寄存器的值。
3.
试验三:
依据提示信息完结程序并运转验证。(exp)
START
;测验寄存器R0中的第2位是否为1,并依据成果修正CPSR的标志位(若是,跳转到START)
试验四:
编写简略的汇编语言程序,功用是核算1+2+3+。。。。+n的值,并把累加的成果存储到寄存器中。 (exp3_1_1)
4.
试验五:
将0x3FC0的第4~11位用0xDD替换,变成0x3DD0。依据提示信息完结程序并运转验证。 (exp)
START
STOP
考虑:
在上述程序中,假如将0x3FC0替换为0xCFC0,应该怎么修正程序?
ARM数据处理指令
ARM的数据处理指令只访问寄存器,是ARM指令集中唯一可以修改数据值的指令。所有的操作数都是32位,结果也是32位,被放到寄存器中。寄存器传…
声明:本文内容来自网络转载或用户投稿,文章版权归原作者和原出处所有。文中观点,不代表本站立场。若有侵权请联系本站删除(kf@86ic.com)https://www.86ic.net/dianyuan/262743.html