diff options
author | kkojima <kkojima@138bc75d-0d04-0410-961f-82ee72b054a4> | 2012-06-14 22:58:05 +0000 |
---|---|---|
committer | kkojima <kkojima@138bc75d-0d04-0410-961f-82ee72b054a4> | 2012-06-14 22:58:05 +0000 |
commit | 88cc9f44dbc8273411f4010cff77d1c9099fb7f9 (patch) | |
tree | 4be410e6e941f2304a98d993d14213775717d8ee | |
parent | 9abfe9e2f5414295397eb1f07899dcaee4da702c (diff) | |
download | gcc-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/ChangeLog | 6 | ||||
-rw-r--r-- | libjava/sysdep/sh/locks.h | 36 |
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 |