From c0d4b93af3ac5155bdec7a1e864b7e410a5ab355 Mon Sep 17 00:00:00 2001 From: Hartmut Kaiser Date: Wed, 11 Oct 2023 12:37:21 -0500 Subject: [PATCH] Fixing compilation problems on 32 Linux systems --- .../concurrency/detail/tagged_ptr_pair.hpp | 32 ++++++++++++++++--- 1 file changed, 27 insertions(+), 5 deletions(-) diff --git a/libs/core/concurrency/include/hpx/concurrency/detail/tagged_ptr_pair.hpp b/libs/core/concurrency/include/hpx/concurrency/detail/tagged_ptr_pair.hpp index cc2afb9f940f..a9d46b3ba02f 100644 --- a/libs/core/concurrency/include/hpx/concurrency/detail/tagged_ptr_pair.hpp +++ b/libs/core/concurrency/include/hpx/concurrency/detail/tagged_ptr_pair.hpp @@ -26,7 +26,7 @@ namespace hpx::lockfree { uint128_type() = default; - constexpr uint128_type(std::uint64_t l, std::uint64_t r) noexcept + constexpr uint128_type(std::size_t l, std::size_t r) noexcept : left(l) , right(r) { @@ -52,11 +52,30 @@ namespace hpx::lockfree { } }; + namespace detail { + + template + struct ptr_mask; // intentionally left unimplemented + + template <> + struct ptr_mask<4> + { + static constexpr std::uint32_t value = 0xffffffff; + }; + + template <> + struct ptr_mask<8> + { + static constexpr std::uint64_t value = 0xffffffffffff; + }; + } // namespace detail + template struct HPX_LOCKFREE_DCAS_ALIGNMENT tagged_ptr_pair { using compressed_ptr_pair_t = uint128_type; - using compressed_ptr_t = std::uint64_t; + // compressed_ptr_t must be of the same size as a pointer + using compressed_ptr_t = std::size_t; using tag_t = std::uint16_t; struct HPX_LOCKFREE_DCAS_ALIGNMENT cast_unit @@ -82,18 +101,21 @@ namespace hpx::lockfree { static constexpr std::size_t left_tag_index = 3; static constexpr std::size_t right_tag_index = 7; - static constexpr compressed_ptr_t ptr_mask = 0xffffffffffff; + static constexpr compressed_ptr_t ptr_mask = + detail::ptr_mask::value; static constexpr Left* extract_left_ptr( compressed_ptr_pair_t i) noexcept { - return hpx::bit_cast(i.left & ptr_mask); + return hpx::bit_cast( + static_cast(i.left & ptr_mask)); } static constexpr Right* extract_right_ptr( compressed_ptr_pair_t i) noexcept { - return hpx::bit_cast(i.right & ptr_mask); + return hpx::bit_cast( + static_cast(i.right & ptr_mask)); } static constexpr tag_t extract_left_tag(