LLVM-5.0 Makefile未定义引用失败

时间:2017-05-01 17:04:40

标签: c++ makefile llvm

在我的代码中包含以下语句

main_module->dump(); // main_module is of type llvm::Module*

导致以下链接器错误:

undefined reference to 'llvm::Module::dump() const'

转储方法位于/usr/lib/llvm-5.0/include/llvm/IR/Module.h

我检查了堆栈溢出(Using llvm::Function::dump(), linker gives "undefined reference to `llvm::Value::dump() const'"),当链接器没有以正确的顺序提供库时,我们似乎得到了这个错误。但是,我在编译命令中最终有了库:

clang++-5.0 -g -O3 main.cpp -o main llvm-config-5.0 --cxxflags --ldflags --system-libs --libs core mcjit native

感谢任何帮助。

奇怪的是,链接器想出了dump方法的类型。它明显地包含在包含文件中。那么为什么它会称之为未定义的参考?

我正在尝试运行的代码: `

# include "llvm/IR/LLVMContext.h"
# include "llvm/IR/Module.h"
# include "llvm/IR/IRBuilder.h"
# include <iostream>

using namespace llvm;

static LLVMContext ctxt;
static IRBuilder<> builder(ctxt);

int main(int argc, char** argv) {

    Module* main_module = new Module("main_module", ctxt);
    std::cout << main_module->getModuleIdentifier() << "\n";

    FunctionType* func_type = FunctionType::get(builder.getInt32Ty(), false);
    Function* main_func = Function::Create(func_type,Function::ExternalLinkage, "main", main_module);

    if (main_module->getFunction("main")) {
        std::cout << "Found function!\n";
    }

    main_module->dump();  // need this for debugging and testing reasons with LLVM

    return 0;
}

2 个答案:

答案 0 :(得分:3)

似乎dump的定义位于ASMWriter.cpp,似乎已被删除。 此外,ASMWrite.cpp的调试方法是指dbgs()中的debug.cpp

我通过复制debug.cppModule::dump()(来自ASMWriter.cpp - 因为我不需要整个代码,只需要来自此文件的特定子例程)例程和放置来解决问题它在我的cpp文件中。

答案 1 :(得分:3)

Subrat提供的解决方案外,您还可以调整代码以避免调用dump。你可以通过调用:

来实现同样的目的
main_module->print(llvm::outs(), nullptr);

同样,如果要转储LLVM函数,可以编写:

main_func->print(llvm::outs());

实际上,从LLVM 5.0.0开始,这就是dump()函数的实现方式。