+2003-05-05 Jakub Jelinek <jakub@redhat.com>
+
+ * sysdeps/ia64/bits/atomic.h (__arch_compare_and_exchange_val_8_acq,
+ __arch_compare_and_exchange_val_16_acq): Cast 0 to mem's type.
+ * sysdeps/powerpc/powerpc32/bits/atomic.h
+ (__arch_compare_and_exchange_val_64_acq): Likewise.
+ * sysdeps/sparc/sparc32/sparcv9/bits/atomic.h
+ (__arch_compare_and_exchange_val_8_acq,
+ __arch_compare_and_exchange_val_16_acq,
+ __arch_compare_and_exchange_val_64_acq): Likewise.
+ * sysdeps/sparc/sparc64/bits/atomic.h
+ (__arch_compare_and_exchange_val_8_acq,
+ __arch_compare_and_exchange_val_16_acq): Likewise.
+ * sysdeps/s390/bits/atomic.h (__arch_compare_and_exchange_val_8_acq,
+ __arch_compare_and_exchange_val_16_acq,
+ __arch_compare_and_exchange_val_64_acq): Likewise.
+ * sysdeps/unix/sysv/linux/sh/bits/atomic.h
+ (__arch_compare_and_exchange_val_64_acq): Likewise.
+ * sysdeps/s390/s390-64/backtrace.c (__backtrace): Add cast to shut
+ up warning.
+ * sysdeps/s390/fpu/fegetenv.c (fegetenv): Likewise.
+
+ * sysdeps/unix/sysv/linux/s390/s390-64/sysdep.h
+ (INLINE_SYSCALL, INTERNAL_SYSCALL_DIRECT, INTERNAL_SYSCALL_SVC0):
+ Return long instead of int.
+ (INTERNAL_SYSCALL_ERROR_P): Cast val to unsigned long, replace
+ 0xfffff001u with -4095UL.
+
2003-05-05 Andreas Jaeger <aj@suse.de>
* sysdeps/x86_64/fpu_control.h: New from i386.
+2003-05-05 Jakub Jelinek <jakub@redhat.com>
+
+ * tests-mbwc/tst_wcsxfrm.c (tst_wcsxfrm): Use %zu instead of %d
+ format specifier when printing ret.
+
2003-04-30 Petter Reinholdtsen <pere@hungry.com>
* tst-fmon.c: Report name of locale if setlocale() fails.
(long) (newval)))
#define __arch_compare_and_exchange_val_8_acq(mem, newval, oldval) \
- (abort (), 0)
+ (abort (), (__typeof (*mem)) 0)
#define __arch_compare_and_exchange_val_16_acq(mem, newval, oldval) \
- (abort (), 0)
+ (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), \
(abort (), 0)
# define __arch_compare_and_exchange_val_64_acq(mem, newval, oldval) \
- (abort (), 0)
+ (abort (), (__typeof (*mem)) 0)
# define __arch_atomic_exchange_64(mem, value) \
({ abort (); (*mem) = (value); })
#define __arch_compare_and_exchange_val_8_acq(mem, newval, oldval) \
- (abort (), 0)
+ (abort (), (__typeof (*mem)) 0)
#define __arch_compare_and_exchange_val_16_acq(mem, newval, oldval) \
- (abort (), 0)
+ (abort (), (__typeof (*mem)) 0)
#define __arch_compare_and_exchange_val_32_acq(mem, newval, oldval) \
({ __typeof (mem) __archmem = (mem); \
implement them by use of the csd instruction. The straightforward
implementation causes warnings so we skip the definition for now. */
# define __arch_compare_and_exchange_val_64_acq(mem, newval, oldval) \
- (abort (), 0)
+ (abort (), (__typeof (*mem)) 0)
#endif
/* Store current floating-point environment.
- Copyright (C) 2000 Free Software Foundation, Inc.
+ Copyright (C) 2000, 2003 Free Software Foundation, Inc.
This file is part of the GNU C Library.
Contributed by Denis Joseph Barrow (djbarrow@de.ibm.com).
no way to find out the ieee instruction pointer if there was no fault. */
_FPU_GETCW (envp->fpc);
envp->ieee_instruction_pointer =
- ptrace (PTRACE_PEEKUSER, getpid (), PT_IEEE_IP);
+ (void *) ptrace (PTRACE_PEEKUSER, getpid (), PT_IEEE_IP);
/* Success. */
return 0;
out of range. */
break;
- array[cnt++] = stack->save_grps[8];
+ array[cnt++] = (void *) stack->save_grps[8];
stack = (struct layout *) stack->back_chain;
}
#define __arch_compare_and_exchange_val_8_acq(mem, newval, oldval) \
- (abort (), 0)
+ (abort (), (__typeof (*mem)) 0)
#define __arch_compare_and_exchange_val_16_acq(mem, newval, oldval) \
- (abort (), 0)
+ (abort (), (__typeof (*mem)) 0)
#define __arch_compare_and_exchange_val_32_acq(mem, newval, oldval) \
({ \
/* This can be implemented if needed. */
#define __arch_compare_and_exchange_val_64_acq(mem, newval, oldval) \
- (abort (), 0)
+ (abort (), (__typeof (*mem)) 0)
#define atomic_exchange(mem, newvalue) \
({ __typeof (*(mem)) __oldval; \
#define __arch_compare_and_exchange_val_8_acq(mem, newval, oldval) \
- (abort (), 0)
+ (abort (), (__typeof (*mem)) 0)
#define __arch_compare_and_exchange_val_16_acq(mem, newval, oldval) \
- (abort (), 0)
+ (abort (), (__typeof (*mem)) 0)
#define __arch_compare_and_exchange_val_32_acq(mem, newval, oldval) \
({ \
#undef INLINE_SYSCALL
#define INLINE_SYSCALL(name, nr, args...) \
({ \
- unsigned int _ret = INTERNAL_SYSCALL (name, , nr, args); \
+ long _ret = INTERNAL_SYSCALL (name, , nr, args); \
if (__builtin_expect (INTERNAL_SYSCALL_ERROR_P (_ret, ), 0)) \
{ \
__set_errno (INTERNAL_SYSCALL_ERRNO (_ret, )); \
_ret = -1; \
} \
- (int) _ret; })
+ _ret; })
#undef INTERNAL_SYSCALL_DECL
#define INTERNAL_SYSCALL_DECL(err) do { } while (0)
#define INTERNAL_SYSCALL_DIRECT(name, err, nr, args...) \
({ \
DECLARGS_##nr(args) \
- register int _ret asm("2"); \
+ register long _ret asm("2"); \
asm volatile ( \
"svc %b1\n\t" \
: "=d" (_ret) \
({ \
DECLARGS_##nr(args) \
register unsigned long _nr asm("1") = (unsigned long)(__NR_##name); \
- register int _ret asm("2"); \
+ register long _ret asm("2"); \
asm volatile ( \
"svc 0\n\t" \
: "=d" (_ret) \
#undef INTERNAL_SYSCALL_ERROR_P
#define INTERNAL_SYSCALL_ERROR_P(val, err) \
- ((unsigned int) (val) >= 0xfffff001u)
+ ((unsigned long) (val) >= -4095UL)
#undef INTERNAL_SYSCALL_ERRNO
#define INTERNAL_SYSCALL_ERRNO(val, err) (-(val))
such an operation. So don't define any code for now. */
# define __arch_compare_and_exchange_val_64_acq(mem, newval, oldval) \
- (abort (), 0)
+ (abort (), (__typeof (*mem)) 0)
#define atomic_exchange_and_add(mem, value) \
({ __typeof (*(mem)) __result, __tmp, __value = (value); \