<div dir="ltr"><div class="gmail_extra"><div class="gmail_quote">On 19 March 2015 at 16:55, Peter Collingbourne <span dir="ltr"><<a href="mailto:peter@pcc.me.uk" target="_blank">peter@pcc.me.uk</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Author: pcc<br>
Date: Thu Mar 19 18:55:38 2015<br>
New Revision: 232785<br>
<br>
URL: <a href="http://llvm.org/viewvc/llvm-project?rev=232785&view=rev" target="_blank">http://llvm.org/viewvc/llvm-project?rev=232785&view=rev</a><br>
Log:<br>
test: Make a start on a test suite for libLTO.<br>
<br>
This works in a similar way to the gold plugin tests. We search for a compatible<br>
linker on $PATH and use it to run tests against our just-built libLTO. To start<br>
with, test the just added opt level functionality.<br>
<br>
Differential Revision: <a href="http://reviews.llvm.org/D8472" target="_blank">http://reviews.llvm.org/D8472</a><br>
<br>
Added:<br>
    llvm/trunk/test/tools/lto/<br>
    llvm/trunk/test/tools/lto/lit.local.cfg<br>
    llvm/trunk/test/tools/lto/opt-level.ll<br>
Modified:<br>
    llvm/trunk/cmake/config-ix.cmake<br>
    llvm/trunk/test/CMakeLists.txt<br>
    llvm/trunk/test/Makefile<br>
    llvm/trunk/test/lit.cfg<br>
    llvm/trunk/test/<a href="http://lit.site.cfg.in" target="_blank">lit.site.cfg.in</a><br>
<br>
Modified: llvm/trunk/cmake/config-ix.cmake<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/cmake/config-ix.cmake?rev=232785&r1=232784&r2=232785&view=diff" target="_blank">http://llvm.org/viewvc/llvm-project/llvm/trunk/cmake/config-ix.cmake?rev=232785&r1=232784&r2=232785&view=diff</a><br>
==============================================================================<br>
--- llvm/trunk/cmake/config-ix.cmake (original)<br>
+++ llvm/trunk/cmake/config-ix.cmake Thu Mar 19 18:55:38 2015<br>
@@ -532,6 +532,10 @@ if(GOLD_EXECUTABLE)<br>
                "PATH to binutils/include containing plugin-api.h for gold plugin.")<br>
 endif()<br>
<br>
+if(APPLE)<br>
+  find_program(LD64_EXECUTABLE NAMES ld DOC "The ld64 linker")<br>
+endif()<br>
+<br>
 include(FindOCaml)<br>
 include(AddOCaml)<br>
 if(WIN32)<br>
<br>
Modified: llvm/trunk/test/CMakeLists.txt<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/test/CMakeLists.txt?rev=232785&r1=232784&r2=232785&view=diff" target="_blank">http://llvm.org/viewvc/llvm-project/llvm/trunk/test/CMakeLists.txt?rev=232785&r1=232784&r2=232785&view=diff</a><br>
==============================================================================<br>
--- llvm/trunk/test/CMakeLists.txt (original)<br>
+++ llvm/trunk/test/CMakeLists.txt Thu Mar 19 18:55:38 2015<br>
@@ -70,6 +70,10 @@ if(TARGET llvm-go)<br>
   set(LLVM_TEST_DEPENDS ${LLVM_TEST_DEPENDS} llvm-go)<br>
 endif()<br>
<br>
+if(APPLE)<br>
+  set(LLVM_TEST_DEPENDS ${LLVM_TEST_DEPENDS} LTO)<br>
+endif()<br>
+<br>
 if(TARGET ocaml_llvm)<br>
   set(LLVM_TEST_DEPENDS ${LLVM_TEST_DEPENDS}<br>
           ocaml_llvm<br>
<br>
Modified: llvm/trunk/test/Makefile<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Makefile?rev=232785&r1=232784&r2=232785&view=diff" target="_blank">http://llvm.org/viewvc/llvm-project/llvm/trunk/test/Makefile?rev=232785&r1=232784&r2=232785&view=diff</a><br>
==============================================================================<br>
--- llvm/trunk/test/Makefile (original)<br>
+++ llvm/trunk/test/Makefile Thu Mar 19 18:55:38 2015<br>
@@ -129,6 +129,7 @@ lit.site.cfg: FORCE<br>
        @$(ECHOPATH) s=@EXEEXT@=$(EXEEXT)=g >> lit.tmp<br>
        @$(ECHOPATH) s=@PYTHON_EXECUTABLE@=$(PYTHON)=g >> lit.tmp<br>
        @$(ECHOPATH) s=@GOLD_EXECUTABLE@=ld=g >> lit.tmp<br>
+       @$(ECHOPATH) s=@LD64_EXECUTABLE@=ld=g >> lit.tmp<br>
        @$(ECHOPATH) s=@OCAMLFIND@=$(OCAMLFIND)=g >> lit.tmp<br>
        @$(ECHOPATH) s!@OCAMLFLAGS@!$(addprefix -cclib ,$(LDFLAGS))!g >> lit.tmp<br>
        @$(ECHOPATH) s=@HAVE_OCAMLOPT@=$(HAVE_OCAMLOPT)=g >> lit.tmp<br>
<br>
Modified: llvm/trunk/test/lit.cfg<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/test/lit.cfg?rev=232785&r1=232784&r2=232785&view=diff" target="_blank">http://llvm.org/viewvc/llvm-project/llvm/trunk/test/lit.cfg?rev=232785&r1=232784&r2=232785&view=diff</a><br>
==============================================================================<br>
--- llvm/trunk/test/lit.cfg (original)<br>
+++ llvm/trunk/test/lit.cfg Thu Mar 19 18:55:38 2015<br>
@@ -188,6 +188,7 @@ config.substitutions.append( ('%llc_dwar<br>
<br>
 # Add site-specific substitutions.<br>
 config.substitutions.append( ('%gold', config.gold_executable) )<br>
+config.substitutions.append( ('%ld64', config.ld64_executable) )<br>
 config.substitutions.append( ('%go', config.go_executable) )<br>
 config.substitutions.append( ('%llvmshlibdir', config.llvm_shlib_dir) )<br>
 config.substitutions.append( ('%shlibext', config.llvm_shlib_ext) )<br>
@@ -369,6 +370,22 @@ def have_ld_plugin_support():<br>
 if have_ld_plugin_support():<br>
     config.available_features.add('ld_plugin')<br>
<br>
+def have_ld64_plugin_support():<br>
+    if config.ld64_executable == '':<br>
+        return False<br>
+<br>
+    ld_cmd = subprocess.Popen([config.ld64_executable, '-v'], stderr = subprocess.PIPE)<br>
+    ld_out = ld_cmd.stderr.read().decode()<br>
+    ld_cmd.wait()<br>
+<br>
+    if 'ld64' not in ld_out or 'LTO' not in ld_out:<br>
+        return False<br>
+<br>
+    return True<br>
+<br>
+if have_ld64_plugin_support():<br>
+    config.available_features.add('ld64_plugin')<br>
+<br>
 # Ask llvm-config about assertion mode.<br>
 try:<br>
     llvm_config_cmd = subprocess.Popen(<br>
<br>
Modified: llvm/trunk/test/<a href="http://lit.site.cfg.in" target="_blank">lit.site.cfg.in</a><br>
URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/test/lit.site.cfg.in?rev=232785&r1=232784&r2=232785&view=diff" target="_blank">http://llvm.org/viewvc/llvm-project/llvm/trunk/test/lit.site.cfg.in?rev=232785&r1=232784&r2=232785&view=diff</a><br>
==============================================================================<br>
--- llvm/trunk/test/<a href="http://lit.site.cfg.in" target="_blank">lit.site.cfg.in</a> (original)<br>
+++ llvm/trunk/test/<a href="http://lit.site.cfg.in" target="_blank">lit.site.cfg.in</a> Thu Mar 19 18:55:38 2015<br>
@@ -14,6 +14,7 @@ config.llvm_exe_ext = "@EXEEXT@"<br>
 config.lit_tools_dir = "@LLVM_LIT_TOOLS_DIR@"<br>
 config.python_executable = "@PYTHON_EXECUTABLE@"<br>
 config.gold_executable = "@GOLD_EXECUTABLE@"<br>
+config.ld64_executable = "@LD64_EXECUTABLE@"<br>
 config.ocamlfind_executable = "@OCAMLFIND@"<br>
 config.have_ocamlopt = "@HAVE_OCAMLOPT@"<br>
 config.have_ocaml_ounit = "@HAVE_OCAML_OUNIT@"<br>
<br>
Added: llvm/trunk/test/tools/lto/lit.local.cfg<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/test/tools/lto/lit.local.cfg?rev=232785&view=auto" target="_blank">http://llvm.org/viewvc/llvm-project/llvm/trunk/test/tools/lto/lit.local.cfg?rev=232785&view=auto</a><br>
==============================================================================<br>
--- llvm/trunk/test/tools/lto/lit.local.cfg (added)<br>
+++ llvm/trunk/test/tools/lto/lit.local.cfg Thu Mar 19 18:55:38 2015<br>
@@ -0,0 +1,2 @@<br>
+if not 'ld64_plugin' in config.available_features:<br>
+   config.unsupported = True<br></blockquote><div><br></div><div>This disables the whole directory. There's only one test in the directory, but it seems like it would make sense for there to be tests for different LTO customers in here. Could you make this a "REQUIRES:" thing instead, so that we can mark the tests individually?</div><div><br></div><div>Nick</div><div> </div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
<br>
Added: llvm/trunk/test/tools/lto/opt-level.ll<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/llvm/trunk/test/tools/lto/opt-level.ll?rev=232785&view=auto" target="_blank">http://llvm.org/viewvc/llvm-project/llvm/trunk/test/tools/lto/opt-level.ll?rev=232785&view=auto</a><br>
==============================================================================<br>
--- llvm/trunk/test/tools/lto/opt-level.ll (added)<br>
+++ llvm/trunk/test/tools/lto/opt-level.ll Thu Mar 19 18:55:38 2015<br>
@@ -0,0 +1,20 @@<br>
+; RUN: llvm-as %s -o %t.o<br>
+; RUN: env DYLD_LIBRARY_PATH=%llvmshlibdir %ld64 -arch x86_64 -dylib -mllvm -O0 -o %t.dylib %t.o<br>
+; RUN: llvm-nm -no-llvm-bc %t.dylib | FileCheck --check-prefix=CHECK-O0 %s<br>
+; RUN: env DYLD_LIBRARY_PATH=%llvmshlibdir %ld64 -arch x86_64 -dylib -mllvm -O2 -o %t.dylib %t.o<br>
+; RUN: llvm-nm -no-llvm-bc %t.dylib | FileCheck --check-prefix=CHECK-O2 %s<br>
+<br>
+target triple = "x86_64-apple-macosx10.8.0"<br>
+<br>
+; CHECK-O0: t _f1<br>
+; CHECK-O2-NOT: _f1<br>
+define internal void @f1() {<br>
+  ret void<br>
+}<br>
+<br>
+; CHECK-O0: T _f2<br>
+; CHECK-O2: T _f2<br>
+define void @f2() {<br>
+  call void @f1()<br>
+  ret void<br>
+}<br>
<br>
<br>
_______________________________________________<br>
llvm-commits mailing list<br>
<a href="mailto:llvm-commits@cs.uiuc.edu">llvm-commits@cs.uiuc.edu</a><br>
<a href="http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits" target="_blank">http://lists.cs.uiuc.edu/mailman/listinfo/llvm-commits</a><br>
</blockquote></div><br></div></div>