summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorkkojima <kkojima@138bc75d-0d04-0410-961f-82ee72b054a4>2012-06-14 22:58:05 +0000
committerkkojima <kkojima@138bc75d-0d04-0410-961f-82ee72b054a4>2012-06-14 22:58:05 +0000
commit88cc9f44dbc8273411f4010cff77d1c9099fb7f9 (patch)
tree4be410e6e941f2304a98d993d14213775717d8ee
parent9abfe9e2f5414295397eb1f07899dcaee4da702c (diff)
downloadgcc-88cc9f44dbc8273411f4010cff77d1c9099fb7f9.tar.gz
Update sysdep/sh/locks.h with atomic builtins
* sysdep/sh/locks.h (__cas_lock): Remove. (__cas_start_atomic, __cas_end_atomic): Likewise. (compare_and_swap): Call __sync_bool_compare_and_swap. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@188640 138bc75d-0d04-0410-961f-82ee72b054a4
-rw-r--r--libjava/ChangeLog6
-rw-r--r--libjava/sysdep/sh/locks.h36
2 files changed, 7 insertions, 35 deletions
diff --git a/libjava/ChangeLog b/libjava/ChangeLog
index e95c659e2e0..9f7d38fa210 100644
--- a/libjava/ChangeLog
+++ b/libjava/ChangeLog
@@ -1,3 +1,9 @@
+2012-06-14 Kaz Kojima <kkojima@gcc.gnu.org>
+
+ * sysdep/sh/locks.h (__cas_lock): Remove.
+ (__cas_start_atomic, __cas_end_atomic): Likewise.
+ (compare_and_swap): Call __sync_bool_compare_and_swap.
+
2012-05-21 Benjamin Kosnik <bkoz@redhat.com>
PR libstdc++/52700
diff --git a/libjava/sysdep/sh/locks.h b/libjava/sysdep/sh/locks.h
index 9a152fb30e5..727c3aa879c 100644
--- a/libjava/sysdep/sh/locks.h
+++ b/libjava/sysdep/sh/locks.h
@@ -14,45 +14,11 @@ details. */
typedef size_t obj_addr_t; /* Integer type big enough for object */
/* address. */
-static unsigned char __cas_lock = 0;
-
-inline static void
-__cas_start_atomic (void)
-{
- unsigned int val;
-
- do
- __asm__ __volatile__ ("tas.b @%1; movt %0"
- : "=r" (val)
- : "r" (&__cas_lock)
- : "memory");
- while (val == 0);
-}
-
-inline static void
-__cas_end_atomic (void)
-{
- __asm__ __volatile__ (" " : : : "memory");
- __cas_lock = 0;
-}
-
inline static bool
compare_and_swap (volatile obj_addr_t *addr, obj_addr_t old,
obj_addr_t new_val)
{
- bool ret;
-
- __cas_start_atomic ();
- if (*addr != old)
- ret = false;
- else
- {
- *addr = new_val;
- ret = true;
- }
- __cas_end_atomic ();
-
- return ret;
+ return __sync_bool_compare_and_swap (addr, old, new_val);
}
inline static void