PLC解密网-PLC培训学习-工控自动化人才技术交流

超级管理员

453

帖子

1378

回复

3116

积分

楼主
发表于 2020-10-09 09:40:19 | 查看: 8300 | 回复: 17

Rd,  Rn, Oprand2

BIC(位清除)指令对 Rn 中的值 和 Operand2 值的反码按位进行逻辑“与”运算。 (注意:ARM官方网站有误, 写的是补码)
BIC 是 逻辑”与非” 指令, 实现的 Bit Clear的功能

举例:
BIC     R0,   R0  , #0xF0000000
#将 R0  高4位清零

BIC    R1,  R1,   #0x0F
#将R1   低4位清0
RSB 反向减法
Rn, Operand2
RSB(反向减法)指令可从 Operand2 中的值减去 Rn 中的值。
这是很有用的,因为有了该指令,Operand2 的选项范围就会更大。

例如:
RSB r4, r4, #1280
从1280中减去 R4

RSB R4, R0, #0×46
从0×46 中 减去 R0, 放入R4



超级管理员

453

帖子

1378

回复

3116

积分
11#
发表于 2020-10-09 10:54:02

image.png

超级管理员

453

帖子

1378

回复

3116

积分
12#
发表于 2020-10-09 11:49:29

协处理器cp15操作指令

mcr & mrc


mrc用于读取CP15中的寄存器

mcr用于写入CP15中的寄存器

image.png

超级管理员

453

帖子

1378

回复

3116

积分
13#
发表于 2020-10-09 13:05:08

image.png

超级管理员

453

帖子

1378

回复

3116

积分
14#
发表于 2020-10-09 13:07:09

写入内存

stmia sp, {r0 - r12}

将r0存入sp指向的内存处(假设为0x30001000);

然后地址+4(即指向0x30001004),将r1存入该地址;

然后地址再+4(指向0x30001008),将r2存入该地址······直到r12内容放入(0x3001030),指令完成。

一个访存周期同时完成13个寄存器的读写


超级管理员

453

帖子

1378

回复

3116

积分
15#
发表于 2020-10-09 13:23:03

8种后缀

ia(increase after)先传输,再地址+4

ib(increase before)先地址+4,再传输

da(decrease after)先传输,再地址-4

db(decrease before)先地址-4,再传输

fd(full decrease)满递减堆栈

ed(empty decrease)空递减堆栈

fa(·······) 满递增堆栈

ea(·······)空递增堆栈

四种栈

空栈:栈指针指向空位,每次存入时可以直接存入然后栈指针移动一格;而取出时需要先移动一格才能取出

满栈:栈指针指向栈中最后一格数据,每次存入时需要先移动栈指针一格再存入;取出时可以直接取出,然后再移动栈指针

增栈:栈指针移动时向地址增加的方向移动的栈

减栈:栈指针移动时向地址减小的方向移动的栈

!的作用

ldmia r0, {r2 - r3}

ldmia r0!, {r2 - r3}

感叹号的作用就是r0的值在ldm过程中发生的增加或者减少最后写回到r0去,也就是说ldm时会改变r0的值。

^的作用

ldmfd sp!, {r0 - r6, pc}

ldmfd sp!, {r0 - r6, pc}^

^的作用:在目标寄存器中有pc时,会同时将spsr写入到cpsr,一般用于从异常模式返回

什么时候要执行spsr写入到cpsr:异常返回 比如中断返回时

超级管理员

453

帖子

1378

回复

3116

积分
16#
发表于 2020-10-09 13:33:30

伪指令的意义

伪指令不是指令,伪指令和指令的根本区别是经过编译后会不会生成机器码。

伪指令的意义在于指导编译过程。

伪指令是和具体的编译器相关的,我们使用gnu工具链,因此学习gnu环境下的汇编伪指令。

gnu汇编中的一些符号

@ 用来做注释。可以在行首也可以在代码后面同一行直接跟,和C语言中//类似

# 做注释,一般放在行首,表示这一行都是注释而不是代码。

:以冒号结尾的是标号

.  点号在gnu汇编中表示当前指令的地址

image.png

# 立即数前面要加#或$,表示这是个立即数


超级管理员

453

帖子

1378

回复

3116

积分
17#
发表于 2020-10-09 14:16:56

image.png

常用gnu伪指令

.global _start @ 给_start外部链接属性

.section .text @ 指定当前段为代码段

.ascii .byte .short .long .word 

.quad .float .string @ 定义数据

image.png

.align 4 @ 以16字节对齐

image.png

.balignl 16 0xabcdefgh @ 16字节对齐填充

image.png


image.png

偶尔会用到的gnu伪指令

.end @标识文件结束

.include @ 头文件包含

.arm / .code32 @声明以下为arm指令

.thumb / .code16 @声明以下为thubm指令

最重要的几个伪指令

ldr 大范围的地址加载指令

adr 小范围的地址加载指令

adrl 中等范围的地址加载指令

nop 空操作


ARM中有一个ldr指令,还有一个ldr伪指令

一般都使用ldr伪指令而不用ldr指令

image.png

image.png

adr与ldr

adr编译时会被1条sub或add指令替代,而ldr编译时会被一条mov指令替代或者文字池方式处理;

adr总是以PC为基准来表示地址,因此指令本身和运行地址有关,可以用来检测程序当前的运行地址在哪里

ldr加载的地址和链接时给定的地址有关,由链接脚本决定。

image.png

您需要登录后才可以回帖 登录 | 立即注册

技术支持 KZYPLC V2.1 © 2020-2027

欢迎光临昆山中宇工控PLC论坛!您是第 10334316 位访问者, 日访问量: 23690 总访问量: 22666845,当前 2024-11-24 00:00:08 在线人数:49

ICP备案证书号: 苏ICP备14003016-2号