Diligent Engine  v.2.4.g
Win32Atomics.hpp
Go to the documentation of this file.
1 /*
2  * Copyright 2019-2021 Diligent Graphics LLC
3  * Copyright 2015-2019 Egor Yusov
4  *
5  * Licensed under the Apache License, Version 2.0 (the "License");
6  * you may not use this file except in compliance with the License.
7  * You may obtain a copy of the License at
8  *
9  * http://www.apache.org/licenses/LICENSE-2.0
10  *
11  * Unless required by applicable law or agreed to in writing, software
12  * distributed under the License is distributed on an "AS IS" BASIS,
13  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14  * See the License for the specific language governing permissions and
15  * limitations under the License.
16  *
17  * In no event and under no legal theory, whether in tort (including negligence),
18  * contract, or otherwise, unless required by applicable law (such as deliberate
19  * and grossly negligent acts) or agreed to in writing, shall any Contributor be
20  * liable for any damages, including any direct, indirect, special, incidental,
21  * or consequential damages of any character arising as a result of this License or
22  * out of the use or inability to use the software (including but not limited to damages
23  * for loss of goodwill, work stoppage, computer failure or malfunction, or any and
24  * all other commercial damages or losses), even if such Contributor has been advised
25  * of the possibility of such damages.
26  */
27 
28 #pragma once
29 
31 {
32  // Use windows-specific atomics. Standard atomic eventually call
33  // the same functions, but introduce significant overhead
34  using Long = long;
35  using AtomicLong = volatile long;
36  using Int64 = long long;
37  using AtomicInt64 = volatile long long;
38 
39  // The function returns the resulting INCREMENTED value.
40  static Long AtomicIncrement(AtomicLong& Val);
41  static Int64 AtomicIncrement(AtomicInt64& Val);
42 
43  // The function returns the resulting DECREMENTED value.
44  static Long AtomicDecrement(AtomicLong& Val);
45  static Int64 AtomicDecrement(AtomicInt64& Val);
46 
47  // The function compares the Destination value with the Comparand value. If the Destination value is equal
48  // to the Comparand value, the Exchange value is stored in the address specified by Destination.
49  // Otherwise, no operation is performed.
50  // The function returns the initial value of the Destination parameter
51  static Long AtomicCompareExchange(AtomicLong& Destination, Long Exchange, Long Comparand);
52 
53  static Long AtomicAdd(AtomicLong& Destination, Long Val);
54  static Int64 AtomicAdd(AtomicInt64& Destination, Int64 Val);
55 };
WindowsAtomics::AtomicInt64
volatile long long AtomicInt64
Definition: Win32Atomics.hpp:37
WindowsAtomics::AtomicIncrement
static Long AtomicIncrement(AtomicLong &Val)
Definition: Win32Atomics.cpp:33
WindowsAtomics::AtomicLong
volatile long AtomicLong
Definition: Win32Atomics.hpp:35
WindowsAtomics
Definition: Win32Atomics.hpp:30
WindowsAtomics::Int64
long long Int64
Definition: Win32Atomics.hpp:36
WindowsAtomics::Long
long Long
Definition: Win32Atomics.hpp:34
WindowsAtomics::AtomicDecrement
static Long AtomicDecrement(AtomicLong &Val)
Definition: Win32Atomics.cpp:44
WindowsAtomics::AtomicCompareExchange
static Long AtomicCompareExchange(AtomicLong &Destination, Long Exchange, Long Comparand)
Definition: Win32Atomics.cpp:54
WindowsAtomics::AtomicAdd
static Long AtomicAdd(AtomicLong &Destination, Long Val)
Definition: Win32Atomics.cpp:59