From e44e8f46a94e30c0d93ca7a351c16531ed4eaa5c Mon Sep 17 00:00:00 2001 From: Fangrui Song Date: Sat, 15 Feb 2020 17:23:18 -0800 Subject: [PATCH] ThinLTOBitcodeWriter: drop dso_local when a GlobalVariable is converted to a declaration If we infer the dso_local flag for -fpic, dso_local should be dropped when we convert a GlobalVariable a declaration. dso_local causes the generation of direct access (e.g. R_X86_64_PC32). Such relocations referencing STB_GLOBAL STV_DEFAULT objects are not allowed in a -shared link. Reviewed By: tejohnson Differential Revision: https://reviews.llvm.org/D74749 --- lib/Transforms/IPO/FunctionImport.cpp | 2 ++ .../X86/not-prevailing-variables.ll | 6 +++-- .../ThinLTOBitcodeWriter/split-dsolocal.ll | 23 +++++++++++++++++++ 3 files changed, 29 insertions(+), 2 deletions(-) create mode 100644 test/Transforms/ThinLTOBitcodeWriter/split-dsolocal.ll diff --git a/lib/Transforms/IPO/FunctionImport.cpp b/lib/Transforms/IPO/FunctionImport.cpp index 55b5c0377f2..792c14d49b7 100644 --- a/lib/Transforms/IPO/FunctionImport.cpp +++ b/lib/Transforms/IPO/FunctionImport.cpp @@ -992,6 +992,8 @@ bool llvm::convertToDeclaration(GlobalValue &GV) { GV.replaceAllUsesWith(NewGV); return false; } + if (!GV.isImplicitDSOLocal()) + GV.setDSOLocal(false); return true; } diff --git a/test/LTO/Resolution/X86/not-prevailing-variables.ll b/test/LTO/Resolution/X86/not-prevailing-variables.ll index e717fcee4bb..bc3e8eed4d4 100644 --- a/test/LTO/Resolution/X86/not-prevailing-variables.ll +++ b/test/LTO/Resolution/X86/not-prevailing-variables.ll @@ -7,12 +7,14 @@ ; var2 is not prevailing and here we check it is not inlined. ; Check 'var2' was not inlined. -; RUN: llvm-objdump -d %t2.o.1 | FileCheck %s +; RUN: llvm-objdump -d -r %t2.o.1 | FileCheck %s ; CHECK: : ; CHECK-NEXT: movl $10, %eax ; CHECK-NEXT: retq ; CHECK: : -; CHECK-NEXT: movl (%rip), %eax +; CHECK-NEXT: movq (%rip), %rax +; CHECK-NEXT: R_X86_64_GOTPCREL var2-0x4 +; CHECK-NEXT: movl (%rax), %eax ; CHECK-NEXT: retq ; Check 'var2' is undefined. diff --git a/test/Transforms/ThinLTOBitcodeWriter/split-dsolocal.ll b/test/Transforms/ThinLTOBitcodeWriter/split-dsolocal.ll new file mode 100644 index 00000000000..78dfba4d87d --- /dev/null +++ b/test/Transforms/ThinLTOBitcodeWriter/split-dsolocal.ll @@ -0,0 +1,23 @@ +; RUN: opt -thinlto-bc -thinlto-split-lto-unit -o %t %s +; RUN: llvm-modextract -b -n 0 -o %t0.bc %t +; RUN: llvm-modextract -b -n 1 -o %t1.bc %t +; RUN: llvm-dis -o - %t0.bc | FileCheck --check-prefix=M0 %s +; RUN: llvm-dis -o - %t1.bc | FileCheck --check-prefix=M1 %s + +; M0: @default = external constant [1 x i8] +; M0: @hidden = external hidden constant [1 x i8] +; M0: @al = external global [1 x i8] + +; M1: @default = dso_local constant [1 x i8] c"0", !type !0 +; M1: @hidden = hidden constant [1 x i8] c"0", !type !0 +; M1: @al = dso_local alias [1 x i8], [1 x i8]* @default +@default = dso_local constant [1 x i8] c"0", !type !0 +@hidden = dso_local hidden constant [1 x i8] c"0", !type !0 + +@al = dso_local alias [1 x i8], [1 x i8]* @default + +define [1 x i8]* @f_default() { ret [1 x i8]* @default } +define [1 x i8]* @f_hidden() { ret [1 x i8]* @hidden } +define [1 x i8]* @f_al() { ret [1 x i8]* @al } + +!0 = !{i32 0, !"typeid"}