3

在我的应用程序中,我有 2 个 LLVM 模块 - 运行时模块(包含void foo(int * a)函数定义)和可执行模块(我正在使用 LLVM C++ API 创建)。

在我的可执行模块中,我创建int main(int argc, char ** argv)并想要放入llvm::CallInst它的主体,它将foo()从运行时模块调用函数。

这是我的代码:

Function * fooF = Function::Create(runtimeModule->getFunction("foo")->getFunctionType(),
    GlobalValue::WeakAnyLinkage, "foo", execModule);

之后,我将两个模块链接在一起:

Linker linker("blabla", execModule, false);
linker.LinkInFile("/path/to/runtime.bc", false);
execModule = linker.releaseModule();

这可以编译,但是当我在链接模块上运行验证程序传递时,我得到:

Global is external, but doesn't have external or dllimport or weak linkage!
void (%i32*)* @foo
invalid linkage type for function declaration
void (%i32*)* @foo

值得一提的是,运行时模块中的所有全局变量都是使用 Internalize pass 内部化的。链接后,但在运行验证程序之前,我正在运行 Dead Global Elimination pass 以及其他一些优化。当我dump()对生成的模块执行操作时,我看到,@foo来自运行时模块的内容也会被删除,尽管它被main(). 看来,LLVM 认为@foo运行时中的定义和@foo可执行文件中的声明是不相关的。

我尝试过使用链接类型 - 没有运气。

那么,从另一个模块创建对函数的调用的正确方法是什么?

4

1 回答 1

0

好的,我已经修复了它,但我仍然无法理解问题所在。在构建我的运行时位码模块期间,我一直在对其进行内部化转换。因此,我尝试在链接后在运行时执行此操作,这对我有所帮助。

啊,我一直在用GlobalValue::WeakAnyLinkage

于 2012-02-02T09:31:26.307 回答