Part3_lesson3---ARM伪指令学习
2024-10-09 来源:cnblogs
1、ARM机器码
对elf格式的文件进行反汇编可得到相应汇编文件的机器码:
arm-linux-objdump -D -S start.elf
机器码的解析,可以参考文件ARM Architecture Reference Manual的The ARM Instruction Set章节。
2、定义类伪指令
伪指令前面加上'.'号是GNU的一个特点!!
.global:标明一个全局的符号。
.data:标明接下来的数据会存放到数据段里面去。即,这是一个数据段。
那么在数据段当中能够定义什么样的数据呢?
.ascii:定义一个字符串类型的数据
.byte:定义一个字节类型的数据
.word:定义一个字的数据。
以上在定义数据的时候一定要有一个标号!!如下:
数据段的起始位置:0x30010084
equ伪指令类似于C语言中的宏定义
align主要用来控制对齐:
没有使用align的情况:
使用arm-linux-readelf -a start.elf
使用align的情况:
3、操作类伪指令
ldr伪指令与前面的实际的存储器访问指令同名;
对于mov指令而言,它能够使用的立即数不能够超过二进制的8位。因为它超出了这个长度所以报错了。
为什么?这个跟mov指令的机器码相关!
那么大于8位的数,用ldr,如
ldr r0,=0x1fff 不过ldr也可以用于小于8位的数。
执行一个反汇编:
nop指令是一个空操作:
相关文章
- arm处理器中a5 a8 a9,v6 v7,arm7 arm9 arm11都是依据什么来分类的
- ARM处理器架构
- Linux Kernel之flush_cache_all在ARM平台下是如何实现的
- Arm 引领软件定义汽车革新, 共同迈向汽车行业未来
- arm召开2025二季度财报会,V9架构继续大获成功
- ARM、Intel、MIPS处理器啥区别?看完全懂了
- makefile初步制作,arm-linux- (gcc/ld/objcopy/objdump)详解
- ubuntu下使用qemu模拟ARM(六)------驱动程序
- Ubuntu下安装arm-linux-gnueabi-xxx编译器
- 用Qemu运行/调试arm linux