[PATCH] D61016: [lit][tests]Add libc++ to link XRay test cases if libc++ is used to build CLANG

Xing Xue via Phabricator via llvm-commits llvm-commits at lists.llvm.org
Tue Apr 23 06:54:09 PDT 2019


xingxue created this revision.
xingxue added reviewers: hubert.reinterpretcast, jasonliu, sfertile.
xingxue added a project: LLVM.
Herald added subscribers: llvm-commits, jsji, mgorny, dberris.
Herald added a reviewer: EricWF.

When `libc++` is used to build CLANG, its XRay libraries `libclang_rt.xray-*.a` have dependencies on `libc++`. Therefore, `libc++` is needed to link and run XRay test cases. For Linux `-rpath` is also needed to specify where to load `libc++`. This change sets macro `LLVM_LIBCXX_USED` to 1 if `libc++` is actually used in the build. XRay tests then check the flag and add `-L<llvm_shlib_dir> -lc++` and `-Wl,-rpath=<llvm_shlib_dir>` if needed.


Repository:
  rL LLVM

https://reviews.llvm.org/D61016

Files:
  compiler-rt/test/lit.common.configured.in
  compiler-rt/test/xray/lit.cfg
  llvm/cmake/modules/HandleLLVMStdlib.cmake


Index: llvm/cmake/modules/HandleLLVMStdlib.cmake
===================================================================
--- llvm/cmake/modules/HandleLLVMStdlib.cmake
+++ llvm/cmake/modules/HandleLLVMStdlib.cmake
@@ -14,6 +14,7 @@
 
   include(CheckCXXCompilerFlag)
   include(CheckLinkerFlag)
+  set(LLVM_LIBCXX_USED 0)
   if(LLVM_ENABLE_LIBCXX)
     if(LLVM_COMPILER_IS_GCC_COMPATIBLE)
       check_cxx_compiler_flag("-stdlib=libc++" CXX_COMPILER_SUPPORTS_STDLIB)
@@ -22,6 +23,7 @@
         append("-stdlib=libc++"
           CMAKE_CXX_FLAGS CMAKE_EXE_LINKER_FLAGS CMAKE_SHARED_LINKER_FLAGS
           CMAKE_MODULE_LINKER_FLAGS)
+        set(LLVM_LIBCXX_USED 1)
       else()
         message(WARNING "Can't specify libc++ with '-stdlib='")
       endif()
Index: compiler-rt/test/xray/lit.cfg
===================================================================
--- compiler-rt/test/xray/lit.cfg
+++ compiler-rt/test/xray/lit.cfg
@@ -10,8 +10,16 @@
 
 # Setup default compiler flags use with -fxray-instrument option.
 clang_xray_cflags = (['-fxray-instrument', config.target_cflags])
-clang_xray_cxxflags = config.cxx_mode_flags + clang_xray_cflags
 
+# If libc++ was used to build XRAY libraries, libc++ is needed. Fix applied
+# to Linux only since -rpath may not be portable. This can be extended to
+# other platforms.
+if config.libcxx_used == "1" and config.host_os == "Linux":
+  clang_xray_cflags = clang_xray_cflags + (['-L%s -lc++ -Wl,-rpath=%s'
+                                          % (config.llvm_shlib_dir,
+                                             config.llvm_shlib_dir)])
+
+clang_xray_cxxflags = config.cxx_mode_flags + clang_xray_cflags
 
 def build_invocation(compile_flags):
   return ' ' + ' '.join([config.clang] + compile_flags) + ' '
Index: compiler-rt/test/lit.common.configured.in
===================================================================
--- compiler-rt/test/lit.common.configured.in
+++ compiler-rt/test/lit.common.configured.in
@@ -49,6 +49,7 @@
   set_default("target_suffix", "-%s" % config.target_arch)
 
 set_default("have_zlib", "@HAVE_LIBZ@")
+set_default("libcxx_used", "@LLVM_LIBCXX_USED@")
 
 # LLVM tools dir can be passed in lit parameters, so try to
 # apply substitution.


-------------- next part --------------
A non-text attachment was scrubbed...
Name: D61016.196237.patch
Type: text/x-patch
Size: 2230 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20190423/10b277ae/attachment.bin>


More information about the llvm-commits mailing list