liuwei061 发表于 2021-8-30 16:02:30

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是否有问题?我该如何解决
请各位大神帮帮忙

人造人 发表于 2021-8-30 17:23:55

在 arm 下不是 0xc3 吧?

liuwei061 发表于 2021-8-31 10:50:14

人造人 发表于 2021-8-30 17:23
在 arm 下不是 0xc3 吧?

你好,请问arm下指令有效的是什么那?

人造人 发表于 2021-8-31 11:20:33

bx lr 吧?
没学过 arm 汇编,不了解这个,你看看这个吧
https://blog.csdn.net/u010059939/article/details/106606902/

liuwei061 发表于 2021-8-31 13:26:23

人造人 发表于 2021-8-31 11:20
bx lr 吧?
没学过 arm 汇编,不了解这个,你看看这个吧
https://blog.csdn.net/u010059939/article/deta ...

谢谢大神,我研究一下,我对这个也不懂
页: [1]
查看完整版本: ARM系统下执行程序提示“非法指令 (核心已转储)”