第一课 逆向分析基础知识
1.1 调用约定
在分析汇编代码时总是要遇到无数的Call,对于这些Call,尽量要根据Call之前传递的参数和Call的返回值来判断Call的功能。传递参数的工 作必须由函数调用者和函数本身来协调,计算机提供了一种被称为栈的数据结构来支持参数传递。
当参数个数多于一个时,按照什么顺序把参数压入堆栈。函数调用后,由谁来把堆栈恢复。在高级语言中,通过函数调用约定来说明这两个问题。常见的调用约定 有:
【例】按__stdcall约定调用函数test2(Par1, Par2)
push par2 ; 参数2
push par1 ; 参数1
call test2;
{
push ebp ; 保护现场原先的EBP指针
mov ebp, esp ; 设置新的EBP指针,指向栈顶
mov eax, [ebp+0C] ; 调用参数2
mov ebx, [ebp+08] ; 调用参数1
sub esp, 8 ; 若函数要用局部变量,则要在堆栈中留出点空间
…
add esp, 8 ; 释放局部变量占用的堆栈
【看雪】第一课 逆向分析基础知识
最新推荐文章于 2025-03-21 22:02:35 发布
本文介绍了逆向分析的基础知识,包括调用约定如stdcall,局部变量的堆栈使用,函数返回值的处理方式,以及启动函数和API函数在Win32程序中的作用。通过示例分析了汇编代码,揭示了函数参数传递、局部变量存储和返回值的实现细节。


1861

被折叠的 条评论
为什么被折叠?



