ARM 汇编常用指令

本文介绍了ARM汇编语言的特点,强调了通用寄存器和CPSR寄存器的作用,并详细讲解了包括跳转指令B、BL,数据传输指令MOV、MVN,加载/存储指令LDR、STR,算数指令ADD、SUB、MUL,位操作指令ORR、AND、BIC,比较指令CMP,多寄存器传输指令LDM、STM,条件执行以及寻址方式等基本概念和用法。
摘要由CSDN通过智能技术生成

ARM指令教程

一、ARM汇编程序特点:

        1、 所有运算处理都是发生通用寄存器(一般是R0~R14)的之中.所有存储器空间(如C语言变量的本质就是一个存储器空间上的几个BYTE).的值的处理,都是要传送到通用寄存器来完成.因此代码中大量看到LDR,STR指令来传送值.

        2、 ARM汇编语句中.当前语句很多时候要隐含的使用上一句的执行结果.而且上一句的执行结果,是放在CPSR寄存器里,(比如说进位,为0,为负…      

          CMP R0,R1
          BNE NoMatch

           比如上一句,BNE隐含的使用的上一句CMP执行结果.NE后缀表示使用Z标志位.两句合起来的意思就是,如果R0,R1的值不相等,就跳转到NoMatch处执行.(注意,PC=R15,CPSR=R16)

 


 

     

    ARM伪指令不是必须的,但是一个完整没有伪指令几乎很难写出来.

       1)、比如一个程序至少包含READONLY AREA和ENTRY,否则CPU都无法知道从哪里开始运行。ARM的属于RISC,指令并不多,但是可以带后缀表示扩展出不同用法,这里与X86汇编完全不同风格

       2)、如BNE实际上是B指令的变种,本质还同一类指令.只是多一个对CPSR的Z标志位的判断。

 二、ARM常用指令,伪指令

         ARM常用指令并不太多,因此使用阅读ARM汇编代码,并不太困难.以下是使用频率最高的指令和伪指令,并不是完整的指令集的教材。详细指令参见参考资料。

         B,BL
         MOV,MVN
         LDR,STR
         ADD,SUB,ADC,SBC,MUL
         AND,ORR,XOR,TST,BIC
         CMP
         LDM/STM
         nop


1、跳转指令B,BL

      程序流程的跳转,在 ARM 可以实现程序流程的跳转指有两种方法:

            1)、 使用专门的跳转指令 B;

          2)、直接向程序计数器PC 写入跳转地址值;

                   这是几乎是任何一种CPU必备的机器,PC表示CPU当前执行语句位置,改变PC的值,相当于实现程序跳转,

                   如实现类似C语言的Return 语句,就是用

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值