Skip to content
  1. Jul 12, 2019
  2. May 30, 2019
    • Petr Hosek's avatar
      [runtimes] Check if pragma comment(lib, ...) is supported first · 789b7f08
      Petr Hosek authored
      This fixes the issue introduced by r362048 where we always use
      pragma comment(lib, ...) for dependent libraries when the compiler
      is Clang, but older Clang versions don't support this pragma so
      we need to check first if it's supported before using it.
      
      llvm-svn: 362055
      789b7f08
  3. May 22, 2019
    • Petr Hosek's avatar
      [runtimes] Move libunwind, libc++abi and libc++ to lib/$target/c++ and include/c++ · 81f433b4
      Petr Hosek authored
      This change is a consequence of the discussion in "RFC: Place libs in
      Clang-dedicated directories", specifically the suggestion that
      libunwind, libc++abi and libc++ shouldn't be using Clang resource
      directory. Tools like clangd make this assumption, but this is
      currently not true for the LLVM_ENABLE_PER_TARGET_RUNTIME_DIR build.
      This change addresses that by moving the output of these libraries to
      lib/$target/c++ and include/c++ directories, leaving resource directory
      only for compiler-rt runtimes and Clang builtin headers.
      
      Differential Revision: https://reviews.llvm.org/D59168
      
      llvm-svn: 361432
      81f433b4
  4. May 02, 2019
    • Petr Hosek's avatar
      [gn] Support for building libcxxabi · 4fe63c70
      Petr Hosek authored
      This change introduces support for building libcxxabi. The library
      build should be complete, but not all CMake options have been
      replicated in GN. We also don't support tests yet.
      
      We only support two stage build at the moment.
      
      Differential Revision: https://reviews.llvm.org/D60372
      
      llvm-svn: 359805
      4fe63c70
  5. Apr 03, 2019
  6. Mar 08, 2019
  7. Feb 17, 2019
    • Jonas Hahnfeld's avatar
      [compiler-rt] Build custom libcxx with libcxxabi · 66c60d9d
      Jonas Hahnfeld authored
      This changes add_custom_libcxx to also build libcxxabi and merges
      the two into a static and hermetic library.
      There are multiple advantages:
      1) The resulting libFuzzer doesn't expose C++ internals and looks
         like a plain C library.
      2) We don't have to manually link in libstdc++ to provide cxxabi.
      3) The sanitizer tests cannot interfere with an installed version
         of libc++.so in LD_LIBRARY_PATH.
      
      Differential Revision: https://reviews.llvm.org/D58013
      
      llvm-svn: 354212
      66c60d9d
  8. Feb 12, 2019
    • Petr Hosek's avatar
      [CMake] Avoid passing -rtlib=compiler-rt when using compiler-rt · 5300d841
      Petr Hosek authored
      We build libc++ and libc++abi with -nodefaultlibs, so -rtlib=compiler-rt
      has no effect and results in an 'argument unused during compilation'
      warning which breaks the build when using -Werror. We can therefore drop
      -rtlib=compiler-rt without any functional change; note that the actual
      compiler-rt linking is handled by HandleCompilerRT.
      
      Differential Revision: https://reviews.llvm.org/D58084
      
      llvm-svn: 353786
      5300d841
  9. Feb 04, 2019
    • Petr Hosek's avatar
      [CMake] Support CMake variables for setting target, sysroot and toolchain · 6fd4e7fe
      Petr Hosek authored
      CMake has a standard way of setting target triple, sysroot and external
      toolchain through CMAKE_<LANG>_COMPILER_TARGET, CMAKE_SYSROOT and
      CMAKE_<LANG>_COMPILER_EXTERNAL_TOOLCHAIN. These are turned into
      corresponding --target=, --sysroot= and --gcc-toolchain= variables add
      included appended to CMAKE_<LANG>_FLAGS.
      
      libunwind, libc++abi, libc++ provides their own mechanism through
      <PROJECT>_TARGET_TRIPLE, <PROJECT>_SYSROOT and <PROJECT>_GCC_TOOLCHAIN
      variables. These are also passed to lit via lit.site.cfg, and lit config
      uses these to set the corresponding compiler flags when building tessts.
      
      This means that there are two different ways of setting target, sysroot
      and toolchain, but only one is properly supported in lit. This change
      extends CMake build for libunwind, libc++abi and libc++ to also support
      the CMake variables in addition to project specific ones in lit.
      
      Differential Revision: https://reviews.llvm.org/D57670
      
      llvm-svn: 353084
      6fd4e7fe
  10. Jan 24, 2019
    • Petr Hosek's avatar
      [libcxxabi] Support building hermetic static library · 8807db32
      Petr Hosek authored
      This is useful when the static libc++abi library is being linked into
      shared libraries that may be used in with other shared libraries that
      use different C++ library. We want to avoid avoid exporting libc++abi
      or libc++ symbols in those cases. This achieved by a new CMake option
      which can be enabled by libc++abi vendors as needed.
      
      Differential Revision: https://reviews.llvm.org/D56026
      
      llvm-svn: 352017
      8807db32
  11. Jan 16, 2019
  12. Aug 01, 2018
  13. Jul 26, 2018
    • Sam Clegg's avatar
      [CMake] Don't use LIBCXXABI_ENABLE_STATIC option before its declared · 77c99ee5
      Sam Clegg authored
      Summary:
      rL337867 introduced two new cmake_dependent_option options:
      - LIBCXXABI_INSTALL_STATIC_LIBRARY
      - LIBCXXABI_INSTALL_SHARED_LIBRARY
      
      They depend on LIBCXXABI_ENABLE_STATIC and LIBCXXABI_ENABLE_SHARED
      and so therefore need to (it seems) come after the declaration of
      these two options.
      
      Subscribers: mgorny, aheejin, christof, ldionne, cfe-commits
      
      Differential Revision: https://reviews.llvm.org/D49825
      
      llvm-svn: 337982
      77c99ee5
  14. Jul 25, 2018
  15. Jul 24, 2018
  16. Jul 23, 2018
  17. Jul 10, 2018
  18. Jun 30, 2018
    • Shoaib Meenai's avatar
      [libc++abi] Look for __config instead of vector · 51d5cc92
      Shoaib Meenai authored
      vector is a generic C++ header, whereas __config is libc++-specific, so
      we can look for it instead to guarantee we're finding a libc++
      installation. This was suggested by Eric in https://reviews.llvm.org/D48694.
      
      This is less important now that we're limiting the header search to the
      specified directories (which definitely shouldn't have any other C++
      library's headers anyway), but it shouldn't hurt either. There's a
      chance some other library could also be providing a __config header, so
      there's still a trade-off there. It would be ideal if we could check for
      the presence of both __config and vector in the same directory, but
      there doesn't seem to be any easy way to do that in CMake.
      
      llvm-svn: 336034
      51d5cc92
    • Shoaib Meenai's avatar
      [libc++abi] Limit libc++ header search to specified paths · 777ec376
      Shoaib Meenai authored
      Right now, when libc++abi is locating libc++ headers, it specifies
      several search locations, but it also doesn't prevent CMake from looking
      for those headers in system directories. I don't know if this was
      intentional or an oversight, but it has several issues:
      
      * We're looking specifically for the vector header, which could just as
        easily be found in a libstdc++ (or other C++ library) installation.
      * No system I know of places their C++ headers directly in system
        include directories (they're always under a C++ subdirectory), so the
        system search will never succeed.
      * find_path searches system paths before the user-specified PATHS, so
        if some system does happen to have C++ headers in its system include
        directories, those headers will be preferred, which doesn't seem
        desirable.
      
      It makes sense to me to limit this header search to the explicitly
      specified paths (using NO_DEFAULT_PATH, as is done for the other
      find_path call in this file), but I'm putting it up for review in case
      there's some use case I'm not thinking of.
      
      Differential Revision: https://reviews.llvm.org/D48694
      
      llvm-svn: 336032
      777ec376
  19. Jun 28, 2018
    • Petr Hosek's avatar
      Support for multiarch runtimes layout · 887f26d4
      Petr Hosek authored
      This change adds a support for multiarch style runtimes layout, so in
      addition to the existing layout where runtimes get installed to:
      
      lib/clang/$version/lib/$os
      
      Clang now allows runtimes to be installed to:
      
      lib/clang/$version/$target/lib
      
      This also includes libc++, libc++abi and libunwind; today those are
      assumed to be in Clang library directory built for host, with the
      new layout it is possible to install libc++, libc++abi and libunwind
      into the runtime directory built for different targets.
      
      The use of new layout is enabled by setting the
      LLVM_ENABLE_RUNTIME_TARGET_DIR CMake variable and is supported by both
      projects and runtimes layouts. The runtimes CMake build has been further
      modified to use the new layout when building runtimes for multiple
      targets.
      
      Differential Revision: https://reviews.llvm.org/D45604
      
      llvm-svn: 335809
      887f26d4
  20. Apr 30, 2018
    • Nico Weber's avatar
      Move _LIBCPP_ENABLE_CXX17_REMOVED_UNEXPECTED_FUNCTIONS macro to build system · 297ec32b
      Nico Weber authored
      _LIBCPP_ENABLE_CXX17_REMOVED_UNEXPECTED_FUNCTIONS is currently used to
      bring back std::unexpected, which is removed in C++17, but still needed
      for libc++abi for backward compatibility.
      
      This macro used to define in cxa_exception.cpp only, but actually
      needed for all sources that touches exceptions.
      So, a build-system-level macro is better fit to define this macro.
      
      https://reviews.llvm.org/D46056
      Patch from Taiju Tsuiku <tzik@chromium.org>!
      
      llvm-svn: 331150
      297ec32b
  21. Apr 04, 2018
  22. Jan 22, 2018
    • Don Hinton's avatar
      [cmake] [libcxxabi] Fix find_path() problems when cross compiling · ae858bf6
      Don Hinton authored
      When CMAKE_SYSROOT or CMAKE_FIND_ROOT_PATH is set, cmake
      recommends setting CMAKE_FIND_ROOT_PATH_MODE_INCLUDE=ONLY
      globally which means find_path() always prepends CMAKE_SYSROOT or
      CMAKE_FIND_ROOT_PATH to all paths used in the search.
      
      However, these find_path() invocations are looking for paths in
      the libcxx and libunwind projects on the host system, not the
      target system, which can be done by passing
      NO_CMAKE_FIND_ROOT_PATH.
      
      Differential Revision: https://reviews.llvm.org/D41623
      
      llvm-svn: 323145
      ae858bf6
  23. Jan 18, 2018
  24. Jan 03, 2018
  25. Nov 18, 2017
  26. Jul 31, 2017
  27. Jul 19, 2017
  28. Jul 11, 2017
  29. Jun 13, 2017
  30. Jun 01, 2017
  31. May 29, 2017
  32. May 11, 2017
  33. May 10, 2017
    • Shoaib Meenai's avatar
      [libc++abi] Disable libc++ extern templates project-wide · f43726cd
      Shoaib Meenai authored
      libc++abi can't depend on libc++, so disable extern templates in libc++
      headers project-wide. This was previously done in cxa_demangle.cpp, but
      I consider it more appropriate to do at the cmake level (since none of
      libc++abi's source files can use libc++ extern templates).
      
      I also think the _LIBCPP_NO_EXCEPTIONS in cxa_demangle.cpp is
      suspicious, but I'm doing one thing at a time.
      
      Differential Revision: https://reviews.llvm.org/D32329
      
      llvm-svn: 302739
      f43726cd
  34. May 04, 2017
  35. Apr 16, 2017
Loading