我在运行时生成了以下llvm ir,我希望立即执行该函数
;other declarations/functions
define %gen__struct__81ty_struct.catch_val @gen__fun__115(void**) {
entry:
%1 = getelementptr void*, void** %0, i32 0
%2 = load void*, void** %1, align 8
%3 = bitcast void* %2 to i64*
store i64 1, i64* %3, align 8
%4 = load i64, i64* %3, align 8
%5 = getelementptr void*, void** %0, i32 1
%6 = load void*, void** %5, align 8
%7 = bitcast void* %6 to i64*
store i64 1, i64* %7, align 8
%8 = load i64, i64* %7, align 8
%9 = getelementptr void*, void** %0, i32 2
%10 = load void*, void** %9, align 8
%11 = bitcast void* %10 to i64*
store i64 1, i64* %11, align 8
ret %gen__struct__81ty_struct.catch_val zeroinitializer
}
然后我使用万花筒jit和以下C ++代码来编译和执行上面的函数,但我一直在遇到段错误。
Function* out = 0;
//code that generates the function ...
runFunc fptr = 0;
jit->addModule(std::move(gblDevice->lmod));
fptr = (runFunc)jit->getPointerToFunction(out);
vector<void*> params;
uint64_t a = 0;
uint64_t b = 0;
uint64_t c = 0;
params.push_back(&a);
params.push_back(&b);
params.push_back(&c);
catch_val_pt cval = fptr(¶ms[0]);
我已经尝试了几个小时来弄清楚上面的代码有什么问题,但似乎一切都已经结束了。
getPointerToFunction函数是。
class OrcJIT {
// ...
JITSymbol findSymbol(const std::string Name) {
std::string MangledName;
raw_string_ostream MangledNameStream(MangledName);
Mangler::getNameWithPrefix(MangledNameStream, Name, DL);
return CODLayer.findSymbol(MangledNameStream.str(), true);
}
inline void* getPointerToFunction(Function* F) {
return (void*)findSymbol(F->getName().data()).getAddress();
}
//...
}
答案 0 :(得分:0)
答案最终变得非常简单。
llvm返回值的方式与gcc返回值之间必然存在二元不兼容性。简短的回答是gen__struct__81ty_struct.catch_val
返回值会导致段错误。
简单地放入生成的函数中,您需要通过传递给生成函数的指针将其返回到结构。除了最简单的情况(也就是int)之外,你不能依赖生成函数匹配的返回值。