STM32
直播中

骨灰级发烧友

12年用户 673经验值
私信 关注
[问答]

什么是汇编指令?常用的汇编语句有哪些

指令和伪指令的本质区别是什么?
什么是汇编指令?常用的汇编语句有哪些?

回帖(1)

孙婷婷

2021-11-29 09:13:36
一些常见的概念:

指令和伪指令:


  指令和伪指令的本质区别:指令在编译后会生成机器码由CPU去执行,而伪指令只是指导编译的过程,本身不会生成机器码。伪指令是编译器提供的,在编译的过程中,编译器自己会去对伪指令做相应的处理。
什么是汇编指令:


  汇编指令是CPU机器指令的助记符,经过编译后会得到一串10组成的机器码,可以由CPU读取执行,不同的平台汇编指令是不同的。
合法立即数和非法立即数


  ARM指令都是32位,除了指令标记和操作标记外,本身只能附带很少位数的立即数。因此立即数有合法和非法之分。
合法立即数:经过任意位数的移位后非零部分可以用8位表示的即为合法立即数
协处理器:


  SOC内部另一处理核心,协助主CPU实现某些功能,被主CPU调用执行一定任务。ARM设计上支持多达16个协处理器,但是一般SoC只实现其中的CP15.(cp:coprocessor)协处理器和MMUcache、TLB等处理有关,功能上和操作系统的虚拟地址映射、cache管理等有关。
指令后缀:


  同一指令经常附带不同后缀,变成不同的指令。经常使用的后缀有:
B(byte)功能不变,操作长度变为8位
H(half word)功能不变,长度变为16位
S(signed)功能不变,操作数变为有符号
如 ldr ldrb ldrh ldr*** ldrsh
S(S标志)功能不变,影响CPSR标志位
如 mov和movs movs r0, #0
条件后缀:


  条件后缀就是在指令后添加下面的后缀,指令只有在满足某些条件下才会执行,相当于C语言里的if语句。比如bleq flag:eq是相等的条件后缀,只有上一句的执行结果是相等,才会执行bleq flag,其他后缀类似。





常用的汇编语句:

说明:

因为汇编指令条数较多,每一句都去分析太耗时而且没有必要,大部分汇编语句都不常用也不会经常写汇编代码,这里只是对汇编语句进行分类和简单介绍,需要用到时再去查询具体用法。
数据处理指令:


  数据传输指令 mov mvn
算术指令 add sub r*** adc ***c rsc
逻辑指令 and orr eor bic
比较指令 cmp cmn tst teq
乘法指令 mvl mla umull umlal smull smlal
前导零计数 clz
CPSR(程序状态寄存器)访问指令:


  mrs & msr
mrs用来读psr,msr用来写psr
CPSR寄存器比较特殊,需要专门的指令访问,这就是mrs和msr。
跳转指令:


  b & bl & bx
b 直接跳转(就没打开算返回)
bl (branch and link),跳转前把返回地址放入lr中,以便返回,用于函数调用
bx跳转同时切换到ARM模式,一般用于异常处理的跳转。
访存指令和软中断指令:


  1.ldr/str & ldm/stm & swp
单个字/半字/字节访问 ldr/str
多字批量访问 ldm/stm
2.swi(software interrupt)
软中断指令用来实现操作系统中系统调用
协处理器cp15的操作指令:


  1.mcr & mrc
mrc用于读取CP15中的寄存器
mcr用于写入CP15中的寄存器
2.mrc和mcr的用法:
mcr{} p15, , , , , {}
opcode_1:对于cp15永远为0
Rd:ARM的普通寄存器
Crn:cp15的寄存器,合法值是c0~c15
Crm:cp15的寄存器,一般均设为c0
opcode_2:一般省略或为0
!的作用


  感叹号的作用就是r0的值在ldm过程中发生的增加或者减少最后写回到r0去,也就是说ldm时会改变r0的值。
ldmia r0!, {r2 - r3}
ldmia r0, {r2 - r3}
上面两个语句的区别:没有!的语句,执行完后r0寄存器里的值没有改变;有!的那句,执行完后r0寄存器里的值+8。
^的作用:


  ^的作用:在目标寄存器中有pc时,会同时将spsr写入到cpsr,一般用于从异常模式返回。
ldmfd sp!, {r0 - r6, pc}
ldmfd sp!, {r0 - r6, pc}^
举报

更多回帖

发帖
×
20
完善资料,
赚取积分