summary refs log tree commit diff
diff options
context:
space:
mode:
authorUlrich Drepper <drepper@redhat.com>2004-07-18 16:29:30 +0000
committerUlrich Drepper <drepper@redhat.com>2004-07-18 16:29:30 +0000
commitf96b2e4e3441e8dd6f316c88658d7949f4a3e858 (patch)
treec188e68febbc644d3303c283c9ed500658180474
parent1b6840e5acb99031f96544551b021acc74273738 (diff)
downloadglibc-f96b2e4e3441e8dd6f316c88658d7949f4a3e858.tar.gz
glibc-f96b2e4e3441e8dd6f316c88658d7949f4a3e858.tar.xz
glibc-f96b2e4e3441e8dd6f316c88658d7949f4a3e858.zip
Update.
2004-04-16  Andreas Schwab  <schwab@suse.de>

	* sysdeps/ia64/bits/atomic.h: Cast first argument of
	__sync_bool_compare_and_swap_si correct to void*.
-rw-r--r--ChangeLog5
-rw-r--r--sysdeps/ia64/bits/atomic.h12
2 files changed, 11 insertions, 6 deletions
diff --git a/ChangeLog b/ChangeLog
index c1962a1c17..119706a718 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+2004-04-16  Andreas Schwab  <schwab@suse.de>
+
+	* sysdeps/ia64/bits/atomic.h: Cast first argument of
+	__sync_bool_compare_and_swap_si correct to void*.
+
 2004-07-17  Ulrich Drepper  <drepper@redhat.com>
 
 	* iconv/iconv_prog.c (print_known_names): Make machine-readable
diff --git a/sysdeps/ia64/bits/atomic.h b/sysdeps/ia64/bits/atomic.h
index c8b567b69c..e7d312c539 100644
--- a/sysdeps/ia64/bits/atomic.h
+++ b/sysdeps/ia64/bits/atomic.h
@@ -52,11 +52,11 @@ typedef uintmax_t uatomic_max_t;
   (abort (), 0)
 
 #define __arch_compare_and_exchange_bool_32_acq(mem, newval, oldval) \
-  (!__sync_bool_compare_and_swap_si ((int *) (mem), (int) (long) (oldval), \
+  (!__sync_bool_compare_and_swap_si ((void *) (mem), (int) (long) (oldval), \
 				     (int) (long) (newval)))
 
 #define __arch_compare_and_exchange_bool_64_acq(mem, newval, oldval) \
-  (!__sync_bool_compare_and_swap_di ((long *) (mem), (long) (oldval), \
+  (!__sync_bool_compare_and_swap_di ((void *) (mem), (long) (oldval), \
 				     (long) (newval)))
 
 #define __arch_compare_and_exchange_val_8_acq(mem, newval, oldval) \
@@ -66,11 +66,11 @@ typedef uintmax_t uatomic_max_t;
   (abort (), (__typeof (*mem)) 0)
 
 #define __arch_compare_and_exchange_val_32_acq(mem, newval, oldval) \
-  __sync_val_compare_and_swap_si ((int *) (mem), (int) (long) (oldval), \
+  __sync_val_compare_and_swap_si ((void *) (mem), (int) (long) (oldval), \
 				  (int) (long) (newval))
 
 #define __arch_compare_and_exchange_val_64_acq(mem, newval, oldval) \
-  __sync_val_compare_and_swap_di ((long *) (mem), (long) (oldval), \
+  __sync_val_compare_and_swap_di ((void *) (mem), (long) (oldval), \
 				  (long) (newval))
 
 /* Atomically store newval and return the old value.  */
@@ -84,9 +84,9 @@ typedef uintmax_t uatomic_max_t;
 #define atomic_exchange_and_add(mem, value) \
   ({ __typeof (*mem) __result;						      \
      if (sizeof (*mem) == 4)						      \
-       __result = __sync_fetch_and_add_si ((int *) (mem), (int) (value));     \
+       __result = __sync_fetch_and_add_si ((void *) (mem), (int) (value));    \
      else if (sizeof (*mem) == 8)					      \
-       __result = __sync_fetch_and_add_di ((long *) (mem), (long) (value));   \
+       __result = __sync_fetch_and_add_di ((void *) (mem), (long) (value));   \
      else								      \
        abort ();							      \
      __result; })