summaryrefslogtreecommitdiffstats
path: root/src/gallium/state_trackers/clover/llvm/invocation.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/gallium/state_trackers/clover/llvm/invocation.cpp')
-rw-r--r--src/gallium/state_trackers/clover/llvm/invocation.cpp19
1 files changed, 16 insertions, 3 deletions
diff --git a/src/gallium/state_trackers/clover/llvm/invocation.cpp b/src/gallium/state_trackers/clover/llvm/invocation.cpp
index 3bb7d72..6560b89 100644
--- a/src/gallium/state_trackers/clover/llvm/invocation.cpp
+++ b/src/gallium/state_trackers/clover/llvm/invocation.cpp
@@ -229,6 +229,21 @@ namespace {
pmb.populateModulePassManager(pm);
pm.run(mod);
}
+
+ std::unique_ptr<Module>
+ link(LLVMContext &ctx, const clang::CompilerInstance &c,
+ const std::vector<module> &modules, std::string &r_log) {
+ std::unique_ptr<Module> mod { new Module("link", ctx) };
+ auto linker = compat::create_linker(*mod);
+
+ for (auto &m : modules) {
+ if (compat::link_in_module(*linker,
+ parse_module_library(m, ctx, r_log)))
+ throw compile_error();
+ }
+
+ return std::move(mod);
+ }
}
module
@@ -238,9 +253,7 @@ clover::llvm::link_program(const std::vector<module> &modules,
std::vector<std::string> options = tokenize(opts + " input.cl");
auto ctx = create_context(r_log);
auto c = create_compiler_instance(target, options, r_log);
- // XXX - Implement linkage of multiple clover modules.
- assert(modules.size() == 1);
- auto mod = parse_module_library(modules[0], *ctx, r_log);
+ auto mod = link(*ctx, *c, modules, r_log);
optimize(*mod, c->getCodeGenOpts().OptimizationLevel);