18namespace Experimental {
21template <
typename T,
typename...
Ts>
30template <std::
size_t N>
35 static void Load(
const void *ptr,
void *
ret)
39 static void Store(
void *ptr,
void *val)
43 static void Add(
void *ptr,
const void *val)
63 static void Load(
const void *ptr,
void *
ret)
67 static void Store(
void *ptr,
void *val)
71 static void Add(
void *ptr,
const void *val)
91 static void Load(
const void *ptr,
void *
ret)
95 static void Store(
void *ptr,
void *val)
99 static void Add(
void *ptr,
const void *val)
119 static void Load(
const void *ptr,
void *
ret)
123 static void Store(
void *ptr,
void *val)
127 static void Add(
void *ptr,
const void *val);
150 MSVC::AtomicOps<
sizeof(T)>::Load(ptr,
ret);
161 std::atomic_thread_fence(std::memory_order_release);
162 MSVC::AtomicOps<
sizeof(T)>::Store(ptr, val);
184 std::atomic_thread_fence(std::memory_order_acquire);
208 AtomicAddCompareExchangeLoop(
static_cast<__int64 *
>(ptr), *
static_cast<const __int64 *
>(val));
215std::enable_if_t<std::is_integral_v<T>>
AtomicAdd(T *ptr, T val)
220 MSVC::AtomicOps<
sizeof(T)>
::Add(ptr, &val);
225std::enable_if_t<std::is_floating_point_v<T>>
AtomicAdd(T *ptr, T val)
238std::enable_if_t<std::is_arithmetic_v<T>>
AtomicInc(T *ptr)
243template <
typename T,
typename U>
244auto AtomicAdd(T *ptr,
const U &add) ->
decltype(ptr->AtomicAdd(add))
246 return ptr->AtomicAdd(add);
252 return ptr->AtomicInc();
ROOT::Detail::TRangeCast< T, true > TRangeDynCast
TRangeDynCast is an adapter class that allows the typed iteration through a TCollection.
std::enable_if_t< std::is_arithmetic_v< T > > AtomicInc(T *ptr)
void AtomicLoad(const T *ptr, T *ret)
void AtomicStoreRelease(T *ptr, T *val)
bool AtomicCompareExchange(T *ptr, T *expected, T *desired)
bool AtomicCompareExchangeAcquire(T *ptr, T *expected, T *desired)
void AtomicAddCompareExchangeLoop(T *ptr, T val)
std::enable_if_t< std::is_integral_v< T > > AtomicAdd(T *ptr, T val)
TMatrixT< Element > & Add(TMatrixT< Element > &target, Element scalar, const TMatrixT< Element > &source)
Modify addition: target += scalar * source.