LLVM IR,简单的程序给出了段错误

时间:2017-10-24 16:08:57

标签: c++ llvm llvm-ir

我在运行时生成了以下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(&params[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();
}
//...
}

1 个答案:

答案 0 :(得分:0)

答案最终变得非常简单。

llvm返回值的方式与gcc返回值之间必然存在二元不兼容性。简短的回答是gen__struct__81ty_struct.catch_val返回值会导致段错误。

简单地放入生成的函数中,您需要通过传递给生成函数的指针将其返回到结构。除了最简单的情况(也就是int)之外,你不能依赖生成函数匹配的返回值。