[compiler-rt] r254966 - [TSan] Enforce TSan runtime doesn't include system headers with --sysroot flag.

Dimitry Andric via llvm-commits llvm-commits at lists.llvm.org
Tue Feb 2 14:48:41 PST 2016


Hmm, for me this causes the compiler-rt build to fail on FreeBSD 10, because the sysroot option then points to non-existing directories.  E.g. it gives:

clang -cc1 version 3.4.1 based upon LLVM 3.4.1 default target x86_64-unknown-freebsd10.2
ignoring nonexistent directory "./usr/include/c++/v1"
ignoring nonexistent directory "/usr/bin/../lib/clang/3.4.1/include"
ignoring nonexistent directory "./usr/include/clang/3.4.1"
ignoring nonexistent directory "./usr/include"
#include "..." search starts here:
#include <...> search starts here:
 /home/dim/llvm-3.8.0/rc2/Phase1/Release/llvmCore-3.8.0-rc2.obj/projects/compiler-rt/lib/tsan
 /home/dim/llvm-3.8.0/rc2/llvm.src/projects/compiler-rt/lib/tsan
 /home/dim/llvm-3.8.0/rc2/Phase1/Release/llvmCore-3.8.0-rc2.obj/include
 /home/dim/llvm-3.8.0/rc2/llvm.src/include
 /usr/local/include
 /home/dim/llvm-3.8.0/rc2/llvm.src/projects/compiler-rt/lib/tsan/..
End of search list.
In file included from /home/dim/llvm-3.8.0/rc2/llvm.src/projects/compiler-rt/lib/tsan/rtl/tsan_interceptors.cc:2411:
/home/dim/llvm-3.8.0/rc2/llvm.src/projects/compiler-rt/lib/tsan/../sanitizer_common/sanitizer_common_interceptors.inc:41:10: fatal error:
      'stdarg.h' file not found
#include <stdarg.h>
         ^
1 error generated.

Note that on FreeBSD 10, clang's internal headers (which normally don't contain stdarg.h, but on my particular build machine they do), are in /usr/include/clang/3.4.1.

Any reason this can't be fixed using -nostdinc, instead?

-Dimitry

> On 08 Dec 2015, at 00:21, Alexey Samsonov via llvm-commits <llvm-commits at lists.llvm.org> wrote:
> 
> Author: samsonov
> Date: Mon Dec  7 17:21:36 2015
> New Revision: 254966
> 
> URL: http://llvm.org/viewvc/llvm-project?rev=254966&view=rev
> Log:
> [TSan] Enforce TSan runtime doesn't include system headers with --sysroot flag.
> 
> Modified:
>    compiler-rt/trunk/cmake/config-ix.cmake
>    compiler-rt/trunk/lib/tsan/CMakeLists.txt
> 
> Modified: compiler-rt/trunk/cmake/config-ix.cmake
> URL: http://llvm.org/viewvc/llvm-project/compiler-rt/trunk/cmake/config-ix.cmake?rev=254966&r1=254965&r2=254966&view=diff
> ==============================================================================
> --- compiler-rt/trunk/cmake/config-ix.cmake (original)
> +++ compiler-rt/trunk/cmake/config-ix.cmake Mon Dec  7 17:21:36 2015
> @@ -29,6 +29,7 @@ check_cxx_compiler_flag(-ftls-model=init
> check_cxx_compiler_flag(-fno-lto             COMPILER_RT_HAS_FNO_LTO_FLAG)
> check_cxx_compiler_flag(-msse3               COMPILER_RT_HAS_MSSE3_FLAG)
> check_cxx_compiler_flag(-std=c99             COMPILER_RT_HAS_STD_C99_FLAG)
> +check_cxx_compiler_flag(--sysroot=.          COMPILER_RT_HAS_SYSROOT_FLAG)
> 
> if(NOT WIN32 AND NOT CYGWIN)
>   # MinGW warns if -fvisibility-inlines-hidden is used.
> 
> Modified: compiler-rt/trunk/lib/tsan/CMakeLists.txt
> URL: http://llvm.org/viewvc/llvm-project/compiler-rt/trunk/lib/tsan/CMakeLists.txt?rev=254966&r1=254965&r2=254966&view=diff
> ==============================================================================
> --- compiler-rt/trunk/lib/tsan/CMakeLists.txt (original)
> +++ compiler-rt/trunk/lib/tsan/CMakeLists.txt Mon Dec  7 17:21:36 2015
> @@ -21,7 +21,6 @@ append_list_if(SANITIZER_LIMIT_FRAME_SIZ
>                TSAN_RTL_CFLAGS)
> append_list_if(COMPILER_RT_HAS_WGLOBAL_CONSTRUCTORS_FLAG -Wglobal-constructors
>                TSAN_RTL_CFLAGS)
> -# FIXME: Add support for --sysroot=. compile flag:
> 
> set(TSAN_SOURCES
>   rtl/tsan_clock.cc
> @@ -187,6 +186,18 @@ endif()
> 
> add_dependencies(compiler-rt tsan)
> 
> +# Make sure that non-platform-specific files don't include any system headers.
> +if(COMPILER_RT_HAS_SYSROOT_FLAG)
> +  file(GLOB _tsan_generic_sources rtl/tsan*)
> +  file(GLOB _tsan_platform_sources rtl/tsan*posix* rtl/tsan*mac*
> +                                   rtl/tsan*linux*)
> +  list(REMOVE_ITEM _tsan_generic_sources ${_tsan_platform_sources})
> +  message(STATUS "platform: ${_tsan_platform_sources}")
> +  message(STATUS "generic: ${_tsan_generic_sources}")
> +  set_source_files_properties(${_tsan_generic_sources}
> +    PROPERTIES COMPILE_FLAGS "--sysroot=.")
> +endif()
> +
> # Build libcxx instrumented with TSan.
> if(COMPILER_RT_HAS_LIBCXX_SOURCES AND
>    COMPILER_RT_TEST_COMPILER_ID STREQUAL "Clang")
> 
> 
> _______________________________________________
> llvm-commits mailing list
> llvm-commits at lists.llvm.org
> http://lists.llvm.org/cgi-bin/mailman/listinfo/llvm-commits

-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 194 bytes
Desc: Message signed with OpenPGP using GPGMail
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20160202/a2d98d52/attachment.sig>


More information about the llvm-commits mailing list