File indexing completed on 2025-06-30 08:32:19
0001
0002
0003
0004
0005
0006
0007
0008
0009
0010
0011
0012
0013 #ifndef BOOST_UUID_DETAIL_UUID_X86_IPP_INCLUDED_
0014 #define BOOST_UUID_DETAIL_UUID_X86_IPP_INCLUDED_
0015
0016 #include <boost/uuid/detail/endian.hpp>
0017 #include <cstdint>
0018
0019 #if defined(BOOST_UUID_REPORT_IMPLEMENTATION)
0020 #include <boost/config/pragma_message.hpp>
0021
0022 #if defined(BOOST_UUID_USE_AVX10_1)
0023 BOOST_PRAGMA_MESSAGE( "Using uuid_x86.ipp, AVX10.1" )
0024
0025 #elif defined(BOOST_UUID_USE_SSE41)
0026 BOOST_PRAGMA_MESSAGE( "Using uuid_x86.ipp, SSE4.1" )
0027
0028 #elif defined(BOOST_UUID_USE_SSE3)
0029 BOOST_PRAGMA_MESSAGE( "Using uuid_x86.ipp, SSE3" )
0030
0031 #else
0032 BOOST_PRAGMA_MESSAGE( "Using uuid_x86.ipp, SSE2" )
0033
0034 #endif
0035 #endif
0036
0037
0038 #if defined(BOOST_UUID_USE_AVX10_1)
0039 #include <immintrin.h>
0040 #elif defined(BOOST_UUID_USE_SSE41)
0041 #include <smmintrin.h>
0042 #elif defined(BOOST_UUID_USE_SSE3)
0043 #include <pmmintrin.h>
0044 #else
0045 #include <emmintrin.h>
0046 #endif
0047
0048 namespace boost {
0049 namespace uuids {
0050 namespace detail {
0051
0052 BOOST_FORCEINLINE __m128i load_unaligned_si128(const std::uint8_t* p) noexcept
0053 {
0054 return _mm_loadu_si128(reinterpret_cast< const __m128i* >(p));
0055 }
0056
0057 BOOST_FORCEINLINE void compare(uuid const& lhs, uuid const& rhs, std::uint32_t& cmp, std::uint32_t& rcmp) noexcept
0058 {
0059 __m128i mm_left = uuids::detail::load_unaligned_si128(lhs.data);
0060 __m128i mm_right = uuids::detail::load_unaligned_si128(rhs.data);
0061
0062
0063
0064
0065
0066
0067
0068
0069
0070
0071
0072
0073
0074
0075
0076
0077 #if defined(BOOST_UUID_USE_AVX10_1)
0078
0079 __mmask16 k_cmp = _mm_cmplt_epu8_mask(mm_left, mm_right);
0080 __mmask16 k_rcmp = _mm_cmplt_epu8_mask(mm_right, mm_left);
0081
0082 cmp = static_cast< std::uint32_t >(_cvtmask16_u32(k_cmp));
0083 rcmp = static_cast< std::uint32_t >(_cvtmask16_u32(k_rcmp));
0084
0085 #else
0086
0087 const __m128i mm_signs_mask = _mm_xor_si128(mm_left, mm_right);
0088
0089 __m128i mm_cmp = _mm_cmpgt_epi8(mm_right, mm_left), mm_rcmp = _mm_cmpgt_epi8(mm_left, mm_right);
0090
0091 mm_cmp = _mm_xor_si128(mm_signs_mask, mm_cmp);
0092 mm_rcmp = _mm_xor_si128(mm_signs_mask, mm_rcmp);
0093
0094 cmp = static_cast< std::uint32_t >(_mm_movemask_epi8(mm_cmp));
0095 rcmp = static_cast< std::uint32_t >(_mm_movemask_epi8(mm_rcmp));
0096
0097 #endif
0098
0099 cmp = (cmp - 1u) ^ cmp;
0100 rcmp = (rcmp - 1u) ^ rcmp;
0101 }
0102
0103 }
0104
0105 inline bool uuid::is_nil() const noexcept
0106 {
0107 __m128i mm = uuids::detail::load_unaligned_si128(data);
0108 #if defined(BOOST_UUID_USE_SSE41)
0109 return _mm_test_all_zeros(mm, mm) != 0;
0110 #else
0111 mm = _mm_cmpeq_epi32(mm, _mm_setzero_si128());
0112 return _mm_movemask_epi8(mm) == 0xFFFF;
0113 #endif
0114 }
0115
0116 inline void uuid::swap(uuid& rhs) noexcept
0117 {
0118 __m128i mm_this = uuids::detail::load_unaligned_si128(data);
0119 __m128i mm_rhs = uuids::detail::load_unaligned_si128(rhs.data);
0120 _mm_storeu_si128(reinterpret_cast< __m128i* >(rhs.data+0), mm_this);
0121 _mm_storeu_si128(reinterpret_cast< __m128i* >(data+0), mm_rhs);
0122 }
0123
0124 inline bool operator== (uuid const& lhs, uuid const& rhs) noexcept
0125 {
0126 __m128i mm_left = uuids::detail::load_unaligned_si128(lhs.data);
0127 __m128i mm_right = uuids::detail::load_unaligned_si128(rhs.data);
0128
0129 #if defined(BOOST_UUID_USE_SSE41)
0130 __m128i mm = _mm_xor_si128(mm_left, mm_right);
0131 return _mm_test_all_zeros(mm, mm) != 0;
0132 #else
0133 __m128i mm_cmp = _mm_cmpeq_epi32(mm_left, mm_right);
0134 return _mm_movemask_epi8(mm_cmp) == 0xFFFF;
0135 #endif
0136 }
0137
0138 inline bool operator< (uuid const& lhs, uuid const& rhs) noexcept
0139 {
0140 std::uint32_t cmp, rcmp;
0141 uuids::detail::compare(lhs, rhs, cmp, rcmp);
0142 return cmp < rcmp;
0143 }
0144
0145 #if defined(BOOST_UUID_HAS_THREE_WAY_COMPARISON)
0146
0147 inline std::strong_ordering operator<=> (uuid const& lhs, uuid const& rhs) noexcept
0148 {
0149 std::uint32_t cmp, rcmp;
0150 uuids::detail::compare(lhs, rhs, cmp, rcmp);
0151 return cmp <=> rcmp;
0152 }
0153
0154 #endif
0155
0156 }
0157 }
0158
0159 #endif