Date: Sat, 25 Apr 2026 14:20:12 +0000 From: Dimitry Andric <dim@FreeBSD.org> To: src-committers@FreeBSD.org, dev-commits-src-all@FreeBSD.org, dev-commits-src-main@FreeBSD.org Cc: Dimitry Andric <dimitry@andric.com> Subject: git: 5465db314a03 - main - libcxx-compat: revert llvmorg-21-init-8400-g703cfe745b96: Message-ID: <69eccd9c.36aea.69dd3443@gitrepo.freebsd.org>
index | next in thread | raw e-mail
The branch main has been updated by dim: URL: https://cgit.FreeBSD.org/src/commit/?id=5465db314a03c11b15e00f22be1609027dfc152c commit 5465db314a03c11b15e00f22be1609027dfc152c Author: Dimitry Andric <dimitry@andric.com> AuthorDate: 2026-01-05 20:14:13 +0000 Commit: Dimitry Andric <dim@FreeBSD.org> CommitDate: 2026-04-25 14:14:20 +0000 libcxx-compat: revert llvmorg-21-init-8400-g703cfe745b96: [libc++] Replace __libcpp_popcount by __builtin_popcountg (#133937) `__libcpp_popcount` was previously used as a fallback for `__builtin_popcountg` to ensure compatibility with older compilers (Clang 18 and earlier), as `__builtin_popcountg` became available in Clang 19. Now that support for Clang 18 has been officially dropped in #130142, we can now safely replace all instances of `__libcpp_popcount` with `__builtin_popcountg` and eliminate the fallback logic. This is part of making libc++ 21 build with clang 18. PR: 292067 MFC after: 1 month --- .../llvm-project/libcxx/include/__bit/popcount.h | 29 ++++++++++++++++++++++ 1 file changed, 29 insertions(+) diff --git a/contrib/llvm-project/libcxx/include/__bit/popcount.h b/contrib/llvm-project/libcxx/include/__bit/popcount.h index 8d9ba0993848..451b85182e9b 100644 --- a/contrib/llvm-project/libcxx/include/__bit/popcount.h +++ b/contrib/llvm-project/libcxx/include/__bit/popcount.h @@ -11,6 +11,7 @@ #include <__config> #include <__type_traits/integer_traits.h> +#include <limits> #if !defined(_LIBCPP_HAS_NO_PRAGMA_SYSTEM_HEADER) # pragma GCC system_header @@ -21,10 +22,38 @@ _LIBCPP_PUSH_MACROS _LIBCPP_BEGIN_NAMESPACE_STD +template <class _Tp> +[[__nodiscard__]] _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR int __popcount_impl(_Tp __t) _NOEXCEPT { + if _LIBCPP_CONSTEXPR (sizeof(_Tp) <= sizeof(unsigned int)) { + return __builtin_popcount(static_cast<unsigned int>(__t)); + } else if _LIBCPP_CONSTEXPR (sizeof(_Tp) <= sizeof(unsigned long)) { + return __builtin_popcountl(static_cast<unsigned long>(__t)); + } else if _LIBCPP_CONSTEXPR (sizeof(_Tp) <= sizeof(unsigned long long)) { + return __builtin_popcountll(static_cast<unsigned long long>(__t)); + } else { +#if _LIBCPP_STD_VER == 11 + return __t != 0 ? __builtin_popcountll(static_cast<unsigned long long>(__t)) + + std::__popcount_impl<_Tp>(__t >> numeric_limits<unsigned long long>::digits) + : 0; +#else + int __ret = 0; + while (__t != 0) { + __ret += __builtin_popcountll(static_cast<unsigned long long>(__t)); + __t >>= std::numeric_limits<unsigned long long>::digits; + } + return __ret; +#endif + } +} + template <class _Tp> [[__nodiscard__]] _LIBCPP_HIDE_FROM_ABI _LIBCPP_CONSTEXPR int __popcount(_Tp __t) _NOEXCEPT { static_assert(__is_unsigned_integer_v<_Tp>, "__popcount only works with unsigned types"); +#if __has_builtin(__builtin_popcountg) // TODO (LLVM 21): This can be dropped once we only support Clang >= 19. return __builtin_popcountg(__t); +#else + return std::__popcount_impl(__t); +#endif } #if _LIBCPP_STD_VER >= 20home | help
Want to link to this message? Use this
URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?69eccd9c.36aea.69dd3443>
