summaryrefslogtreecommitdiff
path: root/src/internal
diff options
context:
space:
mode:
authorBobby Bingham <koorogi@koorogi.info>2016-02-22 21:14:23 -0600
committerRich Felker <dalias@aerifal.cx>2016-02-23 13:04:08 -0500
commit225f6a6b5b7173b6655e4f5d49b5b9fea70bf3bb (patch)
tree756a90a9fb1ea21f1142b024408a16a4eb8016f5 /src/internal
parent074e6b3fe3f2ad89b991f3d8ab0932035b312a62 (diff)
downloadmusl-225f6a6b5b7173b6655e4f5d49b5b9fea70bf3bb.tar.gz
allow implementing a_cas_p with pointer-sized ll/sc
No current ports do this, but it will be useful for porting to 64-bit ll/sc architectures, such as mips64 and powerpc64.
Diffstat (limited to 'src/internal')
-rw-r--r--src/internal/atomic.h18
1 files changed, 18 insertions, 0 deletions
diff --git a/src/internal/atomic.h b/src/internal/atomic.h
index 2097247e..6f37d252 100644
--- a/src/internal/atomic.h
+++ b/src/internal/atomic.h
@@ -82,6 +82,23 @@ static inline int a_fetch_or(volatile int *p, int v)
#endif
+#ifdef a_ll_p
+
+#ifndef a_cas_p
+#define a_cas_p a_cas_p
+static inline void *a_cas_p(volatile void *p, void *t, void *s)
+{
+ void *old;
+ a_pre_llsc();
+ do old = a_ll_p(p);
+ while (old==t && !a_sc_p(p, s));
+ a_post_llsc();
+ return old;
+}
+#endif
+
+#endif
+
#ifndef a_cas
#error missing definition of a_cas
#endif
@@ -209,6 +226,7 @@ static inline void a_or_64(volatile uint64_t *p, uint64_t v)
#endif
#ifndef a_cas_p
+typedef char a_cas_p_undefined_but_pointer_not_32bit[-sizeof(char) == 0xffffffff ? 1 : -1];
#define a_cas_p a_cas_p
static inline void *a_cas_p(volatile void *p, void *t, void *s)
{