diff options
Diffstat (limited to 'src/gallium/state_trackers')
-rw-r--r-- | src/gallium/state_trackers/clover/llvm/codegen.hpp | 7 | ||||
-rw-r--r-- | src/gallium/state_trackers/clover/llvm/codegen/bitcode.cpp | 25 |
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)); +} |