0
点赞
收藏
分享

微信扫一扫

Part3_lesson3---ARM伪指令学习

1、ARM机器码

Part3_lesson3---ARM伪指令学习_数据段

对elf格式的文件进行反汇编可得到相应汇编文件的机器码:

arm-linux-objdump -D -S start.elf

机器码的解析,可以参考文件ARM Architecture Reference Manual的The ARM Instruction Set章节。

2、定义类伪指令

Part3_lesson3---ARM伪指令学习_数据_02

伪指令前面加上"."号是GNU的一个特点!!

.global:标明一个全局的符号。

.data:标明接下来的数据会存放到数据段里面去。即,这是一个数据段。

那么在数据段当中能够定义什么样的数据呢?

.ascii:定义一个字符串类型的数据

.byte:定义一个字节类型的数据

.word:定义一个字的数据。

以上在定义数据的时候一定要有一个标号!!如下:

Part3_lesson3---ARM伪指令学习_伪指令_03

Part3_lesson3---ARM伪指令学习_数据段_04

Part3_lesson3---ARM伪指令学习_数据_05

数据段的起始位置:0x30010084

Part3_lesson3---ARM伪指令学习_数据_06

equ伪指令类似于C语言中的宏定义

Part3_lesson3---ARM伪指令学习_数据段_07

align主要用来控制对齐:

没有使用align的情况:

使用arm-linux-readelf -a start.elf

Part3_lesson3---ARM伪指令学习_伪指令_08

使用align的情况:

Part3_lesson3---ARM伪指令学习_伪指令_09

Part3_lesson3---ARM伪指令学习_伪指令_10

3、操作类伪指令

ldr伪指令与前面的实际的存储器访问指令同名;

Part3_lesson3---ARM伪指令学习_伪指令_11

对于mov指令而言,它能够使用的立即数不能够超过二进制的8位。因为它超出了这个长度所以报错了。

为什么?这个跟mov指令的机器码相关!

那么大于8位的数,用ldr,如

ldr r0,=0x1fff   不过ldr也可以用于小于8位的数。

执行一个反汇编:

Part3_lesson3---ARM伪指令学习_数据_12

Part3_lesson3---ARM伪指令学习_数据段_13

nop指令是一个空操作:

Part3_lesson3---ARM伪指令学习_数据_14

 

举报

相关推荐

0 条评论