Skip to content
  1. Jul 12, 2019
  2. Jun 28, 2019
  3. Jun 27, 2019
  4. Jun 19, 2019
  5. Jun 18, 2019
  6. Jun 10, 2019
  7. Jun 02, 2019
  8. May 30, 2019
    • Petr Hosek's avatar
      [libcxx][libcxxabi] Remove the unused CMake checks · 0528726a
      Petr Hosek authored
      These seemed to have been used in the past but were since removed
      by the add_compile_flags_if_supported functions that combine these
      these checks and adding the flag, but the original checks were never
      removed.
      
      Differential Revision: https://reviews.llvm.org/D62566
      
      llvm-svn: 362058
      0528726a
    • Petr Hosek's avatar
      [runtimes] Use -Wunknown-pragmas for the pragma check · f1ddf431
      Petr Hosek authored
      This is a follow up to r362055, we need -Wunknown-pragmas otherwise
      the check is going to succeed it the pragma isn't supported.
      
      llvm-svn: 362057
      f1ddf431
    • 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
    • Petr Hosek's avatar
      [runtimes] Support ELF dependent libraries feature · 996e62ee
      Petr Hosek authored
      As of r360984, LLD supports dependent libraries feature for ELF.
      libunwind, libc++abi and libc++ have library dependencies: libdl librt
      and libpthread, which means that when libunwind and libc++ are being
      statically linked (using -static-libstdc++ flag), user has to manually
      specify -ldl -lpthread which is onerous.
      
      This change includes the lib pragma to specify the library dependencies
      directly in the source that uses those libraries. This doesn't make any
      difference when using linkers that don't support dependent libraries.
      However, when using LLD that has dependent libraries feature, users no
      longer have to manually specifying library dependencies when using
      static linking, linker will pick the library automatically.
      
      Differential Revision: https://reviews.llvm.org/D62090
      
      llvm-svn: 362048
      996e62ee
  9. May 29, 2019
    • Eric Fiselier's avatar
      Update private_typeinfo's `is_equal` implementation after r361913 · 360ead76
      Eric Fiselier authored
      The libc++ typeinfo implementation is being improved to better
      handle non-merged type names.
      
      This patch takes advantage of that more correct behavior by delegating
      to std::type_infos default operator== instead of doing pointer equality
      ourselves.
      
      However, libc++ still expects unique RTTI by default, and so we
      should still fall back to strcmp when explicitly requested.
      
      llvm-svn: 361916
      360ead76
  10. 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
  11. May 17, 2019
  12. May 16, 2019
  13. May 07, 2019
  14. May 06, 2019
    • Petr Hosek's avatar
      [libcxxabi] Don't use -fvisibility-global-new-delete-hidden when not defining them · 6971a166
      Petr Hosek authored
      When builing the hermetic static library, the compiler switch
      -fvisibility-global-new-delete-hidden is necessary to get the new and
      delete operator definitions made correctly. However, when those
      definitions are not included in the library, then this switch does harm.
      With lld (though not all linkers) setting STV_HIDDEN on SHN_UNDEF
      symbols makes it an error to leave them undefined or defined via dynamic
      linking that should generate PLTs for -shared linking (lld makes this a
      hard error even without -z defs). Though leaving the symbols undefined
      would usually work in practice if the linker were to allow it (and the
      user didn't pass -z defs), this actually indicates a real problem that
      could bite some target configurations more subtly at runtime. For
      example, x86-32 ELF -fpic code generation uses hidden visibility on
      declarations in the caller's scope as a signal that the call will never
      be resolved to a PLT entry and so doesn't have to meet the special ABI
      requirements for PLT calls (setting %ebx). Since these functions might
      actually be resolved to PLT entries at link time (we don't know what the
      user is linking in when the hermetic library doesn't provide all the
      symbols itself), it's not safe for the compiler to treat their
      declarations at call sites as having hidden visibility.
      
      Differential Revision: https://reviews.llvm.org/D61572
      
      llvm-svn: 360004
      6971a166
  15. 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
    • Eric Fiselier's avatar
      Attempt to fix flaky tests. · a4939d35
      Eric Fiselier authored
      The threaded cxa guard test attempted to test multithreaded waiting
      by lining up a bunch of threads at a held init lock and releasing them.
      The test initially wanted each thread to observe the lock being held,
      but some threads may arive too late.
      
      This patch cleans up the test and relaxes the restrictions.
      
      llvm-svn: 359785
      a4939d35
  16. Apr 30, 2019
  17. Apr 29, 2019
  18. Apr 25, 2019
    • Michael Platings's avatar
      Fix compilation error with -DLIBCXXABI_ENABLE_THREADS=OFF · d144572d
      Michael Platings authored
      The error is:
      
      libcxxabi/src/cxa_guard_impl.h: In instantiation of ‘__cxxabiv1::{anonymous}::LibcppMutex __cxxabiv1::{anonymous}::GlobalStatic<__cxxabiv1::{anonymous}::LibcppMutex>::instance’:
      libcxxabi/src/cxa_guard_impl.h:529:62:   required from here
      libcxxabi/src/cxa_guard_impl.h:510:23: error: ‘__cxxabiv1::{anonymous}::LibcppMutex __cxxabiv1::{anonymous}::GlobalStatic<__cxxabiv1::{anonymous}::LibcppMutex>::instance’ has incomplete type
       _LIBCPP_SAFE_STATIC T GlobalStatic<T>::instance = {};
                             ^
      
      llvm-svn: 359175
      d144572d
  19. Apr 24, 2019
    • Eric Fiselier's avatar
      Cleanup new cxa guard implementation. · 5a235865
      Eric Fiselier authored
      * Add TSAN annotations around the futex syscalls.
      * Test that the futex syscall wrappers actually work.
      * Fix bad names.
      
      llvm-svn: 359069
      5a235865
    • Eric Fiselier's avatar
      Work around GCC test failure. · 27fd2f60
      Eric Fiselier authored
      llvm-svn: 359065
      27fd2f60
    • Eric Fiselier's avatar
      Rewrite cxa guard implementation. · 70ebeabf
      Eric Fiselier authored
      This patch does three main things:
        (1) It re-writes the cxa guard implementation to make it testable.
        (2) Adds support for recursive init detection on non-apple platforms.
        (3) It adds a futex based implementation.
      
      The futex based implementation locks and notifies on a per-object basis, unlike the
      current implementation which uses a global lock for all objects. Once this patch settles
      I'll turn it on by default when supported.
      
      llvm-svn: 359060
      70ebeabf
  20. Apr 23, 2019
  21. Apr 18, 2019
    • Louis Dionne's avatar
      [libc++] Make sure we re-export some missing libc++abi symbols from libc++ · 549048f3
      Louis Dionne authored
      Summary:
      Ensure we re-export __cxa_throw_bad_array_new_length and
      __cxa_uncaught_exceptions from libc++, since they are now
      provided by libc++abi.
      
      Doing this allows us to stop linking explicitly against libc++abi in
      the libc++abi tests, since libc++ re-exports all the necessary symbols.
      However, there is one caveat to that. We don't want libc++ to re-export
      __cxa_uncaught_exception (the singular form), since it's only provided
      for backwards compatibility. Hence, for the single test where we check
      this backwards compatibility, we explicitly link against libc++abi.
      
      PR27405
      PR22654
      
      Reviewers: EricWF
      
      Subscribers: christof, jkorous, dexonsmith, libcxx-commits
      
      Tags: #libc
      
      Differential Revision: https://reviews.llvm.org/D60424
      
      llvm-svn: 358690
      549048f3
  22. Apr 11, 2019
  23. Apr 10, 2019
  24. Apr 09, 2019
  25. Apr 08, 2019
    • Eric Fiselier's avatar
      Make reads and writes of the guard variable atomic. · 62c2b5ac
      Eric Fiselier authored
      The read of the guard variable by the caller is atomic,
      and doesn't happen under a mutex.
      
      Our internal reads and writes were non-atomic, because they happened
      under a mutex.
      
      The writes should always be atomic since they can be observed outside
      of the lock.
      
      Making the reads atomic is not strictly necessary under the current
      global mutex approach, but will be under implementations that use a
      futex (which I plan to land shortly). However, they should add little
      additional cost.
      
      llvm-svn: 357944
      62c2b5ac
  26. Apr 05, 2019
    • Eric Fiselier's avatar
      c4225e12
    • Eric Fiselier's avatar
      Further refactor cxa_guard.cpp · d2225d06
      Eric Fiselier authored
      This patch is a part of a series of patches to cleanup
      our implementation of __cxa_acquire et al. No functionality
      change was intended.
      
      This patch does two primary things.
      
      It introduces the GuardObject class to abstract the reading
      and writing to the guard object. In future, it will be used
      to ensure atomic accesses are used when needed.
      
      It also introduces the GuardValue class used to represent
      values of the guard object. It is an abstraction to access
      and write to the various different bits of a guard.
      
      llvm-svn: 357804
      d2225d06
  27. Apr 04, 2019
  28. Apr 03, 2019
Loading