Diligent Engine API Reference
Win32Atomics.h
1 /* Copyright 2015-2018 Egor Yusov
2  *
3  * Licensed under the Apache License, Version 2.0 (the "License");
4  * you may not use this file except in compliance with the License.
5  * You may obtain a copy of the License at
6  *
7  * http://www.apache.org/licenses/LICENSE-2.0
8  *
9  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
10  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
11  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT OF ANY PROPRIETARY RIGHTS.
12  *
13  * In no event and under no legal theory, whether in tort (including negligence),
14  * contract, or otherwise, unless required by applicable law (such as deliberate
15  * and grossly negligent acts) or agreed to in writing, shall any Contributor be
16  * liable for any damages, including any direct, indirect, special, incidental,
17  * or consequential damages of any character arising as a result of this License or
18  * out of the use or inability to use the software (including but not limited to damages
19  * for loss of goodwill, work stoppage, computer failure or malfunction, or any and
20  * all other commercial damages or losses), even if such Contributor has been advised
21  * of the possibility of such damages.
22  */
23 
24 #pragma once
25 
26 struct WindowsAtomics
27 {
28  // Use windows-specific atomics. Standard atomic eventually call
29  // the same functions, but introduce significant overhead
30 
31  typedef long Long;
32  typedef volatile long AtomicLong;
33  typedef long long Int64;
34  typedef volatile long long AtomicInt64;
35 
36  // The function returns the resulting INCREMENTED value.
37  static Long AtomicIncrement(AtomicLong &Val);
38  static Int64 AtomicIncrement(AtomicInt64 &Val);
39 
40  // The function returns the resulting DECREMENTED value.
41  static Long AtomicDecrement(AtomicLong &Val);
42  static Int64 AtomicDecrement(AtomicInt64 &Val);
43 
44  // The function compares the Destination value with the Comparand value. If the Destination value is equal
45  // to the Comparand value, the Exchange value is stored in the address specified by Destination.
46  // Otherwise, no operation is performed.
47  // The function returns the initial value of the Destination parameter
48  static Long AtomicCompareExchange( AtomicLong &Destination, Long Exchange, Long Comparand);
49 
50  static Long AtomicAdd( AtomicLong &Destination, Long Val);
51  static Int64 AtomicAdd( AtomicInt64 &Destination, Int64 Val);
52 };
int64_t Int64
64-bit signed integer
Definition: BasicTypes.h:33