如何在没有 llvm 生成器工具的情况下生成 LLVM 位码?

How to generating LLVM bitcode without the llvm generator tools?

我已经通读了 llvm Kaleidoscope 教程,但它是关于如何使用他们的工具的。我正在寻找一种方法来编写自己的代码,允许我采用抽象语法树并生成 llvm IR。

不幸的是,我对如何去做有点迷茫。我目前的想法是让我的 AST 的每个节点都填充空白样式字符串生成。然而,这似乎并不优雅,可能有更好的方法来做到这一点。

我阅读了 问题,这个问题与我的相似,但根据我对 llvm IR 的理解,它可能完全偏离,它的行为类似于比传统汇编语言更高级的语言,具有它具有功能和变量(无限寄存器)。所以我认为可能适用不同的技术。

一点都不优雅。一般来说:在这一点上,大多数编译器可能会生成某种形式的 IR 或 VM 指令集,这些指令集可能会根据有据可查的方法进行优化。最后,编译器将 result/outcome 翻译成目标机器代码。

将 LLVM-IR 视为您要生成的内部 IR,并让工具链负责优化和创建机器代码。