summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMatthias Braun <matze@braunis.de>2016-10-03 20:11:24 +0000
committerMatthias Braun <matze@braunis.de>2016-10-03 20:11:24 +0000
commiteccdee91960e28dd305d8daa5fc874a57ded65e9 (patch)
treeebf0b97f756d41003123b983b02790a76aea27da
parentab5478a9c669e3e947140eaef22b68220834e73c (diff)
downloadbcm5719-llvm-eccdee91960e28dd305d8daa5fc874a57ded65e9.tar.gz
bcm5719-llvm-eccdee91960e28dd305d8daa5fc874a57ded65e9.zip
X86: Do not produce GOT relocations on windows
Windows has no GOT relocations the way elf/darwin has. Some people use x86_64-pc-win32-macho to build EFI firmware; Do not produce GOT relocations for this target. Differential Revision: https://reviews.llvm.org/D24627 llvm-svn: 283140
-rw-r--r--llvm/lib/Target/TargetMachine.cpp7
-rw-r--r--llvm/test/CodeGen/X86/x86-64-pic-12.ll27
2 files changed, 32 insertions, 2 deletions
diff --git a/llvm/lib/Target/TargetMachine.cpp b/llvm/lib/Target/TargetMachine.cpp
index 17caed97391..d7b34f84afc 100644
--- a/llvm/lib/Target/TargetMachine.cpp
+++ b/llvm/lib/Target/TargetMachine.cpp
@@ -127,8 +127,11 @@ bool TargetMachine::shouldAssumeDSOLocal(const Module &M,
if (GV && GV->hasDLLImportStorageClass())
return false;
- // Every other GV is local on COFF
- if (TT.isOSBinFormatCOFF())
+ // Every other GV is local on COFF.
+ // Make an exception for windows OS in the triple: Some firmwares builds use
+ // *-win32-macho triples. This (accidentally?) produced windows relocations
+ // without GOT tables in older clang versions; Keep this behaviour.
+ if (TT.isOSBinFormatCOFF() || TT.isOSWindows())
return true;
if (GV && (GV->hasLocalLinkage() || !GV->hasDefaultVisibility()))
diff --git a/llvm/test/CodeGen/X86/x86-64-pic-12.ll b/llvm/test/CodeGen/X86/x86-64-pic-12.ll
new file mode 100644
index 00000000000..fa8b8ac71b9
--- /dev/null
+++ b/llvm/test/CodeGen/X86/x86-64-pic-12.ll
@@ -0,0 +1,27 @@
+; RUN: llc -o - %s -relocation-model=pic | FileCheck %s
+; Check that we do not get GOT relocations with the x86_64-pc-windows-macho
+; triple.
+target triple = "x86_64-pc-windows-macho"
+
+@g = common global i32 0, align 4
+
+declare i32 @extbar()
+
+; CHECK-LABEL: bar:
+; CHECK: callq _extbar
+; CHECK: leaq _extbar(%rip),
+; CHECK-NOT: @GOT
+define i8* @bar() {
+ call i32 @extbar()
+ ret i8* bitcast (i32 ()* @extbar to i8*)
+}
+
+; CHECK-LABEL: foo:
+; CHECK: callq _bar
+; CHECK: movl _g(%rip),
+; CHECK-NOT: @GOT
+define i32 @foo() {
+ call i8* @bar()
+ %gval = load i32, i32* @g, align 4
+ ret i32 %gval
+}
OpenPOWER on IntegriCloud