逆向工程核心原理笔记

逆向工程核心原理笔记

1、大端序和小端序

大端序:高地址存地位,低地址存高位 , 代表Unix RISC CPU

小端序:低地址存低位,高地址存高位,代表 Intel x86 CPU

2、IA32 寄存器
  • 通用寄存器 EAX EBX ECX EDX ESP EBP ESI EDI
  • 段寄存器  CS  DS  SS  ES  FS GS
  • 程序状态与控制寄存器 EFLAGS 初级阶段 ZF OF CF
  • 指令指针寄存器 EIP
3、栈

栈是一个高地址向低地址增长的数据结构。

栈帧用EBP定位栈内元素,典型栈帧代码

push ebp
mov ebp,esp
....
mov esp,ebp
pop ebp
retn

修改OD栈的相关设置,可比较直观的看到当前元素相对于(栈底)EBP的位置

image-20230801160516200

image-20230801160535604

涉及到函数调用约定:Cdecl Stdcall fastcall

c 语言 (x86)

cdecl: 参数从右向左,调用者清理堆栈

stdcall:参数从右向左,子程序清理

fastcall: 参数ecx edx (R8 R9(x64)) ,剩下的参数从右向左,子程序清理

C++ 类

x86

thiscall: 参数从右向左,参数确定,this 通过ecx 传递,子程序清理,

​ 参数不定,this在所有参数入栈后压栈,调用者清理

x64

参数确定 参数1、参数2、参数3分别保存在RDX、R8D、R9D中,this指针存放RCX中,参数从右往左,子程序清理

 class A {
   
   
    public:
      int function1(int a, int b);
      int function2(int a, ...);
  }
  int A::function1(int a, int b) {
   
   
     return a + b;
  }
  int A::function2(int a, ...) {
   
   
     va_list ap;
     va_start(ap, a);
     int i;
     int result = 0;
     for (i=
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Hack_zzz

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值