1

我从这里得到了一个示例 llvm 代码。这段代码有一些问题,我也修复了它们。此时,它所做的只是转储翻译后的 IR 代码。我所追求的是从我的代码创建一个可执行文件,而不在我的 bash 中C++调用llvm-as// llcclang我怎样才能做到这一点?

我也不想创建任何 IR 或字节码中间文件。

#include <llvm/ADT/ArrayRef.h>
#include <llvm/IR/LLVMContext.h>
#include <llvm/IR/Module.h>
#include <llvm/IR/Function.h>
#include <llvm/IR/BasicBlock.h>
#include <llvm/IR/IRBuilder.h>
#include <vector>
#include <string>

int main()
{
    llvm::LLVMContext context;
    llvm::Module *module = new llvm::Module("myModule", context);
    llvm::IRBuilder<> builder(context);

    llvm::FunctionType *funcType = llvm::FunctionType::get(builder.getVoidTy(), false);
    llvm::Function *mainFunc = 
        llvm::Function::Create(funcType, llvm::Function::ExternalLinkage, "main", module);
    llvm::BasicBlock *entry = llvm::BasicBlock::Create(context, "entrypoint", mainFunc);
    builder.SetInsertPoint(entry);

    llvm::Value *helloWorld = builder.CreateGlobalStringPtr("hello world!\n");

    std::vector<llvm::Type *> putsArgs;
    putsArgs.push_back(builder.getInt8Ty()->getPointerTo());
    llvm::ArrayRef<llvm::Type*>  argsRef(putsArgs);

    llvm::FunctionType *putsType = 
        llvm::FunctionType::get(builder.getInt32Ty(), argsRef, false);
    llvm::FunctionCallee putsFunc = module->getOrInsertFunction("puts", putsType);

    builder.CreateCall(putsFunc, helloWorld);
    builder.CreateRetVoid();
    module->print(llvm::errs(), nullptr);
}

一个附带问题:顺便说一句,当我搜索 LLVM 示例时,很多结果都是 IR 示例。如何获得从 C++ 教授创建的结果?

4

0 回答 0