2003-01-06  Philip Blundell  <philb@gnu.org>

	* sysdeps/unix/arm/sysdep.S (syscall_error): Optimise a little.
	[__LIBC_REENTRANT]: Unify PIC and non-PIC cases.

	* sysdeps/unix/sysv/linux/arm/sysdep.h (PSEUDO): Remove .type
	directive.
	(PSEUDO_RET): Use SYSCALL_ERROR in place of __syscall_error.
	(SYSCALL_ERROR): New.
	(SYSCALL_ERROR_HANDLER) [NOT_IN_libc]: Provide local copy of error
	handling code.
	(INTERNAL_SYSCALL): Define.
	(INLINE_SYSCALL): Use it.
	(INTERNAL_SYSCALL_ERROR_P, INTERNAL_SYSCALL_ERRNO): Define.
	* sysdeps/unix/sysv/linux/arm/socket.S (__socket): Use
	SYSCALL_ERROR in place of __syscall_error.

2003-01-07  Jakub Jelinek  <jakub@redhat.com>

	* sysdeps/ia64/bits/byteswap.h [__GNUC__ >= 2] (__bswap_16,
	__bswap_32, __bswap_64): Put x into temporary variable
	to avoid warnings.
	[!__GNUC__] (__bswap_16, __bswap_32, __bswap_64): Change into static
	(inline) functions.
	* sysdeps/s390/bits/byteswap.h [__GNUC__ >= 2] (__bswap_16,
	__bswap_32, __bswap_64): Put x into temporary variable
	to avoid warnings.
	[!__GNUC__] (__bswap_16, __bswap_32, __bswap_64): Change into static
	(inline) functions.
	* sysdeps/i386/bits/byteswap.h [!__GNUC__] (__bswap_16, __bswap_32):
	Likewise.

2003-01-07  Jakub Jelinek  <jakub@redhat.com>

	* sysdeps/unix/sysv/linux/alpha/adjtime.c (ntp_adjtime): New weak
	alias.
This commit is contained in:
Ulrich Drepper 2003-01-08 00:22:00 +00:00
parent e9c7764ec9
commit b5facfdac0
12 changed files with 192 additions and 88 deletions

View File

@ -1,3 +1,40 @@
2003-01-06 Philip Blundell <philb@gnu.org>
* sysdeps/unix/arm/sysdep.S (syscall_error): Optimise a little.
[__LIBC_REENTRANT]: Unify PIC and non-PIC cases.
* sysdeps/unix/sysv/linux/arm/sysdep.h (PSEUDO): Remove .type
directive.
(PSEUDO_RET): Use SYSCALL_ERROR in place of __syscall_error.
(SYSCALL_ERROR): New.
(SYSCALL_ERROR_HANDLER) [NOT_IN_libc]: Provide local copy of error
handling code.
(INTERNAL_SYSCALL): Define.
(INLINE_SYSCALL): Use it.
(INTERNAL_SYSCALL_ERROR_P, INTERNAL_SYSCALL_ERRNO): Define.
* sysdeps/unix/sysv/linux/arm/socket.S (__socket): Use
SYSCALL_ERROR in place of __syscall_error.
2003-01-07 Jakub Jelinek <jakub@redhat.com>
* sysdeps/ia64/bits/byteswap.h [__GNUC__ >= 2] (__bswap_16,
__bswap_32, __bswap_64): Put x into temporary variable
to avoid warnings.
[!__GNUC__] (__bswap_16, __bswap_32, __bswap_64): Change into static
(inline) functions.
* sysdeps/s390/bits/byteswap.h [__GNUC__ >= 2] (__bswap_16,
__bswap_32, __bswap_64): Put x into temporary variable
to avoid warnings.
[!__GNUC__] (__bswap_16, __bswap_32, __bswap_64): Change into static
(inline) functions.
* sysdeps/i386/bits/byteswap.h [!__GNUC__] (__bswap_16, __bswap_32):
Likewise.
2003-01-07 Jakub Jelinek <jakub@redhat.com>
* sysdeps/unix/sysv/linux/alpha/adjtime.c (ntp_adjtime): New weak
alias.
2003-01-07 Jakub Jelinek <jakub@redhat.com> 2003-01-07 Jakub Jelinek <jakub@redhat.com>
* elf/rtld.c (_rtld_global): Remove _dl_dynamic_weak initializer. * elf/rtld.c (_rtld_global): Remove _dl_dynamic_weak initializer.

View File

@ -1,5 +1,7 @@
2003-01-07 Jakub Jelinek <jakub@redhat.com> 2003-01-07 Jakub Jelinek <jakub@redhat.com>
* pthreadP.h (__pthread_cond_timedwait): Add prototype.
* sysdeps/unix/sysv/linux/i386/dl-sysdep.h * sysdeps/unix/sysv/linux/i386/dl-sysdep.h
(RTLD_CORRECT_DYNAMIC_WEAK): Remove. (RTLD_CORRECT_DYNAMIC_WEAK): Remove.
(DL_SYSINFO_IMPLEMENTATION): Change into .text section and back. (DL_SYSINFO_IMPLEMENTATION): Change into .text section and back.

View File

@ -260,6 +260,9 @@ extern int __pthread_cond_init (pthread_cond_t *cond,
const pthread_condattr_t *cond_attr); const pthread_condattr_t *cond_attr);
extern int __pthread_cond_signal (pthread_cond_t *cond); extern int __pthread_cond_signal (pthread_cond_t *cond);
extern int __pthread_cond_wait (pthread_cond_t *cond, pthread_mutex_t *mutex); extern int __pthread_cond_wait (pthread_cond_t *cond, pthread_mutex_t *mutex);
extern int __pthread_cond_timedwait (pthread_cond_t *cond,
pthread_mutex_t *mutex,
const struct timespec *abstime);
extern int __pthread_condattr_destroy (pthread_condattr_t *attr); extern int __pthread_condattr_destroy (pthread_condattr_t *attr);
extern int __pthread_condattr_init (pthread_condattr_t *attr); extern int __pthread_condattr_init (pthread_condattr_t *attr);
extern int __pthread_key_create (pthread_key_t *key, void (*destr) (void *)); extern int __pthread_key_create (pthread_key_t *key, void (*destr) (void *));

View File

@ -1,4 +1,8 @@
2003-01-05 Ulrich Drepper <drepper@redhat.com> 2003-01-07 Jakub Jelinek <jakub@redhat.com>
* td_ta_event_getmsg.c: Include assert.h.
-2003-01-05 Ulrich Drepper <drepper@redhat.com>
* Makefile (libthread_db.so-no-z-defs): Define. * Makefile (libthread_db.so-no-z-defs): Define.

View File

@ -1,5 +1,5 @@
/* Retrieve event. /* Retrieve event.
Copyright (C) 1999, 2001, 2002 Free Software Foundation, Inc. Copyright (C) 1999, 2001, 2002, 2003 Free Software Foundation, Inc.
This file is part of the GNU C Library. This file is part of the GNU C Library.
Contributed by Ulrich Drepper <drepper@redhat.com>, 1999. Contributed by Ulrich Drepper <drepper@redhat.com>, 1999.
@ -18,6 +18,7 @@
Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
02111-1307 USA. */ 02111-1307 USA. */
#include <assert.h>
#include <stddef.h> #include <stddef.h>
#include <string.h> #include <string.h>

View File

@ -28,8 +28,9 @@
#define __bswap_constant_16(x) \ #define __bswap_constant_16(x) \
((((x) >> 8) & 0xff) | (((x) & 0xff) << 8)) ((((x) >> 8) & 0xff) | (((x) & 0xff) << 8))
#if defined __GNUC__ && __GNUC__ >= 2 #ifdef __GNUC__
# define __bswap_16(x) \ # if __GNUC__ >= 2
# define __bswap_16(x) \
(__extension__ \ (__extension__ \
({ register unsigned short int __v, __x = (x); \ ({ register unsigned short int __v, __x = (x); \
if (__builtin_constant_p (__x)) \ if (__builtin_constant_p (__x)) \
@ -40,24 +41,31 @@
: "0" (__x) \ : "0" (__x) \
: "cc"); \ : "cc"); \
__v; })) __v; }))
#else # else
/* This is better than nothing. */ /* This is better than nothing. */
# define __bswap_16(x) \ # define __bswap_16(x) \
(__extension__ \ (__extension__ \
({ register unsigned short int __x = (x); __bswap_constant_16 (__x); })) ({ register unsigned short int __x = (x); __bswap_constant_16 (__x); }))
# endif
#else
static __inline unsigned short int
__bswap_16 (unsigned short int __bsx)
{
return __bswap_constant_16 (__bsx);
}
#endif #endif
/* Swap bytes in 32 bit value. */ /* Swap bytes in 32 bit value. */
#define __bswap_constant_32(x) \ #define __bswap_constant_32(x) \
((((x) & 0xff000000) >> 24) | (((x) & 0x00ff0000) >> 8) | \ ((((x) & 0xff000000) >> 24) | (((x) & 0x00ff0000) >> 8) | \
(((x) & 0x0000ff00) << 8) | (((x) & 0x000000ff) << 24)) (((x) & 0x0000ff00) << 8) | (((x) & 0x000000ff) << 24))
#if defined __GNUC__ && __GNUC__ >= 2 #ifdef __GNUC__
# if __GNUC__ >= 2
/* To swap the bytes in a word the i486 processors and up provide the /* To swap the bytes in a word the i486 processors and up provide the
`bswap' opcode. On i386 we have to use three instructions. */ `bswap' opcode. On i386 we have to use three instructions. */
# if !defined __i486__ && !defined __pentium__ && !defined __pentiumpro__ # if !defined __i486__ && !defined __pentium__ && !defined __pentiumpro__
# define __bswap_32(x) \ # define __bswap_32(x) \
(__extension__ \ (__extension__ \
({ register unsigned int __v, __x = (x); \ ({ register unsigned int __v, __x = (x); \
if (__builtin_constant_p (__x)) \ if (__builtin_constant_p (__x)) \
@ -70,8 +78,8 @@
: "0" (__x) \ : "0" (__x) \
: "cc"); \ : "cc"); \
__v; })) __v; }))
# else # else
# define __bswap_32(x) \ # define __bswap_32(x) \
(__extension__ \ (__extension__ \
({ register unsigned int __v, __x = (x); \ ({ register unsigned int __v, __x = (x); \
if (__builtin_constant_p (__x)) \ if (__builtin_constant_p (__x)) \
@ -79,11 +87,18 @@
else \ else \
__asm__ ("bswap %0" : "=r" (__v) : "0" (__x)); \ __asm__ ("bswap %0" : "=r" (__v) : "0" (__x)); \
__v; })) __v; }))
# endif # endif
#else # else
# define __bswap_32(x) \ # define __bswap_32(x) \
(__extension__ \ (__extension__ \
({ register unsigned int __x = (x); __bswap_constant_32 (__x); })) ({ register unsigned int __x = (x); __bswap_constant_32 (__x); }))
# endif
#else
static __inline unsigned int
__bswap_32 (unsigned int __bsx)
{
return __bswap_constant_32 (__bsx);
}
#endif #endif

View File

@ -1,5 +1,5 @@
/* Macros to swap the order of bytes in integer values. /* Macros to swap the order of bytes in integer values.
Copyright (C) 1997, 1998, 2000, 2002 Free Software Foundation, Inc. Copyright (C) 1997, 1998, 2000, 2002, 2003 Free Software Foundation, Inc.
This file is part of the GNU C Library. This file is part of the GNU C Library.
The GNU C Library is free software; you can redistribute it and/or The GNU C Library is free software; you can redistribute it and/or
@ -31,18 +31,22 @@
#if defined __GNUC__ && __GNUC__ >= 2 #if defined __GNUC__ && __GNUC__ >= 2
# define __bswap_16(x) \ # define __bswap_16(x) \
(__extension__ \ (__extension__ \
({ register unsigned short int __v; \ ({ register unsigned short int __v, __x = (x); \
if (__builtin_constant_p (x)) \ if (__builtin_constant_p (x)) \
__v = __bswap_constant_16 (x); \ __v = __bswap_constant_16 (__x); \
else \ else \
__asm__ __volatile__ ("shl %0 = %1, 48 ;;" \ __asm__ __volatile__ ("shl %0 = %1, 48 ;;" \
"mux1 %0 = %0, @rev ;;" \ "mux1 %0 = %0, @rev ;;" \
: "=r" (__v) \ : "=r" (__v) \
: "r" ((unsigned short int) (x))); \ : "r" ((unsigned short int) (__x))); \
__v; })) __v; }))
#else #else
/* This is better than nothing. */ /* This is better than nothing. */
# define __bswap_16(x) __bswap_constant_16 (x) static __inline unsigned short int
__bswap_16 (unsigned short int __bsx)
{
return __bswap_constant_16 (__bsx);
}
#endif #endif
@ -54,17 +58,21 @@
#if defined __GNUC__ && __GNUC__ >= 2 #if defined __GNUC__ && __GNUC__ >= 2
# define __bswap_32(x) \ # define __bswap_32(x) \
(__extension__ \ (__extension__ \
({ register unsigned int __v; \ ({ register unsigned int __v, __x = (x); \
if (__builtin_constant_p (x)) \ if (__builtin_constant_p (x)) \
__v = __bswap_constant_32 (x); \ __v = __bswap_constant_32 (__x); \
else \ else \
__asm__ __volatile__ ("shl %0 = %1, 32 ;;" \ __asm__ __volatile__ ("shl %0 = %1, 32 ;;" \
"mux1 %0 = %0, @rev ;;" \ "mux1 %0 = %0, @rev ;;" \
: "=r" (__v) \ : "=r" (__v) \
: "r" ((unsigned int) (x))); \ : "r" ((unsigned int) (__x))); \
__v; })) __v; }))
#else #else
# define __bswap_32(x) __bswap_constant_32 (x) static __inline unsigned int
__bswap_32 (unsigned int __bsx)
{
return __bswap_constant_32 (__bsx);
}
#endif #endif
@ -82,17 +90,21 @@
#if defined __GNUC__ && __GNUC__ >= 2 #if defined __GNUC__ && __GNUC__ >= 2
# define __bswap_64(x) \ # define __bswap_64(x) \
(__extension__ \ (__extension__ \
({ register unsigned long int __v; \ ({ register unsigned long int __v, __x = (x); \
if (__builtin_constant_p (x)) \ if (__builtin_constant_p (x)) \
__v = __bswap_constant_64 (x); \ __v = __bswap_constant_64 (__x); \
else \ else \
__asm__ __volatile__ ("mux1 %0 = %1, @rev ;;" \ __asm__ __volatile__ ("mux1 %0 = %1, @rev ;;" \
: "=r" (__v) \ : "=r" (__v) \
: "r" ((unsigned long int) (x))); \ : "r" ((unsigned long int) (__x))); \
__v; })) __v; }))
#else #else
# define __bswap_64(x) __bswap_constant_64 (x) static __inline unsigned long int
__bswap_64 (unsigned long int __bsx)
{
return __bswap_constant_64 (__bsx);
}
#endif #endif
#endif /* _BITS_BYTESWAP_H */ #endif /* _BITS_BYTESWAP_H */

View File

@ -1,5 +1,5 @@
/* Macros to swap the order of bytes in integer values. s390 version. /* Macros to swap the order of bytes in integer values. s390 version.
Copyright (C) 2000, 2001, 2002 Free Software Foundation, Inc. Copyright (C) 2000, 2001, 2002, 2003 Free Software Foundation, Inc.
Contributed by Martin Schwidefsky (schwidefsky@de.ibm.com). Contributed by Martin Schwidefsky (schwidefsky@de.ibm.com).
This file is part of the GNU C Library. This file is part of the GNU C Library.
@ -35,11 +35,11 @@
# if __WORDSIZE == 64 # if __WORDSIZE == 64
# define __bswap_16(x) \ # define __bswap_16(x) \
(__extension__ \ (__extension__ \
({ unsigned short int __v; \ ({ unsigned short int __v, __x = (x); \
if (__builtin_constant_p (x)) \ if (__builtin_constant_p (x)) \
__v = __bswap_constant_16 (x); \ __v = __bswap_constant_16 (__x); \
else { \ else { \
unsigned short int __tmp = (unsigned short int) (x); \ unsigned short int __tmp = (unsigned short int) (__x); \
__asm__ __volatile__ ( \ __asm__ __volatile__ ( \
"lrvh %0,%1" \ "lrvh %0,%1" \
: "=&d" (__v) : "m" (__tmp) ); \ : "=&d" (__v) : "m" (__tmp) ); \
@ -48,11 +48,11 @@
# else # else
# define __bswap_16(x) \ # define __bswap_16(x) \
(__extension__ \ (__extension__ \
({ unsigned short int __v; \ ({ unsigned short int __v, __x = (x); \
if (__builtin_constant_p (x)) \ if (__builtin_constant_p (x)) \
__v = __bswap_constant_16 (x); \ __v = __bswap_constant_16 (__x); \
else { \ else { \
unsigned short int __tmp = (unsigned short int) (x); \ unsigned short int __tmp = (unsigned short int) (__x); \
__asm__ __volatile__ ( \ __asm__ __volatile__ ( \
"sr %0,%0\n" \ "sr %0,%0\n" \
"la 1,%1\n" \ "la 1,%1\n" \
@ -64,7 +64,11 @@
# endif # endif
#else #else
/* This is better than nothing. */ /* This is better than nothing. */
#define __bswap_16(x) __bswap_constant_16 (x) static __inline unsigned short int
__bswap_16 (unsigned short int __bsx)
{
return __bswap_constant_16 (__bsx);
}
#endif #endif
/* Swap bytes in 32 bit value. */ /* Swap bytes in 32 bit value. */
@ -76,11 +80,11 @@
# if __WORDSIZE == 64 # if __WORDSIZE == 64
# define __bswap_32(x) \ # define __bswap_32(x) \
(__extension__ \ (__extension__ \
({ unsigned int __v; \ ({ unsigned int __v, __x = (x); \
if (__builtin_constant_p (x)) \ if (__builtin_constant_p (x)) \
__v = __bswap_constant_32 (x); \ __v = __bswap_constant_32 (__x); \
else { \ else { \
unsigned int __tmp = (unsigned int) (x); \ unsigned int __tmp = (unsigned int) (__x); \
__asm__ __volatile__ ( \ __asm__ __volatile__ ( \
"lrv %0,%1" \ "lrv %0,%1" \
: "=&d" (__v) : "m" (__tmp)); \ : "=&d" (__v) : "m" (__tmp)); \
@ -89,11 +93,11 @@
# else # else
# define __bswap_32(x) \ # define __bswap_32(x) \
(__extension__ \ (__extension__ \
({ unsigned int __v; \ ({ unsigned int __v, __x = (x); \
if (__builtin_constant_p (x)) \ if (__builtin_constant_p (x)) \
__v = __bswap_constant_32 (x); \ __v = __bswap_constant_32 (__x); \
else { \ else { \
unsigned int __tmp = (unsigned int) (x); \ unsigned int __tmp = (unsigned int) (__x); \
__asm__ __volatile__ ( \ __asm__ __volatile__ ( \
"la 1,%1\n" \ "la 1,%1\n" \
"icm %0,8,3(1)\n" \ "icm %0,8,3(1)\n" \
@ -105,7 +109,11 @@
__v; })) __v; }))
# endif # endif
#else #else
# define __bswap_32(x) __bswap_constant_32 (x) static __inline unsigned int
__bswap_32 (unsigned int __bsx)
{
return __bswap_constant_32 (__bsx);
}
#endif #endif
/* Swap bytes in 64 bit value. */ /* Swap bytes in 64 bit value. */
@ -119,11 +127,11 @@
# if __WORDSIZE == 64 # if __WORDSIZE == 64
# define __bswap_64(x) \ # define __bswap_64(x) \
(__extension__ \ (__extension__ \
({ unsigned long __w; \ ({ unsigned long __w, __x = (x); \
if (__builtin_constant_p (x)) \ if (__builtin_constant_p (x)) \
__w = __bswap_constant_64 (x); \ __w = __bswap_constant_64 (__x); \
else { \ else { \
unsigned long __tmp = (unsigned long) (x); \ unsigned long __tmp = (unsigned long) (__x); \
__asm__ __volatile__ ( \ __asm__ __volatile__ ( \
"lrvg %0,%1" \ "lrvg %0,%1" \
: "=&d" (__w) : "m" (__tmp)); \ : "=&d" (__w) : "m" (__tmp)); \
@ -140,7 +148,11 @@
__r.__ll; }) __r.__ll; })
# endif # endif
#else #else
# define __bswap_64(x) __bswap_constant_64 (x) static __inline unsigned long long int
__bswap_64 (unsigned long long int __bsx)
{
return __bswap_constant_64 (__bsx);
}
#endif #endif
#endif /* _BITS_BYTESWAP_H */ #endif /* _BITS_BYTESWAP_H */

View File

@ -1,4 +1,4 @@
/* Copyright (C) 1991,92,93,94,95,96,97,98 Free Software Foundation, Inc. /* Copyright (C) 1991,92,93,94,95,96,97,98,2002,03 Free Software Foundation, Inc.
This file is part of the GNU C Library. This file is part of the GNU C Library.
The GNU C Library is free software; you can redistribute it and/or The GNU C Library is free software; you can redistribute it and/or
@ -37,42 +37,34 @@ syscall_error:
moveq r0, $EAGAIN /* Yes; translate it to EAGAIN. */ moveq r0, $EAGAIN /* Yes; translate it to EAGAIN. */
#endif #endif
#ifndef PIC
ldr r1, _errno_loc
str r0, [r1]
#ifdef _LIBC_REENTRANT #ifdef _LIBC_REENTRANT
stmdb sp!, {r0, lr} str lr, [sp, #-4]!
/* put another copy of r0 at a specific errno location */ str r0, [sp, #-4]!
bl C_SYMBOL_NAME(__errno_location) bl PLTJMP(C_SYMBOL_NAME(__errno_location))
ldmia sp!, {r1, lr} ldr r1, [sp], #4
str r1, [r0] str r1, [r0]
#endif mvn r0, $0
ldr pc, [sp], #4
#else #else
stmdb sp!,{r10, lr} #ifndef PIC
@ we have to establish our PIC register ldr r1, 1f
ldr r10, 1f
add r10, pc, r10
0: ldr r1, 2f
ldr r1, [r10, r1]
@ store a copy in _errno_loc
str r0, [r1] str r0, [r1]
#ifdef _LIBC_REENTRANT
@ and another copy in thread copy of _errno_loc
mov r10, r0
bl __errno_location(PLT)
str r10, [r0]
#endif
ldmia sp!, {r10, lr}
b 4f
1: .word _GLOBAL_OFFSET_TABLE_ - 0b - 4
2: .word C_SYMBOL_NAME(errno)(GOT)
4:
#endif
mvn r0, $0 mvn r0, $0
RETINSTR(mov, pc, r14) RETINSTR(mov, pc, r14)
#ifndef PIC 1: .long C_SYMBOL_NAME(errno)
_errno_loc: .long C_SYMBOL_NAME(errno) #else
@ we have to establish our PIC register
ldr r2, 1f
ldr r1, 2f
0: add r2, pc, r2
str r0, [r1, r2]
mvn r0, $0
RETINSTR(mov, pc, r14)
1: .word _GLOBAL_OFFSET_TABLE_ - 0b - 8
2: .word C_SYMBOL_NAME(errno)(GOTOFF)
#endif
#endif #endif
#undef __syscall_error #undef __syscall_error

View File

@ -1,4 +1,4 @@
/* Copyright (C) 1998, 2000, 2002 Free Software Foundation, Inc. /* Copyright (C) 1998, 2000, 2002, 2003 Free Software Foundation, Inc.
This file is part of the GNU C Library. This file is part of the GNU C Library.
The GNU C Library is free software; you can redistribute it and/or The GNU C Library is free software; you can redistribute it and/or
@ -191,5 +191,6 @@ __adjtimex_tv64 (struct timex *tx)
strong_alias (__adjtimex_tv64, __adjtimex_internal); strong_alias (__adjtimex_tv64, __adjtimex_internal);
strong_alias (__adjtimex_tv64, __adjtimex_tv64p); strong_alias (__adjtimex_tv64, __adjtimex_tv64p);
weak_alias (__adjtimex_tv64, ntp_adjtime);
versioned_symbol (libc, __adjtimex_tv64, __adjtimex, GLIBC_2_1); versioned_symbol (libc, __adjtimex_tv64, __adjtimex, GLIBC_2_1);
versioned_symbol (libc, __adjtimex_tv64p, adjtimex, GLIBC_2_1); versioned_symbol (libc, __adjtimex_tv64p, adjtimex, GLIBC_2_1);

View File

@ -79,7 +79,7 @@ ENTRY (__socket)
/* r0 is < 0 if there was an error. */ /* r0 is < 0 if there was an error. */
cmn r0, $124 cmn r0, $124
RETINSTR(movcc, pc, r14) RETINSTR(movcc, pc, r14)
b PLTJMP(syscall_error) b PLTJMP(SYSCALL_ERROR)
PSEUDO_END (__socket) PSEUDO_END (__socket)

View File

@ -49,14 +49,13 @@
#undef PSEUDO #undef PSEUDO
#define PSEUDO(name, syscall_name, args) \ #define PSEUDO(name, syscall_name, args) \
.text; \ .text; \
.type syscall_error,%function; \
ENTRY (name); \ ENTRY (name); \
DO_CALL (syscall_name, args); \ DO_CALL (syscall_name, args); \
cmn r0, $4096; cmn r0, $4096;
#define PSEUDO_RET \ #define PSEUDO_RET \
RETINSTR(movcc, pc, lr); \ RETINSTR(movcc, pc, lr); \
b PLTJMP(__syscall_error) b PLTJMP(SYSCALL_ERROR)
#undef ret #undef ret
#define ret PSEUDO_RET #define ret PSEUDO_RET
@ -65,7 +64,22 @@
SYSCALL_ERROR_HANDLER \ SYSCALL_ERROR_HANDLER \
END (name) END (name)
#define SYSCALL_ERROR_HANDLER /* Nothing here; code in sysdep.S is used. */ #if NOT_IN_libc
# define SYSCALL_ERROR __local_syscall_error
# define SYSCALL_ERROR_HANDLER \
__local_syscall_error: \
str lr, [sp, #-4]!; \
str r0, [sp, #-4]!; \
bl PLTJMP(C_SYMBOL_NAME(__errno_location)); \
ldr r1, [sp], #4; \
rsb r1, r1, #0; \
str r1, [r0]; \
mvn r0, #0; \
ldr pc, [sp], #4;
#else
# define SYSCALL_ERROR_HANDLER /* Nothing here; code in sysdep.S is used. */
# define SYSCALL_ERROR __syscall_error
#endif
/* Linux takes system call args in registers: /* Linux takes system call args in registers:
syscall number in the SWI instruction syscall number in the SWI instruction
@ -123,7 +137,17 @@
/* Define a macro which expands into the inline wrapper code for a system /* Define a macro which expands into the inline wrapper code for a system
call. */ call. */
#undef INLINE_SYSCALL #undef INLINE_SYSCALL
#define INLINE_SYSCALL(name, nr, args...) \ #define INLINE_SYSCALL(name, nr, args...) \
({ unsigned int _sys_result = INTERNAL_SYSCALL (name, nr, args); \
if (__builtin_expect (INTERNAL_SYSCALL_ERROR_P (_sys_result), 0)) \
{ \
__set_errno (INTERNAL_SYSCALL_ERRNO (_sys_result)); \
_sys_result = (unsigned int) -1; \
} \
(int) _sys_result; })
#undef INTERNAL_SYSCALL
#define INTERNAL_SYSCALL(name, nr, args...) \
({ unsigned int _sys_result; \ ({ unsigned int _sys_result; \
{ \ { \
register int _a1 asm ("a1"); \ register int _a1 asm ("a1"); \
@ -134,13 +158,14 @@
: "a1", "memory"); \ : "a1", "memory"); \
_sys_result = _a1; \ _sys_result = _a1; \
} \ } \
if (_sys_result >= (unsigned int) -4095) \
{ \
__set_errno (-_sys_result); \
_sys_result = (unsigned int) -1; \
} \
(int) _sys_result; }) (int) _sys_result; })
#undef INTERNAL_SYSCALL_ERROR_P
#define INTERNAL_SYSCALL_ERROR_P(val) ((unsigned int) (val) >= 0xfffff001u)
#undef INTERNAL_SYSCALL_ERRNO
#define INTERNAL_SYSCALL_ERRNO(val) (-(val))
#define LOAD_ARGS_0() #define LOAD_ARGS_0()
#define ASM_ARGS_0 #define ASM_ARGS_0
#define LOAD_ARGS_1(a1) \ #define LOAD_ARGS_1(a1) \