在函数顶部及其下方添加了更多的程序集以获得更清晰的图像
00427F38 . 50 PUSH EAX
00427F39 . 8975 08 MOV DWORD PTR SS:[EBP+8],ESI
00427F3C . E8 0FFE0200 CALL Test.00457D50
00427F41 . 8B4D 08 MOV ECX,DWORD PTR SS:[EBP+8]
00427F44 . 51 PUSH ECX ; /Arg1
00427F45 . 8D4D E8 LEA ECX,DWORD PTR SS:[EBP-18] ; |
00427F48 . E8 13FE0200 CALL Test.00457D60 ; \Test.00457D60
00427F4D . 8B55 08 MOV EDX,DWORD PTR SS:[EBP+8]
00427F50 . 8D4D E8 LEA ECX,DWORD PTR SS:[EBP-18]
00427F53 . 52 PUSH EDX
IDA Pro制作了此功能声明
void *__userpurge sub_457D60<eax>(void **a1<ecx>, int a2<ebx>, int a3)
这是我尝试过的,不起作用。
int callAddress = (*This is calculated by me 100% correct*)
//void *__userpurge sub_457D60<eax>(void **a1<ecx>, int a2<ebx>, int a3)
__declspec(naked) void stepOneWrapped(int a1, char* a2, int a3)
{
__asm{
push ebp
mov ebp, esp
push a3
mov ebx, [a2]
mov ecx, a1
call [callAddress]
leave
ret
}
}
特别说明:这就像一个dll注入,所以测试程序完全加载了这个程序。
答案 0 :(得分:2)
你需要保留ebx,因为它是一个非易失性寄存器:
__declspec(naked) void stepOneWrapped(int a1, char* a2, int a3)
{
__asm{
push ebp
mov ebp, esp
push ebx
push a3
mov ebx, [a2]
mov ecx, a1
call [callAddress]
pop ebx
leave
ret
}
}
但根据你的IDA转储,你的参数是错误的,所以它应该是这样的(以匹配IDA):
__declspec(naked) void stepOneWrapped(void** a1, int a2, int a3)
{
__asm{
push ebp
mov ebp, esp
push ebx
push a3
mov ebx, a2
mov ecx, a1
call [callAddress]
pop ebx
leave
ret
}
}