为什么我的代码只能在windows xp 32bit系统上运行?[代码生成]

时间:2015-02-07 06:33:01

标签: c visual-c++ compiler-construction compiler-optimization

我正在尝试编写一个生成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;
}

1 个答案:

答案 0 :(得分:2)

保护堆上分配的内存不受DEP的执行。它可能在您的XP机器上被禁用,或者可能是其他内容,但无论原因是什么:您必须使用({至少)VirtualAlloc()作为{而不是malloc()来调用PAGE_EXECUTE_READWRITE。 {1}}动态分配可以执行代码的内存。