前两天遇到一个很头疼个问题,就是需要执行一个类似 JIT 的代码,但是一直出现segFault错误。
问题可能存在于:
1.系统cache没有被清空,导致执行的时候读取到了错误的代码。尝试使用以下清空 cpu cahce的方法:
1. __clear_cache(start, end); // gcc buitin
2. __builtin___clear_cache(start, end); // gcc buitin
3. void asm_clearcache(char* begin, char *end)
{
const int syscall = 0xf0002;
__asm __volatile (
"mov r0, %0\n"
"mov r1, %1\n"
"mov r7, %2\n"
"mov r2, #0x0\n"
"svc 0x00000000\n"
:
: "r" (begin), "r" (end), "r" (syscall)
: "r0", "r1", "r7"
);
}
2.系统保存 JIT 代码的内存区没有可执行权限:
我遇到的就是该问题,但是此问题出现得很隐蔽,因为代码被编译成可执行程序,或者编译成linux动态库都不会出现,唯独在xenomai线程中加载的时候会出现segFault。解决方法,弃用 malloc 或 new 或者定义的数组(即 char []),使用下面这个分配内存:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/mman.h>
// Allocates RWX memory of given size and returns a pointer to it. On failure,
// prints out the error and returns NULL.
void* alloc_executable_memory(size_t size) {
void* ptr = mmap(0, size,
PROT_READ | PROT_WRITE | PROT_EXEC,
MAP_PRIVATE | MAP_ANONYMOUS, -1, 0);
if (ptr == (void*)-1) {
perror("mmap");
return NULL;
}
return ptr;
}
see ref link:
http://eli.thegreenplace.net/2013/11/05/how-to-jit-an-introduction