GRPC Core  4.0.0
 All Data Structures Files Functions Variables Typedefs Enumerations Enumerator Macros Groups Pages
atm_windows.h
Go to the documentation of this file.
1 /*
2  *
3  * Copyright 2015, Google Inc.
4  * All rights reserved.
5  *
6  * Redistribution and use in source and binary forms, with or without
7  * modification, are permitted provided that the following conditions are
8  * met:
9  *
10  * * Redistributions of source code must retain the above copyright
11  * notice, this list of conditions and the following disclaimer.
12  * * Redistributions in binary form must reproduce the above
13  * copyright notice, this list of conditions and the following disclaimer
14  * in the documentation and/or other materials provided with the
15  * distribution.
16  * * Neither the name of Google Inc. nor the names of its
17  * contributors may be used to endorse or promote products derived from
18  * this software without specific prior written permission.
19  *
20  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
21  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
22  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
23  * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
24  * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
25  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
26  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
27  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
28  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
29  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
30  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31  *
32  */
33 
34 #ifndef GRPC_IMPL_CODEGEN_ATM_WINDOWS_H
35 #define GRPC_IMPL_CODEGEN_ATM_WINDOWS_H
36 
39 
40 typedef intptr_t gpr_atm;
41 #define GPR_ATM_MAX INTPTR_MAX
42 
43 #define gpr_atm_full_barrier MemoryBarrier
44 
45 static __inline gpr_atm gpr_atm_acq_load(const gpr_atm *p) {
46  gpr_atm result = *p;
48  return result;
49 }
50 
51 static __inline gpr_atm gpr_atm_no_barrier_load(const gpr_atm *p) {
52  /* TODO(dklempner): Can we implement something better here? */
53  return gpr_atm_acq_load(p);
54 }
55 
56 static __inline void gpr_atm_rel_store(gpr_atm *p, gpr_atm value) {
58  *p = value;
59 }
60 
61 static __inline void gpr_atm_no_barrier_store(gpr_atm *p, gpr_atm value) {
62  /* TODO(ctiller): Can we implement something better here? */
63  gpr_atm_rel_store(p, value);
64 }
65 
66 static __inline int gpr_atm_no_barrier_cas(gpr_atm *p, gpr_atm o, gpr_atm n) {
69 #ifdef GPR_ARCH_64
70  return o == (gpr_atm)InterlockedCompareExchangeAcquire64(
71  (volatile LONGLONG *)p, (LONGLONG)n, (LONGLONG)o);
72 #else
73  return o == (gpr_atm)InterlockedCompareExchangeAcquire((volatile LONG *)p,
74  (LONG)n, (LONG)o);
75 #endif
76 }
77 
78 static __inline int gpr_atm_acq_cas(gpr_atm *p, gpr_atm o, gpr_atm n) {
79 #ifdef GPR_ARCH_64
80  return o == (gpr_atm)InterlockedCompareExchangeAcquire64(
81  (volatile LONGLONG *)p, (LONGLONG)n, (LONGLONG)o);
82 #else
83  return o == (gpr_atm)InterlockedCompareExchangeAcquire((volatile LONG *)p,
84  (LONG)n, (LONG)o);
85 #endif
86 }
87 
88 static __inline int gpr_atm_rel_cas(gpr_atm *p, gpr_atm o, gpr_atm n) {
89 #ifdef GPR_ARCH_64
90  return o == (gpr_atm)InterlockedCompareExchangeRelease64(
91  (volatile LONGLONG *)p, (LONGLONG)n, (LONGLONG)o);
92 #else
93  return o == (gpr_atm)InterlockedCompareExchangeRelease((volatile LONG *)p,
94  (LONG)n, (LONG)o);
95 #endif
96 }
97 
98 static __inline int gpr_atm_full_cas(gpr_atm *p, gpr_atm o, gpr_atm n) {
99 #ifdef GPR_ARCH_64
100  return o == (gpr_atm)InterlockedCompareExchange64((volatile LONGLONG *)p,
101  (LONGLONG)n, (LONGLONG)o);
102 #else
103  return o == (gpr_atm)InterlockedCompareExchange((volatile LONG *)p, (LONG)n,
104  (LONG)o);
105 #endif
106 }
107 
108 static __inline gpr_atm gpr_atm_no_barrier_fetch_add(gpr_atm *p,
109  gpr_atm delta) {
111  gpr_atm old;
112  do {
113  old = *p;
114  } while (!gpr_atm_no_barrier_cas(p, old, old + delta));
115  return old;
116 }
117 
118 static __inline gpr_atm gpr_atm_full_fetch_add(gpr_atm *p, gpr_atm delta) {
120  gpr_atm old;
121 #ifdef GPR_ARCH_64
122  do {
123  old = *p;
124  } while (old != (gpr_atm)InterlockedCompareExchange64((volatile LONGLONG *)p,
125  (LONGLONG)old + delta,
126  (LONGLONG)old));
127 #else
128  do {
129  old = *p;
130  } while (old != (gpr_atm)InterlockedCompareExchange(
131  (volatile LONG *)p, (LONG)old + delta, (LONG)old));
132 #endif
133  return old;
134 }
135 
136 static __inline gpr_atm gpr_atm_full_xchg(gpr_atm *p, gpr_atm n) {
137  return (gpr_atm)InterlockedExchangePointer((PVOID *)p, (PVOID)n);
138 }
139 
140 #endif /* GRPC_IMPL_CODEGEN_ATM_WINDOWS_H */
#define gpr_atm_no_barrier_load(p)
Definition: atm_gcc_atomic.h:61
#define gpr_atm_full_fetch_add(p, delta)
Definition: atm_gcc_atomic.h:70
#define gpr_atm_no_barrier_store(p, value)
Definition: atm_gcc_atomic.h:64
#define gpr_atm_acq_cas(p, o, n)
Definition: atm_gcc_sync.h:85
#define gpr_atm_full_xchg(p, n)
Definition: atm_gcc_atomic.h:94
#define gpr_atm_full_cas(p, o, n)
Definition: atm_gcc_sync.h:87
#define gpr_atm_rel_cas(p, o, n)
Definition: atm_gcc_sync.h:86
#define gpr_atm_acq_load(p)
Definition: atm_gcc_atomic.h:60
#define gpr_atm_rel_store(p, value)
Definition: atm_gcc_atomic.h:62
#define gpr_atm_no_barrier_fetch_add(p, delta)
Definition: atm_gcc_atomic.h:67
intptr_t gpr_atm
Definition: atm_gcc_atomic.h:41
#define gpr_atm_no_barrier_cas(p, o, n)
Definition: atm_gcc_sync.h:84
intptr_t gpr_atm
Win32 variant of atm_platform.h.
Definition: atm_windows.h:40
#define gpr_atm_full_barrier
Definition: atm_windows.h:43