函数调用汇编

目录

一、核心概念

[二、函数调用过程(以 x86 cdecl 为例)](#二、函数调用过程(以 x86 cdecl 为例))

[三、x86 vs x64 区别](#三、x86 vs x64 区别)

[四、示例分析(C代码 → 汇编)](#四、示例分析(C代码 → 汇编))

五、常见问题


一、核心概念

  1. 调用约定 (Calling Convention)

    • 规定参数传递顺序(如 cdecl 是右到左)、栈清理责任(调用者或被调用者清理)。

    • 常见约定:cdecl(C默认)、stdcall(Win32 API)、fastcall(寄存器传参)。

  2. 栈帧 (Stack Frame)

    • 每个函数调用时在栈上分配的内存块,保存返回地址、参数、局部变量等。

    • 通过 EBP(基址指针)和 ESP(栈指针)管理。

  3. 关键寄存器

    • EIP: 指向下一条要执行的指令(不可直接修改)。

    • ESP: 栈顶指针。

    • EBP: 基址指针,标记当前栈帧的起点。

二、函数调用过程(以 x86 cdecl 为例)

  1. 调用者 (Caller) 准备参数
cpp 复制代码
push 3        ; 第三个参数(假设从右向左压栈)
push 2        ; 第二个参数
push 1        ; 第一个参数
call my_func  ; 1. 将返回地址压栈 2. 跳转到 my_func
add esp, 12   ; 调用者清理栈(cdecl 约定)
  1. 被调用函数 (Callee) 建立栈帧
cpp 复制代码
my_func:
    push ebp           ; 保存旧基址指针
    mov ebp, esp       ; 新基址指针指向当前栈顶
    sub esp, 8         ; 分配8字节局部变量空间

此时栈结构:

cpp 复制代码
[ebp+12] 参数3
[ebp+8]  参数2
[ebp+4]  参数1
[ebp]    旧EBP
[ebp-4]  局部变量1
[ebp-8]  局部变量2
  1. 函数执行

通过 EBP 偏移访问参数和局部变量:

cpp 复制代码
mov eax, [ebp+8]   ; 取第一个参数
mov [ebp-4], eax   ; 存入局部变量1
  1. 函数返回
cpp 复制代码
mov eax, 42        ; 返回值存EAX
mov esp, ebp       ; 恢复ESP到栈帧起点
pop ebp            ; 恢复旧EBP
ret                ; 弹出返回地址,跳回调用者

三、x86 vs x64 区别

四、示例分析(C代码 → 汇编)

假设有函数:

cpp 复制代码
int add(int a, int b) {
    return a + b;
}

对应 x86 汇编:

cpp 复制代码
add:
    push ebp
    mov ebp, esp
    mov eax, [ebp+8]    ; 取a
    add eax, [ebp+12]   ; 加b
    mov esp, ebp
    pop ebp
    ret

调用代码:

cpp 复制代码
push 2
push 3
call add
add esp, 8   ; 清理栈
; 结果在EAX中

五、常见问题

  1. 栈溢出:递归过深或局部变量过大导致栈破坏。

  2. 调用约定不匹配 :如误用 stdcall 未清理栈,引发崩溃。

  3. 寄存器保存 :被调用函数需保存 EBX, ESI, EDI(按约定)。

相关推荐
txg6661 天前
编译无关的漏洞检测:基于 Transformer 的 LLVM-IR 与汇编鲁棒建模
汇编·深度学习·安全·transformer
浩浩测试一下2 天前
汇编 16位32位64位通用寄存器(逆向分析)
汇编·windows·stm32·单片机·嵌入式硬件·逆向·二进制
浩浩测试一下2 天前
汇编常用的(JCC 串 判断)指令 通用寄存器 标志寄存器 段寄存器(逆向分析)
汇编·通用寄存器·逆向二进制·标志寄存器·段寄存器·串 jcc 常用指令
浩浩测试一下3 天前
汇编 标志位寄存器 (逆向分析 )
c语言·汇编·逆向·windows编程·标志寄存器
浩浩测试一下3 天前
汇编 数组与串指令(逆向分析)
汇编·逆向·二进制·免杀·串指令·汇编数组
浩浩测试一下3 天前
汇编 内联汇编与混合编程 (逆向分析)
汇编·混合编程·windows编程·内联汇编·二进制逆向·c语言混合汇编
浩浩测试一下3 天前
汇编 结构体与宏
汇编··免杀·结构体·windows编程·逆向二进制
浩浩测试一下4 天前
汇编中的JCC指令 (逆向分析)
汇编·逆向·标志位·jcc指令·跳转指令·标志位寄存器
浩浩测试一下4 天前
汇编中的段与段寄存器(大小)段序 (逆向分析)
汇编·逆向·二进制·字节序·windows编程·内存地址排序
浩浩测试一下5 天前
汇编 call与ret 函数与堆栈 (逆向分析)
汇编·push·函数·pop·call·ret·堆栈逆向