aboutsummaryrefslogtreecommitdiff
path: root/src/codegen.cpp
diff options
context:
space:
mode:
authorVexu <git@vexu.eu>2020-08-20 14:19:11 +0300
committerVexu <git@vexu.eu>2020-08-20 17:12:26 +0300
commit717e2a365d9b5103f855668e4765cc154203a2bf (patch)
tree5e391201b3ce57dd28ab995a9c97284a88b5eb0d /src/codegen.cpp
parentd25674a51ec09640b0140a541a156869b3e03f81 (diff)
downloadzig-717e2a365d9b5103f855668e4765cc154203a2bf.tar.gz
zig-717e2a365d9b5103f855668e4765cc154203a2bf.zip
correct llvm linkage conversion
when weakly exporting external declaration we need to pass LLVMExternalWeakLinkage
Diffstat (limited to 'src/codegen.cpp')
-rw-r--r--src/codegen.cpp9
1 files changed, 5 insertions, 4 deletions
diff --git a/src/codegen.cpp b/src/codegen.cpp
index 36ed520069..e2341fe1aa 100644
--- a/src/codegen.cpp
+++ b/src/codegen.cpp
@@ -292,13 +292,14 @@ static void add_uwtable_attr(CodeGen *g, LLVMValueRef fn_val) {
}
}
-static LLVMLinkage to_llvm_linkage(GlobalLinkageId id) {
+static LLVMLinkage to_llvm_linkage(GlobalLinkageId id, bool is_extern) {
switch (id) {
case GlobalLinkageIdInternal:
return LLVMInternalLinkage;
case GlobalLinkageIdStrong:
return LLVMExternalLinkage;
case GlobalLinkageIdWeak:
+ if (is_extern) return LLVMExternalWeakLinkage;
return LLVMWeakODRLinkage;
case GlobalLinkageIdLinkOnce:
return LLVMLinkOnceODRLinkage;
@@ -521,7 +522,7 @@ static LLVMValueRef make_fn_llvm_value(CodeGen *g, ZigFn *fn) {
}
- LLVMSetLinkage(llvm_fn, to_llvm_linkage(linkage));
+ LLVMSetLinkage(llvm_fn, to_llvm_linkage(linkage, fn->body_node == nullptr));
if (linkage == GlobalLinkageIdInternal) {
LLVMSetUnnamedAddr(llvm_fn, true);
@@ -7962,7 +7963,7 @@ static void do_code_gen(CodeGen *g) {
global_value = LLVMAddGlobal(g->module, get_llvm_type(g, var->var_type), symbol_name);
// TODO debug info for the extern variable
- LLVMSetLinkage(global_value, to_llvm_linkage(linkage));
+ LLVMSetLinkage(global_value, to_llvm_linkage(linkage, true));
maybe_import_dll(g, global_value, GlobalLinkageIdStrong);
LLVMSetAlignment(global_value, var->align_bytes);
LLVMSetGlobalConstant(global_value, var->gen_is_const);
@@ -7975,7 +7976,7 @@ static void do_code_gen(CodeGen *g) {
global_value = var->const_value->llvm_global;
if (exported) {
- LLVMSetLinkage(global_value, to_llvm_linkage(linkage));
+ LLVMSetLinkage(global_value, to_llvm_linkage(linkage, false));
maybe_export_dll(g, global_value, GlobalLinkageIdStrong);
}
if (var->section_name) {