【2021.01.09】经典定长指令-修改EIP

0x70 - 0x7F

  1. 条件跳转,后跟一个字节立即数的偏移(有符号),共两个字节。
  2. 如果条件成立,跳转到 当前指令地址 + 当前指令长度 + lb。
  3. 最大值:向前跳7F,向后跳80。
硬编码汇编
0x70JO
0x71JNO
0x72JB/JNAE/JC
0x73JNB/JAE/JNC
0x74JZ/JE
0x75JNZ/JNE
0x76JBE/JNA
0x77JNBE/JA
0x78JS
0x79JNS
0x7AJP/JPE
0x7BJNP/JPO
0x7CJL/JNGE
0x7DJNL/JGF
0x7EJLE/JNG
0x7FJNLE/JG

0x0F 0x80 - 0x0F 0x8F

  1. 条件跳转,后跟四个字节立即数的偏移(有符号),共五个字节。
  2. 如果条件成立,跳转到 当前指令地址 + 当前指令长度 + ld。
  3. 最大值:向前跳7FFFFFFFF,向后跳80000000。
硬编码汇编
0xF0 0x80JO
0xF0 0x81JNO
0xF0 0x82JB/JNAE/JC
0xF0 0x83JNB/JAE/JNC
0xF0 0x84JZ/JE
0xF0 0x85JNZ/JNE
0xF0 0x86JBE/JNA
0xF0 0x87JNBE/JA
0xF0 0x88JS
0xF0 0x89JNS
0xF0 0x8AJP/JPE
0xF0 0x8BJNP/JPO
0xF0 0x8CJL/JNGE
0xF0 0x8DJNL/JGF
0xF0 0x8EJLE/JNG
0xF0 0x8FJNLE/JG

其他指令1

硬编码汇编长度说明
0xE0LOOPNE/LOOPNZ lb (Jb)2字节ECX = ECX - 1;当ZF = 0 && ECX != 0 时跳转到 当前指令地址 + 当前指令长度 + lb。
0xE1LOOPE/LOOPZ lb (Jb)2字节ECX = ECX - 1;当ZF = 1 && ECX != 0 时跳转到 当前指令地址 + 当前指令长度 + lb。
0xE2LOOP lb (Jb)2字节ECX = ECX - 1;当 ECX != 0 时跳转到 当前指令地址 + 当前指令长度 + lb。
0xE3JrCXZ lb (Jb) 在32位中rCX为ECX2字节当 ECX = 0 时跳转到 当前指令地址 + 当前指令长度 + lb。自行控制步长。
0xE8CALL ld (Jd)5字节CALL 指令的下一条地址入栈后,跳转到 当前指令地址 + 当前指令长度 + ld。
0xE9JMP ld (Jd)5字节跳转到 当前指令地址 + 当前指令长度 + ld。

其他指令2

8个顺序固定的段寄存器:ES、CS、SS、DS、FS、GS、LDTR、TR

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值