ARM系统下执行程序提示“非法指令 (核心已转储)”
我这有一段代码:代码目的是为了实现:编写一个测试程序,申请一个特定内存空间,将其设置为不可执行,然后复制一段代码进入到该内存空间,然后跳转到该内存空间特定地址。代码如下:
#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是否有问题?我该如何解决
请各位大神帮帮忙 在 arm 下不是 0xc3 吧?
人造人 发表于 2021-8-30 17:23
在 arm 下不是 0xc3 吧?
你好,请问arm下指令有效的是什么那? bx lr 吧?
没学过 arm 汇编,不了解这个,你看看这个吧
https://blog.csdn.net/u010059939/article/details/106606902/
人造人 发表于 2021-8-31 11:20
bx lr 吧?
没学过 arm 汇编,不了解这个,你看看这个吧
https://blog.csdn.net/u010059939/article/deta ...
谢谢大神,我研究一下,我对这个也不懂
页:
[1]