|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
我这有一段代码:代码目的是为了实现:编写一个测试程序,申请一个特定内存空间,将其设置为不可执行,然后复制一段代码进入到该内存空间,然后跳转到该内存空间特定地址。
代码如下:
#include <fcntl.h>
#include <sys/mman.h>
#include <string.h>
#include <stdio.h>
void(*entry)();
int main()
{
unsigned char *image = NULL;
image = mmap(NULL, 1024, PROT_WRITE|PROT_READ|PROT_EXEC, MAP_ANONYMOUS | MAP_PRIVATE, -1, 0);
if (image == MAP_FAILED) {
printf("failed to map library ");
return -1;
}
memset(image, 0xc3, 1);
entry=(void (*)())image;
entry();
munmap(image, 1024);
return 0;
}
现在遇到如下问题:此代码在x86平台下可以编译并执行(我将不可执行改为可执行了PROT_EXEC)不报错,但是拿到arm平台下报错“非法指令 (核心已转储)”,非法执行和0xc3是否有问题?我该如何解决
请各位大神帮帮忙 |
|