mirror of
https://sourceware.org/git/glibc.git
synced 2024-11-24 02:03:35 +08:00
Update.
1998-06-25 19:26 Ulrich Drepper <drepper@cygnus.com> * Makeconfig (CPPFLAGS): Use $($(subdir)-CPPFLAGS) if defined first. * locale/Makefile: Define locale-CPPFLAGS instead of redefining CPPFLAGS. * libc.map: Export __sigaction. 1998-06-25 Andreas Jaeger <aj@arthur.rhein-neckar.de> * sysdeps/unix/sysv/linux/bits/sched.h (CLONE_PTRACE): Add it (from Linux 2.1.107). 1998-06-24 Ulrich Drepper <drepper@cygnus.com> * nss/nss_files/files-XXX.c (_nss_files_get,ENTNAME_r): Initialize position when file was opened here. Reported by Howard Chu <hyc@platinum.com>. * sysdeps/generic/glob.c: Also protect FNM_* macros from being undefined in a second inclusion. 1998-06-20 Mark Kettenis <kettenis@phys.uva.nl> * sysdeps/mach/hurd/i386/Makefile: New file. * sysdeps/mach/hurd/i386/init-first.c [!PIC] (init1): Call __libc_init_secure. (_hurd_stack_setup): Renamed from __libc_init_first. (__libc_init_first): New function. * sysdeps/mach/hurd/i386/static-start.S: New file. 1998-05-30 Mark Kettenis <kettenis@phys.uva.nl> * sysdeps/mach/hurd/i386/init-first.c 1998-06-22 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de> * grp/initgroups.c: Use _CALL_DL_FCT. 1998-06-23 Mark Kettenis <kettenis@phys.uva.nl> * elf/dl-load.c (_dl_map_object_from_fd): Add missing cast.
This commit is contained in:
parent
75c3a84f29
commit
0ca7e46e16
44
ChangeLog
44
ChangeLog
@ -1,3 +1,47 @@
|
|||||||
|
1998-06-25 19:26 Ulrich Drepper <drepper@cygnus.com>
|
||||||
|
|
||||||
|
* Makeconfig (CPPFLAGS): Use $($(subdir)-CPPFLAGS) if defined first.
|
||||||
|
* locale/Makefile: Define locale-CPPFLAGS instead of redefining
|
||||||
|
CPPFLAGS.
|
||||||
|
|
||||||
|
* libc.map: Export __sigaction.
|
||||||
|
|
||||||
|
1998-06-25 Andreas Jaeger <aj@arthur.rhein-neckar.de>
|
||||||
|
|
||||||
|
* sysdeps/unix/sysv/linux/bits/sched.h (CLONE_PTRACE): Add it
|
||||||
|
(from Linux 2.1.107).
|
||||||
|
|
||||||
|
1998-06-24 Ulrich Drepper <drepper@cygnus.com>
|
||||||
|
|
||||||
|
* nss/nss_files/files-XXX.c (_nss_files_get,ENTNAME_r): Initialize
|
||||||
|
position when file was opened here.
|
||||||
|
Reported by Howard Chu <hyc@platinum.com>.
|
||||||
|
|
||||||
|
* sysdeps/generic/glob.c: Also protect FNM_* macros from being
|
||||||
|
undefined in a second inclusion.
|
||||||
|
|
||||||
|
1998-06-20 Mark Kettenis <kettenis@phys.uva.nl>
|
||||||
|
|
||||||
|
* sysdeps/mach/hurd/i386/Makefile: New file.
|
||||||
|
* sysdeps/mach/hurd/i386/init-first.c [!PIC] (init1): Call
|
||||||
|
__libc_init_secure.
|
||||||
|
(_hurd_stack_setup): Renamed
|
||||||
|
from __libc_init_first.
|
||||||
|
(__libc_init_first): New function.
|
||||||
|
* sysdeps/mach/hurd/i386/static-start.S: New file.
|
||||||
|
|
||||||
|
1998-05-30 Mark Kettenis <kettenis@phys.uva.nl>
|
||||||
|
|
||||||
|
* sysdeps/mach/hurd/i386/init-first.c
|
||||||
|
|
||||||
|
1998-06-22 Andreas Schwab <schwab@issan.informatik.uni-dortmund.de>
|
||||||
|
|
||||||
|
* grp/initgroups.c: Use _CALL_DL_FCT.
|
||||||
|
|
||||||
|
1998-06-23 Mark Kettenis <kettenis@phys.uva.nl>
|
||||||
|
|
||||||
|
* elf/dl-load.c (_dl_map_object_from_fd): Add missing cast.
|
||||||
|
|
||||||
1998-06-23 Andreas Jaeger <aj@arthur.rhein-neckar.de>
|
1998-06-23 Andreas Jaeger <aj@arthur.rhein-neckar.de>
|
||||||
|
|
||||||
* manual/terminal.texi (Pseudo-Terminals): Correct typos.
|
* manual/terminal.texi (Pseudo-Terminals): Correct typos.
|
||||||
|
@ -20,8 +20,7 @@
|
|||||||
* sysdeps/pthread/pthread.h: Likewise.
|
* sysdeps/pthread/pthread.h: Likewise.
|
||||||
Patches by Xavier leroy.
|
Patches by Xavier leroy.
|
||||||
|
|
||||||
* sysdeps/i386/pt-machine.h: When compiling for i686 don't test for
|
* sysdeps/i386/i686/pt-machine.h: New file.
|
||||||
xchgcmp instruction, it is available.
|
|
||||||
|
|
||||||
1998-06-25 Ulrich Drepper <drepper@cygnus.com>
|
1998-06-25 Ulrich Drepper <drepper@cygnus.com>
|
||||||
|
|
||||||
|
72
linuxthreads/sysdeps/i386/i686/pt-machine.h
Normal file
72
linuxthreads/sysdeps/i386/i686/pt-machine.h
Normal file
@ -0,0 +1,72 @@
|
|||||||
|
/* Machine-dependent pthreads configuration and inline functions.
|
||||||
|
i686 version.
|
||||||
|
Copyright (C) 1996, 1997, 1998 Free Software Foundation, Inc.
|
||||||
|
This file is part of the GNU C Library.
|
||||||
|
Contributed by Richard Henderson <rth@tamu.edu>.
|
||||||
|
|
||||||
|
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., 59 Temple Place - Suite 330,
|
||||||
|
Boston, MA 02111-1307, USA. */
|
||||||
|
|
||||||
|
|
||||||
|
/* Spinlock implementation; required. */
|
||||||
|
extern inline int
|
||||||
|
testandset (int *spinlock)
|
||||||
|
{
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
__asm__ __volatile__("xchgl %0, %1"
|
||||||
|
: "=r"(ret), "=m"(*spinlock)
|
||||||
|
: "0"(1), "m"(*spinlock));
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/* Get some notion of the current stack. Need not be exactly the top
|
||||||
|
of the stack, just something somewhere in the current frame. */
|
||||||
|
#define CURRENT_STACK_FRAME stack_pointer
|
||||||
|
register char * stack_pointer __asm__ ("%esp");
|
||||||
|
|
||||||
|
|
||||||
|
/* Compare-and-swap for semaphores. It's always available on i686. */
|
||||||
|
#define HAS_COMPARE_AND_SWAP
|
||||||
|
|
||||||
|
extern inline int
|
||||||
|
__compare_and_swap (long int *p, long int oldval, long int newval)
|
||||||
|
{
|
||||||
|
char ret;
|
||||||
|
long int readval;
|
||||||
|
|
||||||
|
__asm__ __volatile__ ("lock; cmpxchgl %3, %1; sete %0"
|
||||||
|
: "=q" (ret), "=m" (*p), "=a" (readval)
|
||||||
|
: "r" (newval), "m" (*p), "a" (oldval));
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
extern inline int
|
||||||
|
get_eflags (void)
|
||||||
|
{
|
||||||
|
int res;
|
||||||
|
__asm__ __volatile__ ("pushfl; popl %0" : "=r" (res) : );
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
extern inline void
|
||||||
|
set_eflags (int newflags)
|
||||||
|
{
|
||||||
|
__asm__ __volatile__ ("pushl %0; popfl" : : "r" (newflags) : "cc");
|
||||||
|
}
|
@ -45,9 +45,7 @@ register char * stack_pointer __asm__ ("%esp");
|
|||||||
We test dynamically whether it's available or not. */
|
We test dynamically whether it's available or not. */
|
||||||
|
|
||||||
#define HAS_COMPARE_AND_SWAP
|
#define HAS_COMPARE_AND_SWAP
|
||||||
#ifndef __i686__
|
#define TEST_FOR_COMPARE_AND_SWAP
|
||||||
# define TEST_FOR_COMPARE_AND_SWAP
|
|
||||||
#endif
|
|
||||||
|
|
||||||
extern inline int
|
extern inline int
|
||||||
__compare_and_swap (long int *p, long int oldval, long int newval)
|
__compare_and_swap (long int *p, long int oldval, long int newval)
|
||||||
|
@ -73,13 +73,13 @@ $(objpfx)localedef $(objpfx)locale: $(lib-modules:%=$(objpfx)%.o)
|
|||||||
|
|
||||||
localepath = "$(localedir):$(i18ndir)"
|
localepath = "$(localedir):$(i18ndir)"
|
||||||
|
|
||||||
CPPFLAGS := -DLOCALE_PATH='$(localepath)' \
|
locale-CPPFLAGS := -DLOCALE_PATH='$(localepath)' \
|
||||||
-DLOCALEDIR='"$(localedir)"' \
|
-DLOCALEDIR='"$(localedir)"' \
|
||||||
-DLOCALE_ALIAS_PATH='"$(localedir):$(i18ndir)"' \
|
-DLOCALE_ALIAS_PATH='"$(localedir):$(i18ndir)"' \
|
||||||
-DCHARMAP_PATH='"$(i18ndir)/charmaps"' \
|
-DCHARMAP_PATH='"$(i18ndir)/charmaps"' \
|
||||||
-DREPERTOIREMAP_PATH='"$(i18ndir)/repertoiremaps"' \
|
-DREPERTOIREMAP_PATH='"$(i18ndir)/repertoiremaps"' \
|
||||||
-DLOCSRCDIR='"$(i18ndir)/locales"' -DHAVE_CONFIG_H \
|
-DLOCSRCDIR='"$(i18ndir)/locales"' -DHAVE_CONFIG_H \
|
||||||
-Iprograms $(CPPFLAGS)
|
-Iprograms
|
||||||
|
|
||||||
CFLAGS-charmap.c = -Wno-write-strings -Wno-char-subscripts
|
CFLAGS-charmap.c = -Wno-write-strings -Wno-char-subscripts
|
||||||
CFLAGS-locfile.c = -Wno-write-strings -Wno-char-subscripts
|
CFLAGS-locfile.c = -Wno-write-strings -Wno-char-subscripts
|
||||||
|
7
sysdeps/mach/hurd/i386/Makefile
Normal file
7
sysdeps/mach/hurd/i386/Makefile
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
ifeq ($(subdir),csu)
|
||||||
|
extra-objs += crt0.o
|
||||||
|
install-lib += crt0.o
|
||||||
|
|
||||||
|
$(objpfx)crt0.o: $(objpfx)static-start.o $(objpfx)abi-note.o $(objpfx)init.o
|
||||||
|
$(link-relocatable)
|
||||||
|
endif
|
@ -1,5 +1,5 @@
|
|||||||
/* Initialization code run first thing by the ELF startup code. For i386/Hurd.
|
/* Initialization code run first thing by the ELF startup code. For i386/Hurd.
|
||||||
Copyright (C) 1995, 1996, 1997 Free Software Foundation, Inc.
|
Copyright (C) 1995, 1996, 1997, 1998 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
|
||||||
@ -21,11 +21,13 @@
|
|||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
|
#include <sysdep.h>
|
||||||
|
#include <set-hooks.h>
|
||||||
#include "hurdstartup.h"
|
#include "hurdstartup.h"
|
||||||
#include "set-hooks.h"
|
|
||||||
#include "hurdmalloc.h" /* XXX */
|
#include "hurdmalloc.h" /* XXX */
|
||||||
|
|
||||||
extern void __mach_init (void);
|
extern void __mach_init (void);
|
||||||
|
extern void __libc_init_secure (void);
|
||||||
extern void __libc_init (int, char **, char **);
|
extern void __libc_init (int, char **, char **);
|
||||||
extern void __getopt_clean_environment (char **);
|
extern void __getopt_clean_environment (char **);
|
||||||
extern void __libc_global_ctors (void);
|
extern void __libc_global_ctors (void);
|
||||||
@ -40,7 +42,7 @@ extern int __libc_argc;
|
|||||||
extern char **__libc_argv;
|
extern char **__libc_argv;
|
||||||
|
|
||||||
/* We often need the PID. Cache this value. */
|
/* We often need the PID. Cache this value. */
|
||||||
pid_t __libc_pid;
|
pid_t __libc_pid = 0xf00baa;
|
||||||
|
|
||||||
void *(*_cthread_init_routine) (void); /* Returns new SP to use. */
|
void *(*_cthread_init_routine) (void); /* Returns new SP to use. */
|
||||||
void (*_cthread_exit_routine) (int status) __attribute__ ((__noreturn__));
|
void (*_cthread_exit_routine) (int status) __attribute__ ((__noreturn__));
|
||||||
@ -59,6 +61,7 @@ init1 (int argc, char *arg0, ...)
|
|||||||
__libc_argc = argc;
|
__libc_argc = argc;
|
||||||
__libc_argv = argv;
|
__libc_argv = argv;
|
||||||
__environ = envp;
|
__environ = envp;
|
||||||
|
|
||||||
while (*envp)
|
while (*envp)
|
||||||
++envp;
|
++envp;
|
||||||
d = (void *) ++envp;
|
d = (void *) ++envp;
|
||||||
@ -106,6 +109,10 @@ init1 (int argc, char *arg0, ...)
|
|||||||
d->portarray, d->portarraysize,
|
d->portarray, d->portarraysize,
|
||||||
d->intarray, d->intarraysize);
|
d->intarray, d->intarraysize);
|
||||||
|
|
||||||
|
#ifndef PIC
|
||||||
|
__libc_init_secure ();
|
||||||
|
#endif
|
||||||
|
|
||||||
__libc_init (argc, argv, __environ);
|
__libc_init (argc, argv, __environ);
|
||||||
|
|
||||||
/* This is a hack to make the special getopt in GNU libc working. */
|
/* This is a hack to make the special getopt in GNU libc working. */
|
||||||
@ -214,8 +221,6 @@ init (int *data)
|
|||||||
pointer in the dynamic section based solely on that. It is convention
|
pointer in the dynamic section based solely on that. It is convention
|
||||||
for this function to be in the `.init' section, but the symbol name is
|
for this function to be in the `.init' section, but the symbol name is
|
||||||
the only thing that really matters!! */
|
the only thing that really matters!! */
|
||||||
/*void _init (int argc, ...) __attribute__ ((unused, section (".init")));*/
|
|
||||||
|
|
||||||
void
|
void
|
||||||
_init (int argc, ...)
|
_init (int argc, ...)
|
||||||
{
|
{
|
||||||
@ -232,6 +237,12 @@ _init (int argc, ...)
|
|||||||
void
|
void
|
||||||
__libc_init_first (int argc __attribute__ ((unused)), ...)
|
__libc_init_first (int argc __attribute__ ((unused)), ...)
|
||||||
{
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void
|
||||||
|
_hurd_stack_setup (int argc __attribute__ ((unused)), ...)
|
||||||
|
{
|
||||||
#ifndef PIC
|
#ifndef PIC
|
||||||
void doinit (int *data)
|
void doinit (int *data)
|
||||||
{
|
{
|
||||||
|
28
sysdeps/mach/hurd/i386/static-start.S
Normal file
28
sysdeps/mach/hurd/i386/static-start.S
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
/* Startup code for statically linked Hurd/i386 binaries.
|
||||||
|
Copyright (C) 1998 Free Software Foundation, Inc.
|
||||||
|
This file is part of the GNU C Library.
|
||||||
|
|
||||||
|
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., 59 Temple Place - Suite 330,
|
||||||
|
Boston, MA 02111-1307, USA. */
|
||||||
|
|
||||||
|
.text
|
||||||
|
.globl _start
|
||||||
|
_start:
|
||||||
|
call _hurd_stack_setup
|
||||||
|
xorl %edx, %edx
|
||||||
|
jmp _start1
|
||||||
|
|
||||||
|
#define _start _start1
|
||||||
|
#include <sysdeps/i386/elf/start.S>
|
Loading…
Reference in New Issue
Block a user