diff options
author | Roland McGrath <roland@gnu.org> | 1995-09-30 17:10:48 +0000 |
---|---|---|
committer | Roland McGrath <roland@gnu.org> | 1995-09-30 17:10:48 +0000 |
commit | 41cfadd63c6d28400f263460e3f2b15e74893b63 (patch) | |
tree | a630064faeaec664341df5534b8defe2f5d1443a /sysdeps/unix/sysv/linux | |
parent | 24906b43b9bd9108aef17d18dfbb8764212085f7 (diff) | |
download | glibc-41cfadd63c6d28400f263460e3f2b15e74893b63.tar.gz |
Sat Sep 30 11:47:05 1995 Roland McGrath <roland@churchy.gnu.ai.mit.edu>
* posix/tstgetopt.c, posix/tstgetopt.args: Test long options too.
* sysdeps/unix/sysv/linux/i386/init-first.c (init): Save, set, and
restore %ebx by hand for personality syscall.
GCC cannot deal with spilling the dedicated GOT register.
* misc/Makefile (routines): Add mntent, which was somehow omitted.
Fri Sep 29 15:07:10 1995 Ulrich Drepper <drepper@ipd.info.uni-karlsruhe.de>
* sysdeps/unix/sysv/linux/adjtime.c (__adjtime):
Change name of field `mode' in `struct timex' to `modes'.
Linux-1.3.28 updates this name according to RFC 1489.
Diffstat (limited to 'sysdeps/unix/sysv/linux')
-rw-r--r-- | sysdeps/unix/sysv/linux/Implies | 6 | ||||
-rw-r--r-- | sysdeps/unix/sysv/linux/adjtime.c | 4 | ||||
-rw-r--r-- | sysdeps/unix/sysv/linux/i386/init-first.c | 14 |
3 files changed, 16 insertions, 8 deletions
diff --git a/sysdeps/unix/sysv/linux/Implies b/sysdeps/unix/sysv/linux/Implies index 3f43b3ea82..41c26f20f9 100644 --- a/sysdeps/unix/sysv/linux/Implies +++ b/sysdeps/unix/sysv/linux/Implies @@ -1,9 +1,9 @@ # Linux shares most of the syscalls which are also common to BSD and SVR4. unix/common -# Linux has not yet (as of 1.3.18) the canonical set of <sys/mman.h> -# system calls. msync() and madvice() are missing, so their stubs -# are found here. I think later version will have them ones. +# Linux as of version 1.3.29 has all functions of the mmap family +# which are described in POSIX.4. Missing is only madvise() so +# we define a stub here. unix/mman # Linux has network support in the kernel. diff --git a/sysdeps/unix/sysv/linux/adjtime.c b/sysdeps/unix/sysv/linux/adjtime.c index 3673cd9164..8400e1b907 100644 --- a/sysdeps/unix/sysv/linux/adjtime.c +++ b/sysdeps/unix/sysv/linux/adjtime.c @@ -43,10 +43,10 @@ __adjtime (itv, otv) return -1; } tntx.offset = tmp.tv_usec + tmp.tv_sec * 1000000L; - tntx.mode = ADJ_OFFSET_SINGLESHOT; + tntx.modes = ADJ_OFFSET_SINGLESHOT; } else - tntx.mode = 0; + tntx.modes = 0; if (__adjtimex (&tntx) < 0) return -1; diff --git a/sysdeps/unix/sysv/linux/i386/init-first.c b/sysdeps/unix/sysv/linux/i386/init-first.c index 0177daae24..84b5ff9f2c 100644 --- a/sysdeps/unix/sysv/linux/i386/init-first.c +++ b/sysdeps/unix/sysv/linux/i386/init-first.c @@ -18,6 +18,7 @@ not, write to the Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ #include <unistd.h> +#include <sysdep.h> #include "fpu_control.h" extern void __libc_init (int, char **, char **); @@ -31,9 +32,16 @@ init (int *data) char **argv = (void *) (data + 1); char **envp = &argv[argc + 1]; - /* Make sure we are not using iBSC2 personality. */ - asm ("int $0x80 # syscall no %0, arg %1" - : : "a" (SYS_ify (personality)), "b" (0)); + /* Make sure we are not using the iBSC2 personality. The `personality' + syscall takes one argument; zero means the Linux personality. The + argument arrives in %ebx; we have to save and restore %ebx by hand + here, because GCC (as of 2.7.0) cannot handle saving and restoring it + for us when it is the dedicated GOT register for PIC. */ + asm ("pushl %%ebx\n" + "xorl %%ebx, %%ebx\n" + "int $0x80 # syscall no %0\n" + "popl %%ebx" + : : "a" (SYS_ify (personality))); /* Set the FPU control word to the proper default value. */ __setfpucw (___fpu_control); |