summaryrefslogtreecommitdiffstats
path: root/src/gallium/state_trackers/clover/llvm/codegen/bitcode.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/gallium/state_trackers/clover/llvm/codegen/bitcode.cpp')
-rw-r--r--src/gallium/state_trackers/clover/llvm/codegen/bitcode.cpp25
1 files changed, 24 insertions, 1 deletions
diff --git a/src/gallium/state_trackers/clover/llvm/codegen/bitcode.cpp b/src/gallium/state_trackers/clover/llvm/codegen/bitcode.cpp
index d2baa07..658cce9 100644
--- a/src/gallium/state_trackers/clover/llvm/codegen/bitcode.cpp
+++ b/src/gallium/state_trackers/clover/llvm/codegen/bitcode.cpp
@@ -24,7 +24,11 @@
///
/// \file
/// Trivial codegen back-end that simply passes through the existing LLVM IR
-/// and formats it so it can be consumed by pipe drivers.
+/// and either formats it so it can be consumed by pipe drivers (if
+/// build_module_bitcode() is used) or serializes so it can be deserialized at
+/// a later point and passed to the actual codegen back-end (if
+/// build_module_library() / parse_module_library() is used), potentially
+/// after linking against other bitcode object files.
///
#include "llvm/codegen.hpp"
@@ -74,3 +78,22 @@ clover::llvm::print_module_bitcode(const ::llvm::Module &mod) {
mod.print(os, NULL);
return os.str();
}
+
+module
+clover::llvm::build_module_library(const ::llvm::Module &mod) {
+ module m;
+ const auto code = emit_code(mod);
+ m.secs.emplace_back(0, module::section::text, code.size(), code);
+ return m;
+}
+
+std::unique_ptr<::llvm::Module>
+clover::llvm::parse_module_library(const module &m, ::llvm::LLVMContext &ctx,
+ std::string &r_log) {
+ auto mod = ::llvm::parseBitcodeFile(::llvm::MemoryBufferRef(
+ as_string(m.secs[0].data), " "), ctx);
+ if (!mod)
+ fail(r_log, error(CL_INVALID_PROGRAM), mod.getError().message());
+
+ return std::unique_ptr<::llvm::Module>(std::move(*mod));
+}