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后端文档解析

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

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

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

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

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

发布于 2019-06-02

以上是关于LLVM每日谈之五十三 Target Registration的更正的主要内容,如果未能解决你的问题,请参考以下文章

LLVM每日谈之五十六 从RegionPass看Region

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

LLVM每日谈之五十五 浅谈对Pass的错误认知及其原因

通信算法之五十三:代码封装

通信算法之五十三:算法英文

LLVM每日谈之十九 LLVM的第一本系统的书&lt;Getting Started with LLVM Core Libraries&gt;