我主要将 LLVM C++ API 用作脚本语言的代码生成器,该脚本语言在运行时被解析和评估(生成代码、编译和执行它)。目前,我正在研究分布式/并发系统上下文中的未来用例,并想知道是否以及如何实现这些用例。也许你可以分享你的想法:
- 有没有办法在分布式系统的一个节点上生成 LLVM 代码,将其序列化为某种有线格式,将其发送到另一个节点,在那里编译或重新编译,然后执行它?我已经坚持寻找序列化模块/函数的方法。
- 有没有办法在同一个 LLVMContext 中启用多线程代码生成/编译,即线程池共享一个 LLVMContext 并同时在此上下文中生成/执行代码。到目前为止,我发现在这种情况下,每个线程都应该有一个 LLVMContext。但是,我可以在不同的上下文之间共享一个模块并与 1) 相关,我如何将生成的代码从一个模块移动到另一个模块?