LLVM每日谈之五十三 Target Registration的更正
Posted snsn1984
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了LLVM每日谈之五十三 Target Registration的更正相关的知识,希望对你有一定的参考价值。
前文:创建一个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
以上是关于LLVM每日谈之五十三 Target Registration的更正的主要内容,如果未能解决你的问题,请参考以下文章
LLVM每日谈之五十六 从RegionPass看Region
LLVM每日谈之五十四 新建后端的第二步校正(register set)
LLVM每日谈之十九 LLVM的第一本系统的书<Getting Started with LLVM Core Libraries>