4

我主要将 LLVM C++ API 用作脚本语言的代码生成器,该脚本语言在运行时被解析和评估(生成代码、编译和执行它)。目前,我正在研究分布式/并发系统上下文中的未来用例,并想知道是否以及如何实现这些用例。也许你可以分享你的想法:

  1. 有没有办法在分布式系统的一个节点上生成 LLVM 代码,将其序列化为某种有线格式,将其发送到另一个节点,在那里编译或重新编译,然后执行它?我已经坚持寻找序列化模块/函数的方法。
  2. 有没有办法在同一个 LLVMContext 中启用多线程代码生成/编译,即线程池共享一个 LLVMContext 并同时在此上下文中生成/执行代码。到目前为止,我发现在这种情况下,每个线程都应该有一个 LLVMContext。但是,我可以在不同的上下文之间共享一个模块并与 1) 相关,我如何将生成的代码从一个模块移动到另一个模块?
4

1 回答 1

2

您绝对可以使用 LLVM 位码格式将代码从一个节点转发到另一个节点。有关更多信息,请参阅 include/llvm/Bitcode/ReaderWriter.h 等。您还可以查看 LLVM 工具的来源,以了解位码是如何序列化和反序列化的。您可能会发现http://llvm.org/docs/BitCodeFormat.html很有用。

于 2012-07-31T11:14:02.583 回答