arm 汇编

本文介绍了ARM汇编中的位操作指令,如BIC和TST。通过例子解释了如何清除指定位以及如何进行条件判断。TST指令用于测试寄存器与立即数的按位与结果,如果结果为零则执行特定操作,否则跳转到另一代码段。还提到了子指令subs用于更新条件标志位,并展示了存储类指令ldr的用法。
BIC指令
BIC指令的格式为:
BIC{条件}{S}目的寄存器,操作数1,操作数2
BIC指令用于清除操作数1的某些位,并把结果放置到目的寄存器中。操作数1应是一个寄存器,操作数2可以是一个寄存器,被移位的寄存器,或一个立即数。操作数2为32位的掩码,如果在掩码中设置了某一位,则清除这一位。未设置的掩码位保持不变。指令示例:

BICR0,R0,#%1011;该指令清除R0中的位0、1、和3,其余的位保持不变



TST指令
TST指令的格式为:
TST{条件}操作数1,操作数2
TST指令用于把一个寄存器的内容和另一个寄存器的内容或立即数进行按位与运算,并根据运算结果更新CPSR中条件标志位的值。操作数1是要测试的数据,而操作数2是一个位掩码,该指令一般用来检测是否设置了特定的位。指令示例:TSTR1,#%1;用于测试在寄存器R1中是否设置了最低位(%表示二进制数)TSTR1,#0xffe;将寄存器R1的值与立即数0xffe按位与,并根据结果设
置CPSR的标志位


TST R9,#0x00000002


BNE Next


LDR R0,#0x00000000


先进行and运算,如果结果为 零,则设置zero=1(继续下面的LDR指令);


否则,zero=0(跳到Next处执行)。


代码段:

cmp r0, #0

beq 1f ; r0==0那么向前跳转到B处执行

bne 1b ; 否则向后跳转到A处执行



be bne:

cpsr 中z=1表示结果为零, be , equal 成立 。 eq 表示z=1 , ne表示z=0 

teq 

测试是否相等,将两个数进行异或运算。

subs  s代表更新cpsr中的条件标志位 



存储类指令:

ldr r0, [r1], r2 ; 将地址为r1的内存单元数据读取到r0中,然后r1=r1+r2 


参考资料:

http://wenku.baidu.com/link?url=cX0tdQ4uqRS6rhM8KoHY8hugzUXr0r-QK_eVK2JlPU6bjkUInmJ7bsvH98Y11e27klCj1YyK1NxYkzrDjE5XvZh64sIQsYyFxP0qUwL28pu



arm开发中,掌握一些汇编语言知识很有必要,这并非要求用汇编编程,而是借此掌握机器指令的格式、存储方式、执行过程以及寄存器的变化[^1]。 ### 汇编语言基础 - **基本语法**:包含注释、立即数等内容。还需了解程序状态寄存器,其中有条件码标志位和控制位等[^1]。 - **基本指令**: - **指令基本格式**:有汇编指令格式、条件码等。例如mov指令有其特定的机器指令格式[^1]。 - **数据传输指令mov**:存在立即数范围问题及相应解决办法,还有扩展用法[^1]。 - **算术指令**:用于执行算术运算[^1]。 - **逻辑指令**:进行逻辑操作[^1]。 - **比较指令**:用于比较数据[^1]。 - **跳转指令**:包含语句标号的概念,以及b与bl指令的使用[^1]。 - **内存操作指令**:分为单个内存空间(ldr与str)、连续内存空间操作,还有堆栈操作,堆栈操作涉及相关概念及程序示例(第五章第3节)[^1]。 - **软中断指令**:如swi指令,涉及中断处理程序的查找、mrs指令和msr指令的使用,以及中断产生和处理前后的操作[^1]。 - **常用伪操作**:包括符号定义伪操作、数据定义伪操作、控制伪操作以及ARM汇编器支持的伪指令等[^1]。 - **寻址方式**:汇编中有多种寻址方式[^1]。 ### 编程示例 - **ldrb和strb指令程序实例**:有ldrb结合单个内存空间和连续内存空间的示例[^1]。 - **ldm和stm指令示例**:可用于特定的内存操作场景[^1]。 - **swi指令示例**:有基本示例和swi参数用法完整示例程序[^1]。 ### 其他相关 - **与C语言混用**:存在内联汇编和内嵌汇编的情况[^1]。 - **过程调用标准**:如AAPCS/ATPCS,涉及子函数的参数、局部变量和堆栈相关内容[^1]。 ### 伪指令 ARM汇编的伪指令有特定的语法格式和作用,例如: - **ADR**:ADR{cond} register , expr,将基于PC或基于寄存器的地址值读取到寄存器中,用于小范围的地址读取[^3]。 - **ADRL**:ADRL{cond} register, expr,将基于PC或基于寄存器的地址值读取到寄存器中,用于中等范围的地址读取[^3]。 - **LDR**:LDR {cond} register, =[expr | label - expr],将一个32位的立即数或者一个地址值读取到寄存器中,用于大范围的地址读取[^3]。 - **NOP**:在汇编时将被替换成ARM中的空操作[^3]。 ### 代码示例 以下是一个简单的ARM汇编代码示例: ```asm mov r0,#0x1 mov r1,#0x0 mov r2,#0x64 bl Loop Loop: cmp r0,r2 bhi stop add r1,r1,r0 add r0,r0,#0x01 mov pc,lr stop: B stop .end ``` 此代码实现了一定的逻辑运算,通过循环累加等操作来完成特定任务[^4]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值