From: Francisco Jerez Date: Tue, 17 May 2016 14:02:56 +0000 (+0200) Subject: clover/llvm: Clean up bitcode codegen. X-Git-Tag: upstream/17.1.0~8149 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=1d042adc0a0a47e343ce29c15ac6767c824a8e9c;p=platform%2Fupstream%2Fmesa.git clover/llvm: Clean up bitcode codegen. Reviewed-by: Serge Martin Tested-by: Jan Vesely --- diff --git a/src/gallium/state_trackers/clover/llvm/invocation.cpp b/src/gallium/state_trackers/clover/llvm/invocation.cpp index 21e6e02..f0f1b7a 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 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 + get_symbol_offsets(const ::llvm::Module &mod) { std::map 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 + emit_code(const ::llvm::Module &mod) { + ::llvm::SmallVector 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 @@ -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);