diff options
author | Matthias Klose <doko@ubuntu.com> | 2009-12-13 22:44:27 +0000 |
---|---|---|
committer | Matthias Klose <doko@gcc.gnu.org> | 2009-12-13 22:44:27 +0000 |
commit | 840a82bab8661de20dd5603f123d325d6de5a004 (patch) | |
tree | c905c4a14d4f1d7e89745b13416dac4037c5cab2 /boehm-gc | |
parent | 38fb287358032f46d834287481984cdb997196df (diff) | |
download | gcc-840a82bab8661de20dd5603f123d325d6de5a004.tar.gz |
gc_locks.h: For __ARM_EABI__ define GC_test_and_set GC_clear to use the atomic builtins.
2009-12-09 Matthias Klose <doko@ubuntu.com>
* include/private/gc_locks.h: For __ARM_EABI__ define
GC_test_and_set GC_clear to use the atomic builtins.
From-SVN: r155198
Diffstat (limited to 'boehm-gc')
-rw-r--r-- | boehm-gc/ChangeLog | 5 | ||||
-rw-r--r-- | boehm-gc/include/private/gc_locks.h | 8 |
2 files changed, 12 insertions, 1 deletions
diff --git a/boehm-gc/ChangeLog b/boehm-gc/ChangeLog index dd87502774c..542ddc1e0b6 100644 --- a/boehm-gc/ChangeLog +++ b/boehm-gc/ChangeLog @@ -1,3 +1,8 @@ +2009-12-09 Matthias Klose <doko@ubuntu.com> + + * include/private/gc_locks.h: For __ARM_EABI__ define + GC_test_and_set GC_clear to use the atomic builtins. + 2009-12-05 Ralf Wildenhues <Ralf.Wildenhues@gmx.de> * Makefile.in: Regenerate. diff --git a/boehm-gc/include/private/gc_locks.h b/boehm-gc/include/private/gc_locks.h index d1bb2e4521a..54cfdb92d37 100644 --- a/boehm-gc/include/private/gc_locks.h +++ b/boehm-gc/include/private/gc_locks.h @@ -207,6 +207,12 @@ # define GC_CLEAR_DEFINED # endif /* ALPHA */ # ifdef ARM32 +# define GC_TEST_AND_SET_DEFINED +# if (__GNUC__>4)||((__GNUC__==4)&&(__GNUC_MINOR__>=5)) && defined(__ARM_EABI__) +# define GC_CLEAR_DEFINED +# define GC_test_and_set(addr) __sync_lock_test_and_set (addr, 1) +# define GC_clear(addr) __sync_lock_release (addr) +# else inline static int GC_test_and_set(volatile unsigned int *addr) { int oldval; /* SWP on ARM is very similar to XCHG on x86. Doesn't lock the @@ -219,7 +225,7 @@ : "memory"); return oldval; } -# define GC_TEST_AND_SET_DEFINED +# endif # endif /* ARM32 */ # ifdef CRIS inline static int GC_test_and_set(volatile unsigned int *addr) { |