我正在尝试编写一个生成x86机器代码的程序,但代码只能在32位winxp上运行。它说“tiny.exe中的0x776315ee处的未处理异常:0xC0000005:访问冲突。”在win7 64bit上,为什么?
#include <stdio.h>
#include <stdlib.h>
#include <memory.h>
int main()
{
char *code = (char *)malloc(1024);
memset(code, 0, 1024);
char opcode = 0xB8;
memcpy(code, &opcode, sizeof(char));
int oprand = 2;
memcpy(code + sizeof(char), &oprand, sizeof(int));
char opret = 0xC3;
memcpy(code + sizeof(char) + sizeof(int), &opret, sizeof(char));
typedef void (* func_t)(void);
func_t func = (func_t)code;
func();
return 0;
}
答案 0 :(得分:2)
保护堆上分配的内存不受DEP的执行。它可能在您的XP机器上被禁用,或者可能是其他内容,但无论原因是什么:您必须使用({至少)VirtualAlloc()
作为{而不是malloc()
来调用PAGE_EXECUTE_READWRITE
。 {1}}动态分配可以执行代码的内存。