UWP: Fix build issue caused by atomic operations
This commit is contained in:
parent
85aa0adeef
commit
f514fabf61
1 changed files with 1 additions and 1 deletions
|
@ -185,7 +185,7 @@ static _ALWAYS_INLINE_ uint64_t _atomic_increment_impl(register uint64_t *pw) {
|
||||||
|
|
||||||
static _ALWAYS_INLINE_ uint64_t _atomic_sub_impl(register uint64_t *pw, register uint64_t val) {
|
static _ALWAYS_INLINE_ uint64_t _atomic_sub_impl(register uint64_t *pw, register uint64_t val) {
|
||||||
|
|
||||||
#if _WIN32_WINNT >= 0x0601 // Windows 7+
|
#if _WIN32_WINNT >= 0x0601 && !defined(UWP_ENABLED) // Windows 7+ except UWP
|
||||||
return InterlockedExchangeSubtract64(pw, val) - val;
|
return InterlockedExchangeSubtract64(pw, val) - val;
|
||||||
#else
|
#else
|
||||||
return InterlockedExchangeAdd64((LONGLONG volatile *)pw, -(int64_t)val) - val;
|
return InterlockedExchangeAdd64((LONGLONG volatile *)pw, -(int64_t)val) - val;
|
||||||
|
|
Loading…
Reference in a new issue