LLVM每日谈之五十三 Target Registration的更正

前文:创建一个LLVM新后端的第一步中文档与代码的差异 主要是为新后端实现了一个Target Machine,这是新建后端七个步骤的第一步。在这个步骤之后,还有一个隐含的内容,那就是将这个Target注册,好让其它的LLVM工具可以在运行时使用你新建的target。

LLVM的官方文档中,以Sparc为例,做了举例:

LLVM每日谈之五十三 Target Registration的更正

LLVM每日谈之五十三 Target Registration的更正

 

实际上,代码变动已经很大了。目前的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后端文档解析

小乖他爹:LLVM每日谈之四十八 LLVM后端文档解析1

小乖他爹:LLVM每日谈之四十九 LLVM后端文档解析2

小乖他爹:LLVM每日谈之五十 LLVM 后端文档解析3 —目标描述类

小乖他爹:LLVM每日谈之五十一 TargetMachine

小乖他爹:LLVM每日谈之五十二 创建一个LLVM新后端的第一步中文档与代码的差异

发布于 2019-06-02

上一篇:LLVM每日谈之五十二 创建LLVM后端的第一步校正(target machine)


下一篇:LLVM每日谈之五十四 新建后端的第二步校正(register set)