summaryrefslogtreecommitdiffstats
path: root/src/gallium/state_trackers
diff options
context:
space:
mode:
Diffstat (limited to 'src/gallium/state_trackers')
-rw-r--r--src/gallium/state_trackers/clover/llvm/codegen.hpp7
-rw-r--r--src/gallium/state_trackers/clover/llvm/codegen/bitcode.cpp25
2 files changed, 31 insertions, 1 deletions
diff --git a/src/gallium/state_trackers/clover/llvm/codegen.hpp b/src/gallium/state_trackers/clover/llvm/codegen.hpp
index c4d4997dfed..e0e990190d2 100644
--- a/src/gallium/state_trackers/clover/llvm/codegen.hpp
+++ b/src/gallium/state_trackers/clover/llvm/codegen.hpp
@@ -46,6 +46,13 @@ namespace clover {
print_module_bitcode(const ::llvm::Module &mod);
module
+ build_module_library(const ::llvm::Module &mod);
+
+ std::unique_ptr<::llvm::Module>
+ parse_module_library(const module &m, ::llvm::LLVMContext &ctx,
+ std::string &r_log);
+
+ module
build_module_native(::llvm::Module &mod, const target &target,
const clang::CompilerInstance &c,
std::string &r_log);
diff --git a/src/gallium/state_trackers/clover/llvm/codegen/bitcode.cpp b/src/gallium/state_trackers/clover/llvm/codegen/bitcode.cpp
index d2baa07fdf9..658cce923c9 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));
+}