From efd443581e18067a7080af1944ae2402a1349544 Mon Sep 17 00:00:00 2001 From: chuikingshek Date: Sun, 20 Apr 2025 22:07:42 +0800 Subject: [PATCH] Add Windows ARM64 support --- include/pcg_uint128.hpp | 15 ++++++++++++++- 1 file changed, 14 insertions(+), 1 deletion(-) diff --git a/include/pcg_uint128.hpp b/include/pcg_uint128.hpp index 75c5699..0a173ec 100644 --- a/include/pcg_uint128.hpp +++ b/include/pcg_uint128.hpp @@ -67,7 +67,7 @@ #define PCG_LITTLE_ENDIAN 1 #elif __BIG_ENDIAN__ || _BIG_ENDIAN #define PCG_LITTLE_ENDIAN 0 - #elif __x86_64 || __x86_64__ || _M_X64 || __i386 || __i386__ || _M_IX86 + #elif __x86_64 || __x86_64__ || __i386 || __i386__ || _M_IX86 || _M_AMD64 || _M_ARM64 #define PCG_LITTLE_ENDIAN 1 #elif __powerpc__ || __POWERPC__ || __ppc__ || __PPC__ \ || __m68k__ || __mc68000__ @@ -733,7 +733,13 @@ uint_x4 operator*(const uint_x4& a, #if PCG_64BIT_SPECIALIZATIONS #if defined(_MSC_VER) +#if defined(_M_AMD64) || defined(_M_IX86) #pragma intrinsic(_umul128) +#elif defined(_M_ARM64) +#pragma intrinsic(__umulh) +#else +#error Unsupported architecture +#endif #endif #if defined(_MSC_VER) || __SIZEOF_INT128__ @@ -742,8 +748,15 @@ uint_x4 operator*(const uint_x4& a, const uint_x4& b) { #if defined(_MSC_VER) +#if defined(_M_AMD64) || defined(_M_IX86) uint64_t hi; uint64_t lo = _umul128(a.d.v01, b.d.v01, &hi); +#elif defined(_M_ARM64) + uint64_t lo = a.d.v01 * b.d.v01; + uint64_t hi = __umulh(a.d.v01, b.d.v01); +#else +#error Unsupported architecture +#endif #else __uint128_t r = __uint128_t(a.d.v01) * __uint128_t(b.d.v01); uint64_t lo = uint64_t(r);