[PATCH] D22827: [test/gold] Add gold test subdirectory tests needing v1.12 (or higher)
Teresa Johnson via llvm-commits
llvm-commits at lists.llvm.org
Wed Jul 27 06:11:57 PDT 2016
This revision was automatically updated to reflect the committed changes.
Closed by commit rL276860: [test/gold] Add gold test subdirectory tests needing v1.12 (or higher) (authored by tejohnson).
Changed prior to commit:
https://reviews.llvm.org/D22827?vs=65596&id=65717#toc
Repository:
rL LLVM
https://reviews.llvm.org/D22827
Files:
llvm/trunk/test/tools/gold/X86/v1.12/Inputs/thinlto_emit_linked_objects.ll
llvm/trunk/test/tools/gold/X86/v1.12/lit.local.cfg
llvm/trunk/test/tools/gold/X86/v1.12/thinlto_emit_linked_objects.ll
Index: llvm/trunk/test/tools/gold/X86/v1.12/Inputs/thinlto_emit_linked_objects.ll
===================================================================
--- llvm/trunk/test/tools/gold/X86/v1.12/Inputs/thinlto_emit_linked_objects.ll
+++ llvm/trunk/test/tools/gold/X86/v1.12/Inputs/thinlto_emit_linked_objects.ll
@@ -0,0 +1,7 @@
+target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
+target triple = "x86_64-unknown-linux-gnu"
+
+define void @foo() {
+entry:
+ ret void
+}
Index: llvm/trunk/test/tools/gold/X86/v1.12/lit.local.cfg
===================================================================
--- llvm/trunk/test/tools/gold/X86/v1.12/lit.local.cfg
+++ llvm/trunk/test/tools/gold/X86/v1.12/lit.local.cfg
@@ -0,0 +1,26 @@
+import re
+import subprocess
+
+def is_gold_v1_12_linker_available():
+
+ if not config.gold_executable:
+ return False
+ try:
+ ld_cmd = subprocess.Popen([config.gold_executable, '-v'], stdout = subprocess.PIPE)
+ ld_out = ld_cmd.stdout.read().decode()
+ ld_cmd.wait()
+ except:
+ return False
+
+ match = re.search(r'GNU gold \(.*\) (\d+)\.(\d+)', ld_out)
+ if not match:
+ return False
+ major = int(match.group(1))
+ minor = int(match.group(2))
+ if major < 1 or (major == 1 and minor < 12):
+ return False
+
+ return True
+
+if not is_gold_v1_12_linker_available():
+ config.unsupported = True
Index: llvm/trunk/test/tools/gold/X86/v1.12/thinlto_emit_linked_objects.ll
===================================================================
--- llvm/trunk/test/tools/gold/X86/v1.12/thinlto_emit_linked_objects.ll
+++ llvm/trunk/test/tools/gold/X86/v1.12/thinlto_emit_linked_objects.ll
@@ -0,0 +1,30 @@
+; First generate bitcode with a module summary index for each file
+; RUN: opt -module-summary %s -o %t.o
+; RUN: opt -module-summary %p/Inputs/thinlto_emit_linked_objects.ll -o %t2.o
+
+; Next do the ThinLink step, specifying thinlto-index-only so that the gold
+; plugin exits after generating individual indexes. The objects the linker
+; decided to include in the link should be emitted into the file specified
+; after 'thinlto-index-only='. In this version of the test, only %t.o will
+; be included in the link, and not %t2.o since it is within
+; a library (--start-lib/--end-lib pair) and not strongly referenced.
+; Note that the support for detecting this is in gold v1.12.
+; RUN: %gold -plugin %llvmshlibdir/LLVMgold.so \
+; RUN: --plugin-opt=thinlto \
+; RUN: --plugin-opt=thinlto-index-only=%t3 \
+; RUN: -m elf_x86_64 \
+; RUN: -o %t4 \
+; RUN: %t.o \
+; RUN: --start-lib %t2.o --end-lib
+
+; RUN: cat %t3 | FileCheck %s
+; CHECK: thinlto_emit_linked_objects.ll.tmp.o
+; CHECK-NOT: thinlto_emit_linked_objects.ll.tmp2.o
+
+target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
+target triple = "x86_64-unknown-linux-gnu"
+
+define i32 @main() {
+entry:
+ ret i32 0
+}
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D22827.65717.patch
Type: text/x-patch
Size: 2874 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20160727/82be338f/attachment.bin>
More information about the llvm-commits
mailing list