From 5994c992cc75abb67085190a7fa7848604ea67aa Mon Sep 17 00:00:00 2001
From: rth <rth@138bc75d-0d04-0410-961f-82ee72b054a4>
Date: Sun, 23 Mar 2003 01:38:00 +0000
Subject: [PATCH]         * sysdep/ia64/locks.h: Include ia64intrin.h.        
 (compare_and_swap): Use __sync_bool_compare_and_swap.        
 (compare_and_swap_release): Expose ar.ccv assignment.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@64737 138bc75d-0d04-0410-961f-82ee72b054a4
---
 libjava/ChangeLog           |  6 ++++++
 libjava/sysdep/ia64/locks.h | 21 ++++++++++-----------
 2 files changed, 16 insertions(+), 11 deletions(-)

diff --git a/libjava/ChangeLog b/libjava/ChangeLog
index 3ce4f20b3510..0dc65e5b0efe 100644
--- a/libjava/ChangeLog
+++ b/libjava/ChangeLog
@@ -1,3 +1,9 @@
+2003-03-22  Richard Henderson  <rth@redhat.com>
+
+	* sysdep/ia64/locks.h: Include ia64intrin.h.
+	(compare_and_swap): Use __sync_bool_compare_and_swap.
+	(compare_and_swap_release): Expose ar.ccv assignment.
+
 2003-03-22  Andreas Tobler <a.tobler@schweiz.ch>
 
 	* include/posix.h: Add suffix for darwin dynamic libraries.
diff --git a/libjava/sysdep/ia64/locks.h b/libjava/sysdep/ia64/locks.h
index 6edee83ea99a..bde43b420fbb 100644
--- a/libjava/sysdep/ia64/locks.h
+++ b/libjava/sysdep/ia64/locks.h
@@ -11,6 +11,8 @@ details.  */
 #ifndef __SYSDEP_LOCKS_H__
 #define __SYSDEP_LOCKS_H__
 
+#include <ia64intrin.h>
+
 typedef size_t obj_addr_t;	/* Integer type big enough for object	*/
 				/* address.				*/
 
@@ -19,11 +21,7 @@ compare_and_swap(volatile obj_addr_t *addr,
 	 				      obj_addr_t old,
 					      obj_addr_t new_val) 
 {
-  unsigned long oldval;
-  __asm__ __volatile__("mov ar.ccv=%4 ;; cmpxchg8.acq %0=%1,%2,ar.ccv"
-	      : "=r"(oldval), "=m"(*addr)
-	      : "r"(new_val), "1"(*addr), "r"(old) : "memory");
-  return (oldval == old);
+  return __sync_bool_compare_and_swap (addr, old, new_val);
 }
 
 // The fact that *addr is volatile should cause the compiler to
@@ -31,7 +29,7 @@ compare_and_swap(volatile obj_addr_t *addr,
 inline static void
 release_set(volatile obj_addr_t *addr, obj_addr_t new_val)
 {
-  __asm__ __volatile__(" " : : : "memory");
+  __asm__ __volatile__("" : : : "memory");
   *(addr) = new_val;
 }
 
@@ -40,11 +38,12 @@ compare_and_swap_release(volatile obj_addr_t *addr,
 	 				             obj_addr_t old,
 						     obj_addr_t new_val) 
 {
-  unsigned long oldval;
-  __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);
+  register unsigned long ar_ccv __asm__("ar.ccv") = old;
+  unsigned long out;
+  __asm__ __volatile__("cmpxchg8.rel %0=%1,%2,%4"
+	      : "=r"(out), "=m"(*addr)
+	      : "r"(new_val), "m"(*addr), "d"(ar_ccv) : "memory");
+  return (out == old);
 }
 
 #endif
-- 
GitLab