char* pStub , 在执行 pFunc 函数时 , 无条件跳转到 pStub 函数中 ;
要修改 pFunc 函数 , 要先设置该函数所在的内存页的访问 属性 , 否则如果用户没有相关内存访问权限...架构下的插桩拦截
----
插桩拦截 时 , 在 实际函数 入口处写入的 跳转代码 就是 汇编中的 跳转指令 ;
跳转指令 可以理解为 " 指令 " 或 " 机器码 " , 指令是人看到的 汇编指令..., 机器码是给 CPU 执行的 二进制机器码 ; 二者是等效的 ;
x86 架构下的跳转指令 : 下面的二进制数都是十六进制数 ;
32
位指令 ;
E9 00 00 00 00 , JMP target...[] = { 0xE9,0,0,0,0 };
然后 , 计算 pStub 函数跳转地址 , 目标函数 pStub 地址 - 当前函数 pFunc 地址 - 5 , x86 架构中 , 跳转指令 跳转的是...偏移量 , 不是绝对地址值 ;
/* 计算 pStub 函数跳转地址 , 目标函数 pStub 地址 - 当前函数 pFunc 地址 - 5
* 跳转指令 跳转的是 偏移量 , 不是绝对地址值