6ed0492f8e
Tue Oct 22 21:38:21 1996 Ulrich Drepper <drepper@cygnus.com> * version.h: Bump version number to 1.97. * features.h: Undo change of Sun Oct 20 22:19:58 1996. Include libc-version.h. * features.h.in: Removed. * Makefile: Change rules to generate libc-version.h instead of features.h. * malloc/free.c: Add cast to prevent warning. * malloc/malloc-walk.c: Likewise. * malloc/ralloc.c: Likewise. * malloc/realloc.c: Likewise. * grp/fgetgrent_r.c: Accept empty numeric field if name start with + or -. * pwd/fgetpwent_r.c: Likewise. * nss/nss_files/files-grp.c: Don't accept entries with names starting with + or - in lookup functions. * nss/nss_files/files-pwd.c: Likewise. * Makerules: Call autolock.sh using $(SHELL). Mon Oct 21 22:52:16 1996 NIIBE Yutaka <gniibe@mri.co.jp> * elf/dl-minimal.c: Don't define `dgettext' replacement but `dcgettext'. When optimizing the macros in <libintl.h> define `dgettext' as a macro and so this function will never be called. Mon Oct 21 15:41:59 1996 Ulrich Drepper <drepper@cygnus.com> * sysdeps/i386/sysdep.h: Define END to use .size when available. (PSEUDO_END): Use END. * sysdeps/unix/sysv/linux/i386/sysdep.h: Define PSEUDO_END to define SYSCALL_ERROR_HANDLER before using END. (SYSCALL_ERROR_HANDLER): Don't use .size directive. * sysdeps/unix/sysv/linux/clone.S: Don't use SYSCALL_ERROR_HANDLER and .size directive but PSEUDO_END. * sysdeps/unix/sysv/linux/mmap.S: Likewise. * sysdeps/unix/sysv/linux/socket.S: Likewise. * sysdeps/unix/sysv/linux/syscall.S: Likewise. * sysdeps/unix/sysv/linux/sysdep.S (__errno_location): Use END. * sysdeps/unix/i386/sysdep.S (__syscall_error): Likewise. * sysdeps/i386/__longjmp.S: Use END instead of PSEUDO_END. * sysdeps/i386/bsd-_setjmp.S: Likewise. * sysdeps/i386/bsd-setjmp.S: Likewise. * sysdeps/i386/memchr.S: Likewise. * sysdeps/i386/memcmp.S: Likewise. * sysdeps/i386/setjmp.S: Likewise. * sysdeps/i386/stpcpy.S: Likewise. * sysdeps/i386/stpncpy.S: Likewise. * sysdeps/i386/strchr.S: Likewise. * sysdeps/i386/strcspn.S: Likewise. * sysdeps/i386/strpbrk.S: Likewise. * sysdeps/i386/strrchr.S: Likewise. * sysdeps/i386/strspn.S: Likewise. * sysdeps/i386/strtok.S: Likewise. * sysdeps/i386/i486/strcat.S: Likewise. * sysdeps/i386/i486/strlen.S: Likewise. * sysdeps/i386/i586/memset.S: Likewise. * sysdeps/i386/i586/strchr.S: Likewise. * sysdeps/i386/i586/strlen.S: Likewise. * sysdeps/i386/strlen.c: De-ANSI-fy. * sysdeps/generic/_strerror.c: Undo change of Mon Oct 21 01:32:36 1996. Define dgettext if not defined to use dcgettext. * sysdeps/mach/_strerror.c: Likewise. * sysdeps/unix/sysv/i386/time.S: Add PSEUDO_END to get __syscall_error defined.. Sat Oct 19 12:27:50 1996 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de> * sysdeps/unix/sysv/linux/m68k/mmap.S: Fix braino: CALL_MCOUNT is already included in the ENTRY macro. Remove SYSCALL_ERROR_HANDLER now provided by PSEUDO_END. * sysdeps/unix/sysv/linux/m68k/sigreturn.S: Likewise. * sysdeps/unix/sysv/linux/m68k/socket.S: Likewise. * sysdeps/unix/sysv/linux/m68k/syscall.S: Likewise. * sysdeps/unix/sysv/linux/m68k/sysdep.S: Likewise. * sysdeps/unix/sysv/linux/m68k/clone.S: Likewise. Use JUMPTARGET. * sysdeps/generic/sysdep.h (END): Provide default empty definition. * sysdeps/unix/sysv/linux/m68k/sysdep.h (END): Redefine to use size directive. (PSEUDO): Don't include SYSCALL_ERROR_HANDLER. (PSEUDO_END): Include it here instead. (SYSCALL_ERROR_HANDLER): Remove type directive. * sysdeps/m68k/bsd-_setjmp.S: Use END, not PSEUDO_END. * sysdeps/m68k/bsd-setjmp.S: Likewise. * sysdeps/unix/sysv/linux/m68k/sigreturn.S: Likewise. * sysdeps/unix/sysv/linux/m68k/sysdep.S: Likewise. (__syscall_error): Can't use ENTRY macro. Sat Oct 19 12:13:24 1996 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de> * sysdeps/unix/sysv/linux/syscalls.list (getresuid, setresuid): Set caller to EXTRA. O_SHLOCK. Tue Oct 15 14:37:40 1996 Thomas Bushnell, n/BSG <thomas@gnu.ai.mit.edu> * sysdeps/mach/hurd/fcntlbits.h (O_HURD): Add O_EXLOCK and
189 lines
6.2 KiB
C
189 lines
6.2 KiB
C
/* Copyright (C) 1996 Free Software Foundation, Inc.
|
|
This file is part of the GNU C Library.
|
|
Written by Andreas Schwab, <schwab@issan.informatik.uni-dortmund.de>,
|
|
December 1995.
|
|
|
|
The GNU C Library is free software; you can redistribute it and/or
|
|
modify it under the terms of the GNU Library General Public License as
|
|
published by the Free Software Foundation; either version 2 of the
|
|
License, or (at your option) any later version.
|
|
|
|
The GNU C Library is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
Library General Public License for more details.
|
|
|
|
You should have received a copy of the GNU Library General Public
|
|
License along with the GNU C Library; see the file COPYING.LIB. If
|
|
not, write to the Free Software Foundation, Inc., 675 Mass Ave,
|
|
Cambridge, MA 02139, USA. */
|
|
|
|
#include <sysdeps/unix/sysdep.h>
|
|
|
|
/* For Linux we can use the system call table in the header file
|
|
/usr/include/asm/unistd.h
|
|
of the kernel. But these symbols do not follow the SYS_* syntax
|
|
so we have to redefine the `SYS_ify' macro here. */
|
|
#undef SYS_ify
|
|
#ifdef __STDC__
|
|
# define SYS_ify(syscall_name) __NR_##syscall_name
|
|
#else
|
|
# define SYS_ify(syscall_name) __NR_/**/syscall_name
|
|
#endif
|
|
|
|
#ifdef ASSEMBLER
|
|
|
|
/* Define an entry point visible from C. */
|
|
#define ENTRY(name) \
|
|
.globl name; \
|
|
.type name, @function; \
|
|
.align 4; \
|
|
C_LABEL(name) \
|
|
CALL_MCOUNT
|
|
|
|
#undef END
|
|
#define END(name) .size name, . - name
|
|
|
|
/* If compiled for profiling, call `_mcount' at the start of each function. */
|
|
#ifdef PROF
|
|
/* The mcount code relies on a normal frame pointer being on the stack
|
|
to locate our caller, so push one just for its benefit. */
|
|
#define CALL_MCOUNT \
|
|
move.l %fp, -(%sp); move.l %sp, %fp; \
|
|
jbsr JUMPTARGET (_mcount); \
|
|
move.l (%sp)+, %fp;
|
|
#else
|
|
#define CALL_MCOUNT /* Do nothing. */
|
|
#endif
|
|
|
|
#ifdef PIC
|
|
#define JUMPTARGET(name) name##@PLTPC
|
|
#else
|
|
#define JUMPTARGET(name) name
|
|
#endif
|
|
|
|
/* Since C identifiers are not normally prefixed with an underscore
|
|
on this system, the asm identifier `syscall_error' intrudes on the
|
|
C name space. Make sure we use an innocuous name. */
|
|
#define syscall_error __syscall_error
|
|
|
|
/* Linux uses a negative return value to indicate syscall errors, unlike
|
|
most Unices, which use the condition codes' carry flag.
|
|
|
|
Since version 2.1 the return value of a system call might be negative
|
|
even if the call succeeded. E.g., the `lseek' system call might return
|
|
a large offset. Therefore we must not anymore test for < 0, but test
|
|
for a real error by making sure the value in %d0 is a real error
|
|
number. For now (as of 2.1.1) 122 is the largest defined error number.
|
|
We allow for a bit of room for development and treat -128 to -1 as
|
|
error values. */
|
|
#define PSEUDO(name, syscall_name, args) \
|
|
.text; \
|
|
ENTRY (name) \
|
|
DO_CALL (&SYS_ify (syscall_name), args); \
|
|
moveq.l &-128, %d1; \
|
|
cmp.l %d1, %d0; \
|
|
jcc syscall_error
|
|
|
|
#undef PSEUDO_END
|
|
#define PSEUDO_END(name) \
|
|
SYSCALL_ERROR_HANDLER; \
|
|
END (name)
|
|
|
|
#ifdef PIC
|
|
/* Store (- %d0) into errno through the GOT. */
|
|
#ifdef _LIBC_REENTRANT
|
|
#define SYSCALL_ERROR_HANDLER \
|
|
syscall_error: \
|
|
move.l (errno@GOTPC, %pc), %a0; \
|
|
neg.l %d0; \
|
|
move.l %d0, (%a0); \
|
|
move.l %d0, -(%sp); \
|
|
jbsr __errno_location@PLTPC; \
|
|
move.l (%sp)+, (%a0); \
|
|
move.l &-1, %d0; \
|
|
/* Copy return value to %a0 for syscalls that are declared to return \
|
|
a pointer (e.g., mmap). */ \
|
|
move.l %d0, %a0; \
|
|
rts;
|
|
#else
|
|
#define SYSCALL_ERROR_HANDLER \
|
|
syscall_error: \
|
|
move.l (errno@GOTPC, %pc), %a0; \
|
|
neg.l %d0; \
|
|
move.l %d0, (%a0); \
|
|
move.l &-1, %d0; \
|
|
/* Copy return value to %a0 for syscalls that are declared to return \
|
|
a pointer (e.g., mmap). */ \
|
|
move.l %d0, %a0; \
|
|
rts;
|
|
#endif /* _LIBC_REENTRANT */
|
|
#else
|
|
#define SYSCALL_ERROR_HANDLER /* Nothing here; code in sysdep.S is used. */
|
|
#endif /* PIC */
|
|
|
|
/* Linux takes system call arguments in registers:
|
|
|
|
syscall number %d0 call-clobbered
|
|
arg 1 %d1 call-clobbered
|
|
arg 2 %d2 call-saved
|
|
arg 3 %d3 call-saved
|
|
arg 4 %d4 call-saved
|
|
arg 5 %d5 call-saved
|
|
|
|
The stack layout upon entering the function is:
|
|
|
|
20(%sp) Arg# 5
|
|
16(%sp) Arg# 4
|
|
12(%sp) Arg# 3
|
|
8(%sp) Arg# 2
|
|
4(%sp) Arg# 1
|
|
(%sp) Return address
|
|
|
|
(Of course a function with say 3 arguments does not have entries for
|
|
arguments 4 and 5.)
|
|
|
|
Separate move's are faster than movem, but need more space. Since
|
|
speed is more important, we don't use movem. Since %a0 and %a1 are
|
|
scratch registers, we can use them for saving as well. */
|
|
|
|
#define DO_CALL(syscall, args) \
|
|
move.l syscall, %d0; \
|
|
DOARGS_##args \
|
|
trap &0; \
|
|
UNDOARGS_##args
|
|
|
|
#define DOARGS_0 /* No arguments to frob. */
|
|
#define UNDOARGS_0 /* No arguments to unfrob. */
|
|
#define _DOARGS_0(n) /* No arguments to frob. */
|
|
|
|
#define DOARGS_1 _DOARGS_1 (4)
|
|
#define _DOARGS_1(n) move.l n(%sp), %d1; _DOARGS_0 (n)
|
|
#define UNDOARGS_1 UNDOARGS_0
|
|
|
|
#define DOARGS_2 _DOARGS_2 (8)
|
|
#define _DOARGS_2(n) move.l %d2, %a0; move.l n(%sp), %d2; _DOARGS_1 (n-4)
|
|
#define UNDOARGS_2 UNDOARGS_1; move.l %a0, %d2
|
|
|
|
#define DOARGS_3 _DOARGS_3 (12)
|
|
#define _DOARGS_3(n) move.l %d3, %a1; move.l n(%sp), %d3; _DOARGS_2 (n-4)
|
|
#define UNDOARGS_3 UNDOARGS_2; move.l %a1, %d3
|
|
|
|
#define DOARGS_4 _DOARGS_4 (16)
|
|
#define _DOARGS_4(n) move.l %d4, -(%sp); move.l n+4(%sp), %d4; _DOARGS_3 (n)
|
|
#define UNDOARGS_4 UNDOARGS_3; move.l (%sp)+, %d4
|
|
|
|
#define DOARGS_5 _DOARGS_5 (20)
|
|
#define _DOARGS_5(n) move.l %d5, -(%sp); move.l n+4(%sp), %d5; _DOARGS_4 (n)
|
|
#define UNDOARGS_5 UNDOARGS_4; move.l (%sp)+, %d5
|
|
|
|
|
|
#define ret rts
|
|
#if 0 /* Not used by Linux */
|
|
#define r0 %d0
|
|
#define r1 %d1
|
|
#define MOVE(x,y) movel x , y
|
|
#endif
|
|
|
|
#endif /* ASSEMBLER */
|