这是从注入捆绑项目复制的c文件中的asm函数:
asm void mach_thread_trampoline(void)
{
// Call _pthread_set_self with pthread_t arg already on stack
pop eax
call eax
add esp, 4
// Call cthread_set_self with pthread_t arg already on stack
pop eax
call eax
add esp, 4
// Call function with return address and arguments already on stack
pop eax
jmp eax
}
在 gcc 之后(我在 mac os x lion 10.7.4 上工作):
$gcc -m32 -fasm-blocks -oa ac -g
gdb 目标,观察 gdb 中的 mach_thread_trampoline 内容:
(gdb) x/17i mach_thread_trampoline
0x1f80 <mach_thread_trampoline>: pop %eax
0x1f81 <mach_thread_trampoline+1>: call *%eax
0x1f83 <mach_thread_trampoline+3>: mov %esp,%eax
0x1f85 <mach_thread_trampoline+5>: mov %eax,%esp
0x1f87 <mach_thread_trampoline+7>: add $0x4,%esp
0x1f8a <mach_thread_trampoline+10>: mov %esp,%eax
0x1f8c <mach_thread_trampoline+12>: mov %eax,-0x8(%ebp)
0x1f8f <mach_thread_trampoline+15>: pop %eax
0x1f90 <mach_thread_trampoline+16>: call *%eax
0x1f92 <mach_thread_trampoline+18>: mov %esp,%eax
0x1f94 <mach_thread_trampoline+20>: mov %eax,%esp
0x1f96 <mach_thread_trampoline+22>: add $0x4,%esp
0x1f99 <mach_thread_trampoline+25>: mov %esp,%eax
0x1f9b <mach_thread_trampoline+27>: mov %eax,-0x8(%ebp)
0x1f9e <mach_thread_trampoline+30>: pop %eax
0x1f9f <mach_thread_trampoline+31>: jmp *%eax
0x1fa1 <mach_thread_trampoline+33>: ret
目标为 mach_thread_trampoline 函数添加了一些指令。
是否有任何方法可以保持 asm 功能不变?