gc_locks.h [IA64]: Include ia64intrin.h.
* include/private/gc_locks.h [IA64]: Include ia64intrin.h. (GC_test_and_set): Use __sync_lock_test_and_set. (GC_clear): Use volatile assignment. (GC_compare_and_exchange): Use __sync_bool_compare_and_swap. (GC_memory_write_barrier): Use __sync_synchronize. From-SVN: r64736
This commit is contained in:
parent
086bfb7a46
commit
2298018014
@ -1,3 +1,11 @@
|
|||||||
|
2003-03-22 Richard Henderson <rth@redhat.com>
|
||||||
|
|
||||||
|
* include/private/gc_locks.h [IA64]: Include ia64intrin.h.
|
||||||
|
(GC_test_and_set): Use __sync_lock_test_and_set.
|
||||||
|
(GC_clear): Use volatile assignment.
|
||||||
|
(GC_compare_and_exchange): Use __sync_bool_compare_and_swap.
|
||||||
|
(GC_memory_write_barrier): Use __sync_synchronize.
|
||||||
|
|
||||||
2003-03-12 Andreas Schwab <schwab@suse.de>
|
2003-03-12 Andreas Schwab <schwab@suse.de>
|
||||||
|
|
||||||
* configure.in: Avoid trailing /. in toolexeclibdir.
|
* configure.in: Avoid trailing /. in toolexeclibdir.
|
||||||
|
@ -100,17 +100,13 @@
|
|||||||
# define GC_TEST_AND_SET_DEFINED
|
# define GC_TEST_AND_SET_DEFINED
|
||||||
# endif
|
# endif
|
||||||
# if defined(IA64)
|
# if defined(IA64)
|
||||||
|
# include <ia64intrin.h>
|
||||||
inline static int GC_test_and_set(volatile unsigned int *addr) {
|
inline static int GC_test_and_set(volatile unsigned int *addr) {
|
||||||
long oldval, n = 1;
|
return __sync_lock_test_and_set(addr, 1);
|
||||||
__asm__ __volatile__("xchg4 %0=%1,%2"
|
|
||||||
: "=r"(oldval), "=m"(*addr)
|
|
||||||
: "r"(n), "1"(*addr) : "memory");
|
|
||||||
return oldval;
|
|
||||||
}
|
}
|
||||||
# define GC_TEST_AND_SET_DEFINED
|
# define GC_TEST_AND_SET_DEFINED
|
||||||
/* Should this handle post-increment addressing?? */
|
|
||||||
inline static void GC_clear(volatile unsigned int *addr) {
|
inline static void GC_clear(volatile unsigned int *addr) {
|
||||||
__asm__ __volatile__("st4.rel %0=r0" : "=m" (*addr) : : "memory");
|
*addr = 0;
|
||||||
}
|
}
|
||||||
# define GC_CLEAR_DEFINED
|
# define GC_CLEAR_DEFINED
|
||||||
# endif
|
# endif
|
||||||
@ -326,20 +322,17 @@
|
|||||||
# if defined(IA64)
|
# if defined(IA64)
|
||||||
# if !defined(GENERIC_COMPARE_AND_SWAP)
|
# if !defined(GENERIC_COMPARE_AND_SWAP)
|
||||||
inline static GC_bool GC_compare_and_exchange(volatile GC_word *addr,
|
inline static GC_bool GC_compare_and_exchange(volatile GC_word *addr,
|
||||||
GC_word old, GC_word new_val)
|
GC_word old,
|
||||||
|
GC_word new_val)
|
||||||
{
|
{
|
||||||
unsigned long oldval;
|
return __sync_bool_compare_and_swap (addr, old, new_val);
|
||||||
__asm__ __volatile__("mov ar.ccv=%4 ;; cmpxchg8.rel %0=%1,%2,ar.ccv"
|
|
||||||
: "=r"(oldval), "=m"(*addr)
|
|
||||||
: "r"(new_val), "1"(*addr), "r"(old) : "memory");
|
|
||||||
return (oldval == old);
|
|
||||||
}
|
}
|
||||||
# endif /* !GENERIC_COMPARE_AND_SWAP */
|
# endif /* !GENERIC_COMPARE_AND_SWAP */
|
||||||
# if 0
|
# if 0
|
||||||
/* Shouldn't be needed; we use volatile stores instead. */
|
/* Shouldn't be needed; we use volatile stores instead. */
|
||||||
inline static void GC_memory_write_barrier()
|
inline static void GC_memory_write_barrier()
|
||||||
{
|
{
|
||||||
__asm__ __volatile__("mf" : : : "memory");
|
__sync_synchronize ();
|
||||||
}
|
}
|
||||||
# endif /* 0 */
|
# endif /* 0 */
|
||||||
# endif /* IA64 */
|
# endif /* IA64 */
|
||||||
|
Loading…
Reference in New Issue
Block a user