From: Andrew Haley Date: Fri, 16 Jan 2004 17:25:26 +0000 (+0000) Subject: locks.h: Don't use in/out memory constraints. X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=a3fe7b56f3f0f153f9524f55bbcae9c65f127691;p=gcc.git locks.h: Don't use in/out memory constraints. 2004-01-16 Andrew Haley * sysdep/x86-64/locks.h: Don't use in/out memory constraints. * sysdep/i386/locks.h: Likewise. From-SVN: r75982 --- diff --git a/libjava/ChangeLog b/libjava/ChangeLog index c16a006c96b..517aea5b2c4 100644 --- a/libjava/ChangeLog +++ b/libjava/ChangeLog @@ -1,3 +1,8 @@ +2004-01-16 Andrew Haley + + * sysdep/x86-64/locks.h: Don't use in/out memory constraints. + * sysdep/i386/locks.h: Likewise. + 2004-01-16 Fernando Nasser * java/awt/EventDispatchThread.java (run): Stop running when diff --git a/libjava/sysdep/i386/locks.h b/libjava/sysdep/i386/locks.h index a9501ae99b2..0e2cd797148 100644 --- a/libjava/sysdep/i386/locks.h +++ b/libjava/sysdep/i386/locks.h @@ -25,8 +25,8 @@ compare_and_swap(volatile obj_addr_t *addr, { char result; __asm__ __volatile__("lock; cmpxchgl %2, %0; setz %1" - : "+m"(*(addr)), "=q"(result) - : "r" (new_val), "a"(old) + : "=m"(*addr), "=q"(result) + : "r" (new_val), "a"(old), "m"(*addr) : "memory"); return (bool) result; } diff --git a/libjava/sysdep/x86-64/locks.h b/libjava/sysdep/x86-64/locks.h index bad6de6dc6f..7fb9bbba0bf 100644 --- a/libjava/sysdep/x86-64/locks.h +++ b/libjava/sysdep/x86-64/locks.h @@ -26,13 +26,13 @@ compare_and_swap(volatile obj_addr_t *addr, obj_addr_t old, obj_addr_t new_val) char result; #ifdef __x86_64__ __asm__ __volatile__("lock; cmpxchgq %2, %0; setz %1" - : "+m"(*(addr)), "=q"(result) - : "r" (new_val), "a"(old) + : "=m"(*(addr)), "=q"(result) + : "r" (new_val), "a"(old), "m"(*addr) : "memory"); #else __asm__ __volatile__("lock; cmpxchgl %2, %0; setz %1" - : "+m"(*(addr)), "=q"(result) - : "r" (new_val), "a"(old) + : "=m"(*(addr)), "=q"(result) + : "r" (new_val), "a"(old), "m"(*addr) : "memory"); #endif return (bool) result;