AT&T汇编

指令后缀

AT&T格式的汇编指令有不同的后缀

其中

b表示byte,字节

w表示word,字/两字节

l表示long,32位系统下的long是4字节

q表示quad,意味四重,表示4个字/8字节

寄存器用途

参见
AT&T的汇编世界 - Gemfield的文章 - 知乎

特殊寻址方式

指针寄存器rsp可以用-8(%rsp)这种方式来寻址,rax等寄存器则不能

想寻址的偏移量保存在寄存器里:

(%rsp, %rax) # 偏移rax寄存器里保存的值

%rsp, %rax, 2) # 取rsp偏移rax2处的值,上行实际上是缺省了1
2(%rsp, %rax, 2) # 取rsp偏移rax
2+2处的值

如下图所示

通过gdb调试查看,符合

命令行参数

在bash中执行命令时,参数的数量保存在(%rsp)寄存器处;

第0个参数的地址(可执行文件名)保存在8(%rsp)处

第1个参数的地址保存在16(%rsp)处

... ...

后面是环境变量

GDB汇编调试简介

layout asm 显示汇编源码
si 单步执行汇编指令,会进入函数
ni 单行执行汇编指令,不会进入函数
i r (info regirester) 查看寄存器的值
p 打印变量的值

p $rax # 打印rax寄存器的数据

p *0xaaaa # 打印0xaaaa处的数据,以十进制整数形式

p (char*)0xaaaa # 以字符串形式

x 打印地址内的数据

x $rsp # 打印rsp寄存器指向地址内保存的数据

x/[数量][格式][宽度]

数量:打印多少字节

格式:t二进制/o八进制/d十进制/x十六进制/c字符/f浮点

宽度:b字节/h两字节/w四字节/g八字节

例:x/20xg $rsp,打印rsp到rsp+20处的指向地址内保存的数据

语法杂记

div

div指令不接受一个立即数作为参数

div执行前被除数的高位放在rdx、低位放在rax,执行后的商放在rax、余数放在rdx,因此要连续运算,需要把高位rdx清零或是重新赋值

lea

lea指令的源操作数不能是数据寄存器,因此如果想把一个常量的地址加载到某处

movq $1234, %rax

leaq %rax, %rdi

上述做法是错误的

一般需要用栈空间中转,用法如下

movq $1234, -8(%rsp)

leaq -8(%rsp), %di

(使用栈空间需要先分配

相关推荐
九思十安1 天前
HNU2026-计算机系统-笔记 5 汇编进阶
汇编·笔记
九思十安1 天前
HNU2026-计算机系统-笔记 4 汇编初步
汇编·笔记
这猪好帅2 天前
协程原理与实现
汇编
Byron Loong5 天前
【逆向】AT Hook 与 Inline Hook 对比
c语言·汇编·c++
iCxhust7 天前
微机原理课程设计大综合---计数器
汇编·单片机·嵌入式硬件·课程设计·微机原理
xxjj998a8 天前
PHP与汇编:从Web到硬件的编程差异
开发语言·汇编·php
陈eaten9 天前
汇编使用AES指令集实现AES解密
汇编·python·aes解密·aes指令集
顾鉴行思9 天前
10 字符串常量到底存在哪里?
c语言·汇编·经验分享
iCxhust9 天前
在 emu8086 中可以直接编译运行的完整汇编程序,演示数组的定义、遍历、求和、求最大值。
开发语言·前端·javascript·汇编·单片机·嵌入式硬件·算法
浩浩测试一下9 天前
堆栈中的 参数与局部变量 (逆向分析)
汇编·逆向·免杀·堆栈·windows编程·pe壳