Skip to content
  1. Jan 11, 2016
  2. Dec 09, 2015
    • Evgeniy Stepanov's avatar
      Add 3 more missing inline/visibility attributes. · 02b8e949
      Evgeniy Stepanov authored
      These are the cases when an out-of-class definition of a method is
      marked _LIBCPP_INLINE_VISIBILITY, but the in-class declaration is
      not. This will start failing when (or if) we switch to
      attribute((internal_linkage)).
      
      llvm-svn: 255166
      02b8e949
  3. Nov 12, 2015
  4. Nov 07, 2015
  5. Oct 25, 2015
  6. Aug 28, 2015
  7. Aug 23, 2015
  8. Aug 19, 2015
    • Eric Fiselier's avatar
      [libcxx] Allow use of <atomic> in C++03. Try 3. · 749adeba
      Eric Fiselier authored
      Summary:
      After putting this question up on cfe-dev I have decided that it would be best to allow the use of `<atomic>` in C++03. Although static initialization is a concern the syntax required to get it is C++11 only. Meaning that C++11 constant static initialization cannot silently break in C++03, it will always cause a syntax error. Furthermore `ATOMIC_VAR_INIT` and `ATOMIC_FLAG_INIT` remain defined in C++03 even though they cannot be used because C++03 usages will cause better error messages.
      
      The main change in this patch is to replace `__has_feature(cxx_atomic)`, which only returns true when C++ >= 11, to `__has_extension(c_atomic)` which returns true whenever clang supports the required atomic builtins.
      
      
      This patch adds the following macros:
      * `_LIBCPP_HAS_C_ATOMIC_IMP`      - Defined on clang versions which provide the C `_Atomic` keyword.
      * `_LIBCPP_HAS_GCC_ATOMIC_IMP` - Defined on GCC > 4.7. We must use the fallback atomic implementation.
      * `_LIBCPP_HAS_NO_ATOMIC_HEADER` - Defined when it is not safe to include `<atomic>`.
      
      `_LIBCPP_HAS_C_ATOMIC_IMP` and `_LIBCPP_HAS_GCC_ATOMIC_IMP` are mutually exclusive, only one should be defined. If neither is defined then `<atomic>` is not implemented and including `<atomic>` will issue an error.
      
      Reviewers: chandlerc, jroelofs, mclow.lists
      
      Subscribers: cfe-commits
      
      Differential Revision: http://reviews.llvm.org/D11555
      
      llvm-svn: 245463
      749adeba
  9. Aug 18, 2015
  10. Jul 18, 2015
    • Eric Fiselier's avatar
      Enable and fix warnings during the build. · 87a82490
      Eric Fiselier authored
      Although CMake adds warning flags, they are ignored in the libc++ headers
      because the headers '#pragma system header' themselves.
      
      This patch disables the system header pragma when building libc++ and fixes
      the warnings that arose.
      
      The warnings fixed were:
      1. <memory> - anonymous structs are a GNU extension
      2. <functional> - anonymous structs are a GNU extension.
      3. <__hash_table> - Embedded preprocessor directives have undefined behavior.
      4. <string> - Definition is missing noexcept from declaration.
      5. <__std_stream> - Unused variable.
      
      llvm-svn: 242623
      87a82490
  11. Jul 16, 2015
  12. Jul 13, 2015
  13. Jul 07, 2015
    • Eric Fiselier's avatar
      [libcxx] Add atomic_support.h header to src that handles needed atomic operations. · 1faf289e
      Eric Fiselier authored
      Summary:
      In some places in libc++ we need to use the `__atomic_*` builtins. This patch adds a header that provides access to those builtins in a uniform way from within the dylib source.
      
      If the compiler building the dylib does not support these builtins then a warning is issued.
      
      Only relaxed loads are needed within the headers. A singe function to do these relaxed loads has been added to `<memory>`.
      
      This patch applies the new atomic builtins to `__shared_count` and `call_once`.
      
      Reviewers: mclow.lists
      
      Subscribers: majnemer, jroelofs, cfe-commits
      
      Differential Revision: http://reviews.llvm.org/D10406
      
      llvm-svn: 241532
      1faf289e
  14. Jul 01, 2015
  15. Jun 19, 2015
  16. Jun 13, 2015
    • Eric Fiselier's avatar
      [libcxx] Fix detection of __is_final. · ee187e24
      Eric Fiselier authored
      Summary: Currently we only enable the use of __is_final(...) with Clang. GCC also provides __is_final(...) since 4.7 in all standard modes. This patch creates the macro _LIBCPP_HAS_IS_FINAL to note the availability of `__is_final`.
      
      Reviewers: danalbert, mclow.lists
      
      Reviewed By: mclow.lists
      
      Subscribers: cfe-commits
      
      Differential Revision: http://reviews.llvm.org/D8795
      
      llvm-svn: 239664
      ee187e24
  17. Jun 02, 2015
  18. May 31, 2015
  19. May 28, 2015
  20. May 27, 2015
  21. May 19, 2015
  22. May 10, 2015
  23. Apr 07, 2015
    • Marshall Clow's avatar
      In many places, there was an #ifdef/#else block that selected one of two... · 1f508014
      Marshall Clow authored
      In many places, there was an #ifdef/#else block that selected one of two implmentations of rebind_alloc based on whether or not we had template aliases. Create a helper struct to encapsulate that bit of logic, and replace all the ifdefs with uses of that struct. No functionality change intented.
      
      llvm-svn: 234296
      1f508014
  24. Mar 31, 2015
    • Eric Fiselier's avatar
      [libcxx] Optimize vectors uninitialized construction of trivial types from an iterator range. · e782178e
      Eric Fiselier authored
      Summary:
      In certain cases vector can use memcpy to construct a range of elements at the back of the vector. We currently don't do this resulting in terrible code gen in non-optimized mode and a
      very large slowdown compared to libstdc++. 
      
      This patch adds a `__construct_forward_range(Allocator, Iter, Iter, _Ptr&)` and `__construct_forward_range(Allocator, Tp*, Tp*, Tp*&)` functions to `allocator_traits` which act similarly to the existing `__construct_forward(...)` functions.
      
      This patch also changes vectors `__construct_at_end(Iter, Iter)` to be `__construct_at_end(Iter, Iter, SizeType)` where SizeType is the size of the range. `__construct_at_end(Iter, Iter, SizeType)` now calls `allocator_traits<Tp>::__construct_forward_range(...)`. 
      
      This patch is based off the design of `__swap_out_circular_buffer(...)` which uses `allocator_traits<Tp>::__construct_forward(...)`.
      
      On my machine this code performs 4x better than the current implementation when tested against `std::vector<int>`. 
      
      
      
      Reviewers: howard.hinnant, titus, kcc, mclow.lists
      
      Reviewed By: mclow.lists
      
      Subscribers: cfe-commits
      
      Differential Revision: http://reviews.llvm.org/D8109
      
      llvm-svn: 233711
      e782178e
  25. Feb 13, 2015
    • Saleem Abdulrasool's avatar
      Handle function name conflicts in _LIBCPP_MSVCRT mode · 8e5ce331
      Saleem Abdulrasool authored
      Visual Studio's SAL extension uses a macro named __deallocate. This macro is
      used pervasively, and gets included through various different ways. This
      conflicts with the similarly named interfaces in libc++. Introduce a undef
      header similar to __undef_min_max to handle this. This fixes a number of errors
      due to the macro replacing the function name.
      
      llvm-svn: 229162
      8e5ce331
  26. Feb 06, 2015
  27. Nov 17, 2014
  28. Nov 11, 2014
  29. Oct 23, 2014
    • Eric Fiselier's avatar
      Add support for "fancy" pointers to shared_ptr. Fixes PR20616 · 319be722
      Eric Fiselier authored
      Summary:
      This patch add support for "fancy pointers/allocators" as well as fixing support for shared_pointer and "minimal" allocators.
      
      Fancy pointers are class types that meet the NullablePointer requirements. In our case they are created by fancy allocators. `support/min_allocator.h` is an archetype for these types.
      
      There are three types of changes made in this patch:
      1. `_Alloc::template rebind<T>::other` -> `__allocator_traits_rebind<_Alloc, T>::type`. This change was made because allocators don't need a rebind template. `__allocator_traits_rebind` is used instead of `allocator_traits::rebind` because use of `allocator_traits::rebind` requires a workaround for when template aliases are unavailable.
      2. `a.deallocate(this, 1)` -> `a.deallocate(pointer_traits<self>::pointer_to(*this), 1)`. This change change is made because fancy pointers aren't always constructible from raw pointers. 
      3. `p.get()` -> `addressof(*p.get())`. Fancy pointers aren't actually a pointer. When we need a "real" pointer we take the address of dereferencing the fancy pointer. This should give us the actual raw pointer.
      
      Test Plan: Tests were added using `support/min_allocator.h` to each affected shared_ptr overload and creation function. These tests can only be executed in C++11 or greater since min_allocator is only available then. A extra test was added for the non-variadic versions of allocate_shared. 
      
      Reviewers: danalbert, mclow.lists
      
      Reviewed By: mclow.lists
      
      Subscribers: cfe-commits
      
      Differential Revision: http://reviews.llvm.org/D4859
      
      llvm-svn: 220469
      319be722
  30. Sep 05, 2014
Loading