arm汇编—str,mov等指令

STR指令的格式为:
STR{条件}  源寄存器,<存储器地址>
STR指令用亍从源寄存器中将一个32位的字数据传送到存储器中。该指令在程序设计中比较常
用,寻址方式灵活多样,使用方式可参考指令LDR。

指令示例:
STR R0,[R1],#8             ;将R0中的字数据写入以R1为地址的存储器中,并将新地址R1+8写入R1。

STR R0,[R1,#8]             ;将R0中的字数据写入以R1+8为地址的存储器中。”

str     r1, [r0]                       ;将r1寄存器的值,传送到地址值为r0的(存储器)内存中


MOV 指令的基本格式如下:
        movx source, destination
   source 和 destination 的值可以是内存地址,存储在内存中的数据值,指令语句中定义的数据值,或者寄存器。

ldr:
当第二个操作数前面没有“=”时,表示内存访问指令,从内存中读取4Byte数据到寄存器,语法格式如下:
ldr{条件} 目的寄存器, 存储器地址
如果第二个操作数前面有“=”,表示大范围地址读取伪指令,用于加载32位的立即数或一个地址到指定寄存器,语法格式如下:
ldr 目的寄存器, =32位立即数/地址

adrl r2, mem_cfg_val

adrl是中等范围地址读取伪指令,将基于pc相对偏移的地址值或基于寄存器相对偏移的地址值读取到寄存器中,在汇编编译器编译源程序时,adrl伪指令被编译器替换成两条合适的指令。若不能用两条指令实现,则产生错误,编译失败。这条代码会替换为:

30000050: e28f2018  add r2, pc, #24 ; 0x18

30000054: e1a00000  nop (mov r0,r0)

adrl伪指令格式:

adrl{cond}   register, expr

地址表达式expr的取值范围:

当地址值是字节对齐时,其取指范围为: -64K64K

当地址值是字对齐时,其取指范围为: -256K256K

nop

空操作伪指令,在汇编是替换成ARM中的空操作,例如mov r0, r0

cmp

比较指令,格式如下:

cmp{条件操作数1, 操作数2

用与将一个寄存器的内容和另一寄存器的内容或立即数进行比较,然后更新CPSR中条件标志位的值,标志位表示操作数1和操作数2的关系(大于、小于、相等)。

bne 1b

b(跳转指令)+ne(条件:不相等),如果CPSRZ位为0(不相等),就跳转到后面的1标号处。

b表示向后搜索,已经执行过的代码为‘后’;

f表示向前搜索,还未执行的代码为‘前’。

mov  pc, lr

从子程序返回。lr为子程序链接寄存器(r14),当执行bl子程序调用指令时,lr会备份pc(程序计数器r15)。

.align

指定对齐方式,gnu汇编命令都以一个点开头。

.equ

赋值命令,格式如下:

.equ symbol, expression

设置symbol的值为expression

.long

定义一个4Byte的数据。

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: ARM汇编指令有:ADD,SUB,MOV,MVN,CMP,AND,ORR,EOR,MUL,MLA,UMULL,UMLAL,LDR,STR,B,BL,BX,BLX,SWI,RSB,ADC,SBC,RSC,LSL,LSR,ASR,ROR,CLZ,CMN,TEQ,LDA,STM,LDM,SWP,SWPB,PUSH,POP,BKPT,SMLAL,SMULL,QADD,QSUB,QDADD,QDSUB,SMULW,SMLAW,SMLALBB,SMLALBT,SMLALTB,SMLALTT,SMULBB,SMULBT,SMULTB,SMULTT,SMLABB,SMLABT,SMLATB,SMLATT,SMULWB,SMUAWB,SMULWT,SMUAWT,SMLALBB,SMLALBT,SMLALTB,SMLALTT,SMLAWB,SMLAWT,SMLSD,SMLSLD,SMMLA,SMMLS,SMMUL,SMUAD,SMUSD,SMULXY,SMLALXY,SMLSLXY,SMMLAR,SMMLSR,SMMULR,SMUADX,SMUSDX,SMLA,SMLS,SMUL,SMUAD,SMUSD,SMULW,SMLAW,SMULX,SMLALX,SMLSLX,SMMLA,SMMLS,SMMUL,SMUAD,SMUSD,SMULW,SMLAW,SMULX,SMLALX,SMLSLX,SMMLA,SMMLS,SMMUL,SMUAD,SMUSD,SMULW,SMLAW,SMULX,SMLALX,SMLSLX。 ### 回答2: ARM汇编语言是一种低级程序设计语言,用于控制ARM架构处理器的指令集。ARM指令集由多个指令组成,这些指令可以执行各种操作,包括算术运算、逻辑运算、数据传输、分支跳转等。以下是一些常见的ARM汇编指令: 1. 数据处理指令:用于执行算术和逻辑运算,例如加法、减法、与、或等。 2. 数据传输指令:用于读取和存储数据,例如将数据从内存传输到寄存器,或者将数据从寄存器传输到内存。 3. 分支和跳转指令:用于控制程序流程,例如条件分支、无条件分支、函数调用和返回等。 4. 位移和移位指令:用于对数据进行位移和移位操作,例如逻辑左移、逻辑右移、算术右移等。 5. 系统控制指令:用于与操作系统和硬件交互,例如中断处理、特权级别切换等。 6. 协处理器指令:用于执行与协处理器相关的操作,例如浮点运算。 此外,ARM汇编语言还包括一些指令的变种和修饰符来支持更多的功能和操作。不同的ARM处理器可能有略微不同的指令集,因此具体指令的数量和功能可能会有所不同。 总而言之,ARM汇编指令集非常丰富,可以满足各种程序的需求。掌握这些指令可以帮助开发者更好地理解和优化底层程序。 ### 回答3: ARM汇编语言是一种底层的程序设计语言,用于编写与ARM架构处理器直接交互的程序。ARM汇编指令非常多,我将列举一些常见的指令。 1. 数据传送指令:包括LDR(加载数据到寄存器)、STR(将寄存器中的数据存储到指定地址)等。 2. 算术运算指令:例如ADD(加法)、SUB(减法)、MUL(乘法)等。 3. 逻辑运算指令:如AND(与运算)、ORR(或运算)、EOR(异或运算)等。 4. 控制指令:包括B(无条件分支)、BL(带有链接的分支)、CMP(比较指令)、BEQ(相等时分支)等。 5. 中断处理指令:如SWI(软中断)和SVC(超级方法调用)等用于处理中断请求的指令。 6. 位操作指令:例如TST(测试位)、LSL(逻辑左移位)和ASR(算术右移位)等。 7. 存储器访问指令:如LDM(多寄存器加载)和STM(多寄存器存储)等,用于对内存进行批量读写。 8. 条件执行指令:包括IT(条件执行标记)和FNE(不等于时执行)等,用于根据条件灵活地执行指令。 以上只是ARM汇编指令的一小部分示例,实际上ARM汇编指令非常丰富,还有很多其他类型的指令。不同的ARM架构处理器可能会有不同的指令集,因此具体的指令会因处理器型号而异。掌握并熟练使用这些指令,可以编写高效的底层程序。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值