mirror of
https://github.com/intel/compute-runtime.git
synced 2025-12-22 18:25:05 +08:00
40 lines
1.0 KiB
C
40 lines
1.0 KiB
C
|
|
/*
|
||
|
|
* Copyright (C) 2019-2022 Intel Corporation
|
||
|
|
*
|
||
|
|
* SPDX-License-Identifier: MIT
|
||
|
|
*
|
||
|
|
*/
|
||
|
|
|
||
|
|
#pragma once
|
||
|
|
|
||
|
|
#include <atomic>
|
||
|
|
#include <thread>
|
||
|
|
|
||
|
|
namespace NEO {
|
||
|
|
namespace MultiThreadHelpers {
|
||
|
|
|
||
|
|
template <typename Type>
|
||
|
|
inline bool atomicCompareExchangeWeakSpin(std::atomic<Type> &destination,
|
||
|
|
Type &expectedValue,
|
||
|
|
const Type desiredValue) {
|
||
|
|
const Type currentValue = destination;
|
||
|
|
if (currentValue == expectedValue) {
|
||
|
|
if (destination.compare_exchange_weak(expectedValue, desiredValue)) {
|
||
|
|
return true;
|
||
|
|
}
|
||
|
|
} else {
|
||
|
|
expectedValue = currentValue;
|
||
|
|
}
|
||
|
|
return false;
|
||
|
|
}
|
||
|
|
|
||
|
|
template <typename Type>
|
||
|
|
void interlockedMax(std::atomic<Type> &dest, Type newVal) {
|
||
|
|
Type oldVal = dest;
|
||
|
|
Type maxVal = oldVal < newVal ? newVal : oldVal;
|
||
|
|
while (!atomicCompareExchangeWeakSpin(dest, oldVal, maxVal)) {
|
||
|
|
maxVal = oldVal < newVal ? newVal : oldVal;
|
||
|
|
}
|
||
|
|
}
|
||
|
|
} // namespace MultiThreadHelpers
|
||
|
|
} // namespace NEO
|