前文:创建一个LLVM新后端的第一步中文档与代码的差异 主要是为新后端实现了一个Target Machine,这是新建后端七个步骤的第一步。在这个步骤之后,还有一个隐含的内容,那就是将这个Target注册,好让其它的LLVM工具可以在运行时使用你新建的target。
LLVM的官方文档中,以Sparc为例,做了举例:
和
实际上,代码变动已经很大了。目前的Target的注册的代码,已经不在原来的地方了,甚至连include/llvm/Target/TargetRegistry.h都已经不存在了。本文以RISCV的最新代码为例子,展示Target注册的代码:
llvm/lib/Target/RISCV/TargetInfo/RISCVTargetInfo.cpp
extern "C" void LLVMInitializeRISCVTargetInfo() {
RegisterTarget<Triple::riscv32> X(getTheRISCV32Target(), "riscv32",
"32-bit RISC-V", "RISCV");
RegisterTarget<Triple::riscv64> Y(getTheRISCV64Target(), "riscv64",
"64-bit RISC-V", "RISCV");
}
llvm/lib/Target/RISCV/RISCVAsmPrinter.cpp
// Force static initialization.
extern "C" void LLVMInitializeRISCVAsmPrinter() {
RegisterAsmPrinter<RISCVAsmPrinter> X(getTheRISCV32Target());
RegisterAsmPrinter<RISCVAsmPrinter> Y(getTheRISCV64Target());
}
可以看到,目前的代码结构已经和文档差异很大。指出这一点,也是希望能让后续接触这块的少走一些弯路。
参考文档:http://releases.llvm.org/8.0.0/docs/WritingAnLLVMBackend.html
参考代码:llvm/llvm-project Latest commitf58ef87
相关内容:
小乖他爹:LLVM每日谈之三十七 LLVM后端简介(杭州分享PPT)
小乖他爹:LLVM每日谈之五十 LLVM 后端文档解析3 —目标描述类
小乖他爹:LLVM每日谈之五十一 TargetMachine
小乖他爹:LLVM每日谈之五十二 创建一个LLVM新后端的第一步中文档与代码的差异
发布于 2019-06-02