我从这里得到了一个示例 llvm 代码。这段代码有一些问题,我也修复了它们。此时,它所做的只是转储翻译后的 IR 代码。我所追求的是从我的代码创建一个可执行文件,而不在我的 bash 中C++
调用llvm-as
// llc
。clang
我怎样才能做到这一点?
我也不想创建任何 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++ 教授创建的结果?