summaryrefslogtreecommitdiffstats
path: root/src/gallium/state_trackers
diff options
context:
space:
mode:
authorFrancisco Jerez <currojerez@riseup.net>2016-05-17 16:02:56 +0200
committerFrancisco Jerez <currojerez@riseup.net>2016-07-11 20:34:33 -0700
commit1d042adc0a0a47e343ce29c15ac6767c824a8e9c (patch)
treebbaabe23169530d4b4847d1ffcf3b73dddc62754 /src/gallium/state_trackers
parent952d1e6fd68abd13a35748529bdca5c8356eba69 (diff)
clover/llvm: Clean up bitcode codegen.
Reviewed-by: Serge Martin <edb+mesa@sigluy.net> Tested-by: Jan Vesely <jan.vesely@rutgers.edu>
Diffstat (limited to 'src/gallium/state_trackers')
-rw-r--r--src/gallium/state_trackers/clover/llvm/invocation.cpp36
1 files changed, 20 insertions, 16 deletions
diff --git a/src/gallium/state_trackers/clover/llvm/invocation.cpp b/src/gallium/state_trackers/clover/llvm/invocation.cpp
index 21e6e023e27..f0f1b7a5f43 100644
--- a/src/gallium/state_trackers/clover/llvm/invocation.cpp
+++ b/src/gallium/state_trackers/clover/llvm/invocation.cpp
@@ -406,27 +406,31 @@ namespace {
return m;
}
- module
- build_module_llvm(llvm::Module *mod,
- const clang::CompilerInstance &c) {
- llvm::SmallVector<char, 1024> llvm_bitcode;
- llvm::raw_svector_ostream bitcode_ostream(llvm_bitcode);
- llvm::BitstreamWriter writer(llvm_bitcode);
- llvm::WriteBitcodeToFile(mod, bitcode_ostream);
-#if HAVE_LLVM < 0x0308
- bitcode_ostream.flush();
-#endif
-
+ std::map<std::string, unsigned>
+ get_symbol_offsets(const ::llvm::Module &mod) {
std::map<std::string, unsigned> offsets;
unsigned i = 0;
for (const auto &name : map(std::mem_fn(&::llvm::Function::getName),
- get_kernels(*mod)))
+ get_kernels(mod)))
offsets[name] = i++;
- return build_module_common(*mod, { llvm_bitcode.begin(),
- llvm_bitcode.end() },
- offsets, c);
+ return offsets;
+ }
+
+ std::vector<char>
+ emit_code(const ::llvm::Module &mod) {
+ ::llvm::SmallVector<char, 1024> data;
+ ::llvm::raw_svector_ostream os { data };
+ WriteBitcodeToFile(&mod, os);
+ return { os.str().begin(), os.str().end() };
+ }
+
+ module
+ build_module_bitcode(const ::llvm::Module &mod,
+ const clang::CompilerInstance &c) {
+ return build_module_common(mod, emit_code(mod), get_symbol_offsets(mod),
+ c);
}
std::vector<char>
@@ -587,7 +591,7 @@ clover::compile_program_llvm(const std::string &source,
m = module();
break;
case PIPE_SHADER_IR_LLVM:
- m = build_module_llvm(&*mod, *c);
+ m = build_module_bitcode(*mod, *c);
break;
case PIPE_SHADER_IR_NATIVE:
m = build_module_native(&*mod, target, *c, r_log);