Skip to content
  1. Apr 22, 2016
  2. Mar 03, 2016
  3. Feb 25, 2016
  4. Jan 11, 2016
  5. 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
  6. Nov 12, 2015
  7. Nov 07, 2015
  8. Oct 25, 2015
  9. Aug 28, 2015
  10. Aug 23, 2015
  11. 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
  12. Aug 18, 2015
  13. 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
  14. Jul 16, 2015
  15. Jul 13, 2015
  16. 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
  17. Jul 01, 2015
  18. Jun 19, 2015
  19. 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
  20. Jun 02, 2015
  21. May 31, 2015
  22. May 28, 2015
  23. May 27, 2015
  24. May 19, 2015
  25. May 10, 2015
  26. 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
  27. 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
  28. 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
  29. Feb 06, 2015
  30. Nov 17, 2014
Loading