summaryrefslogtreecommitdiffhomepage
path: root/include
diff options
context:
space:
mode:
authorTyge Løvset <[email protected]>2021-06-08 13:40:58 +0200
committerTyge Løvset <[email protected]>2021-06-08 13:40:58 +0200
commit1d3c1e2e61dcf82d85c279831801544d401fe889 (patch)
tree9cf117bfd9b8f761ef2e9503101bd805bc5d6ae3 /include
parent28596b49a281d69ce2e28e0c5d7cec9620e0dc80 (diff)
downloadSTC-modified-1d3c1e2e61dcf82d85c279831801544d401fe889.tar.gz
STC-modified-1d3c1e2e61dcf82d85c279831801544d401fe889.zip
Cleanup on atomics ops.
Diffstat (limited to 'include')
-rw-r--r--include/stc/csptr.h39
1 files changed, 13 insertions, 26 deletions
diff --git a/include/stc/csptr.h b/include/stc/csptr.h
index 76057b5b..5762c5db 100644
--- a/include/stc/csptr.h
+++ b/include/stc/csptr.h
@@ -53,32 +53,19 @@ int main() {
*/
typedef long atomic_count_t;
#if defined(__GNUC__) || defined(__clang__)
- STC_INLINE void atomic_increment(atomic_count_t* pw) {__atomic_add_fetch(pw, 1, __ATOMIC_SEQ_CST);}
- STC_INLINE atomic_count_t atomic_decrement(atomic_count_t* pw) {return __atomic_sub_fetch(pw, 1, __ATOMIC_SEQ_CST);}
+ #define c_atomic_increment(v) (void)__atomic_add_fetch(v, 1, __ATOMIC_SEQ_CST)
+ #define c_atomic_decrement(v) __atomic_sub_fetch(v, 1, __ATOMIC_SEQ_CST)
#elif defined(_MSC_VER)
#include <intrin.h>
- STC_INLINE void atomic_increment(atomic_count_t* pw) {_InterlockedIncrement(pw);}
- STC_INLINE atomic_count_t atomic_decrement(atomic_count_t* pw) {return _InterlockedDecrement(pw);}
+ #define c_atomic_increment(v) (void)_InterlockedIncrement(v)
+ #define c_atomic_decrement(v) _InterlockedDecrement(v)
#elif defined(__i386__) || defined(__x86_64__)
- STC_INLINE void atomic_increment(atomic_count_t* pw) {
- __asm__ (
- "lock\n\t"
- "incl %0":
- "=m"( *pw ): // ++*pw // output (%0)
- "m"( *pw ): // input (%1)
- "cc" // clobbers
- );
- }
- STC_INLINE atomic_count_t atomic_decrement(atomic_count_t* pw) {
- int r;
- __asm__ __volatile__ (
- "lock\n\t"
- "xadd %1, %0":
- "=m"( *pw ), "=r"( r ): // int r = *pw; // outputs (%0, %1)
- "m"( *pw ), "1"( -1 ): // *pw += -1; // inputs (%2, %3 == %1)
- "memory", "cc" // clobbers
- );
- return r - 1;
+ STC_INLINE void c_atomic_increment(atomic_count_t* v)
+ { __asm__ __volatile__("lock; incq %0" :"=m"(*v) :"m"(*v)); }
+ STC_INLINE atomic_count_t c_atomic_decrement(atomic_count_t* v) {
+ atomic_count_t i = -1;
+ __asm__ __volatile__("lock; xadd %0, %1" :"=r"(i) :"m"(*v), "0"(i));
+ return i - 1;
}
#endif
@@ -126,7 +113,7 @@ typedef long atomic_count_t;
\
STC_INLINE CX \
CX##_clone(CX ptr) { \
- if (ptr.use_count) atomic_increment(ptr.use_count); \
+ if (ptr.use_count) c_atomic_increment(ptr.use_count); \
return ptr; \
} \
\
@@ -139,7 +126,7 @@ typedef long atomic_count_t;
\
STC_INLINE void \
CX##_del(CX* self) { \
- if (self->use_count && atomic_decrement(self->use_count) == 0) { \
+ if (self->use_count && c_atomic_decrement(self->use_count) == 0) { \
valueDel(self->get); \
if (self->get != &((struct CX##_rep_*)self->use_count)->val) c_free(self->get); \
c_free(self->use_count); \
@@ -169,7 +156,7 @@ typedef long atomic_count_t;
STC_INLINE CX##_value_t* \
CX##_copy(CX* self, CX ptr) { \
CX##_del(self); \
- if (ptr.use_count) atomic_increment(ptr.use_count); \
+ if (ptr.use_count) c_atomic_increment(ptr.use_count); \
*self = ptr; \
return self->get; \
} \