aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog45
-rw-r--r--FAQ11
-rw-r--r--FAQ.in9
-rw-r--r--iconv/gconv.c2
-rw-r--r--iconv/iconv.c9
-rw-r--r--iconvdata/gconv-modules6
-rw-r--r--iconvdata/johab.c34
-rw-r--r--linuxthreads/ChangeLog5
-rw-r--r--linuxthreads/pthread.c16
-rw-r--r--sysdeps/unix/sysv/linux/fxstat64.c1
-rw-r--r--sysdeps/unix/sysv/linux/i386/getmsg.c41
-rw-r--r--sysdeps/unix/sysv/linux/i386/getpmsg.c41
-rw-r--r--sysdeps/unix/sysv/linux/i386/putmsg.c42
-rw-r--r--sysdeps/unix/sysv/linux/i386/putpmsg.c42
-rw-r--r--sysdeps/unix/sysv/linux/lxstat64.c1
-rw-r--r--sysdeps/unix/sysv/linux/m68k/getmsg.c1
-rw-r--r--sysdeps/unix/sysv/linux/m68k/getpmsg.c1
-rw-r--r--sysdeps/unix/sysv/linux/m68k/putmsg.c1
-rw-r--r--sysdeps/unix/sysv/linux/m68k/putpmsg.c1
-rw-r--r--sysdeps/unix/sysv/linux/mips/getmsg.c1
-rw-r--r--sysdeps/unix/sysv/linux/mips/getpmsg.c1
-rw-r--r--sysdeps/unix/sysv/linux/mips/putmsg.c1
-rw-r--r--sysdeps/unix/sysv/linux/mips/putpmsg.c1
-rw-r--r--sysdeps/unix/sysv/linux/powerpc/getmsg.c1
-rw-r--r--sysdeps/unix/sysv/linux/powerpc/getpmsg.c1
-rw-r--r--sysdeps/unix/sysv/linux/powerpc/putmsg.c1
-rw-r--r--sysdeps/unix/sysv/linux/powerpc/putpmsg.c1
-rw-r--r--sysdeps/unix/sysv/linux/powerpc/syscalls.list2
-rw-r--r--sysdeps/unix/sysv/linux/xstat64.c5
29 files changed, 292 insertions, 32 deletions
diff --git a/ChangeLog b/ChangeLog
index 5814f1e674..8dd88d28ec 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,5 +1,50 @@
+1999-12-21 Ulrich Drepper <drepper@cygnus.com>
+
+ * sysdeps/unix/sysv/linux/i386/getmsg.c: New file.
+ * sysdeps/unix/sysv/linux/i386/getpmsg.c: New file.
+ * sysdeps/unix/sysv/linux/i386/putmsg.c: New file.
+ * sysdeps/unix/sysv/linux/i386/putpmsg.c: New file.
+ * sysdeps/unix/sysv/linux/m68k/getmsg.c: New file.
+ * sysdeps/unix/sysv/linux/m68k/getpmsg.c: New file.
+ * sysdeps/unix/sysv/linux/m68k/putmsg.c: New file.
+ * sysdeps/unix/sysv/linux/m68k/putpmsg.c: New file.
+ * sysdeps/unix/sysv/linux/mips/getmsg.c: New file.
+ * sysdeps/unix/sysv/linux/mips/getpmsg.c: New file.
+ * sysdeps/unix/sysv/linux/mips/putmsg.c: New file.
+ * sysdeps/unix/sysv/linux/mips/putpmsg.c: New file.
+ * sysdeps/unix/sysv/linux/powerpc/getmsg.c: New file.
+ * sysdeps/unix/sysv/linux/powerpc/getpmsg.c: New file.
+ * sysdeps/unix/sysv/linux/powerpc/putmsg.c: New file.
+ * sysdeps/unix/sysv/linux/powerpc/putpmsg.c: New file.
+ * sysdeps/unix/sysv/linux/powerpc/syscalls.list: Add getpmsg and
+ putpmsg.
+
+1999-12-20 Ulrich Drepper <drepper@cygnus.com>
+
+ * sysdeps/unix/sysv/linux/lxstat64.c: Include "kernel-features.h"
+ before testing for __ASSUME_STAT64_SYSCALL.
+ * sysdeps/unix/sysv/linux/fxstat64.c: Likewise.
+ * sysdeps/unix/sysv/linux/xstat64.c: Likewise.
+
+1999-12-20 Andreas Schwab <schwab@suse.de>
+
+ * manual/install.texi (Running make install): Clearify that
+ install_root should be an absolute file name.
+
1999-12-20 Ulrich Drepper <drepper@cygnus.com>
+ * iconv/gconv.c (__gconv): Deal with outbuf being NULL.
+
+ * iconv/iconv.c (iconv): Allow omitting output buffer if no input
+ buffer is given to place conversion descriptor in initial state.
+ * iconvdata/gconv-modules: Correct aliases CSPC850MULTILINGUAL and
+ CSPC862LATINHEBREW.
+ * iconvdata/gconv-modules: Add aliases GB2312 and csGB2312
+ (according to IANA registry).
+ Reported by Bruno Haible <haible@ilog.fr>.
+
+ * iconvdata/johab.c: Correct completely broken conversion to JOHAB.
+
* locale/categories.def: Remove most of the collate definitions.
* locale/langinfo.h: Comment out corresponding definitions.
* locale/programs/locale-spec.c (locale_special): Don't recognize the
diff --git a/FAQ b/FAQ
index fe08cb1539..44558ee4ed 100644
--- a/FAQ
+++ b/FAQ
@@ -170,6 +170,7 @@ please let me know.
daylight saving time is in effect the timezone string is EST.
4.6. I've build make 3.77 against glibc 2.1 and now make gets
segmentation faults.
+4.7. Why do so many programs using math functions fail on my AlphaStation?
~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~
@@ -1705,6 +1706,15 @@ filesystem support :-( ). To get a working make you can use either make
3.75 or patch 3.77. A working patch is available via RedHat's Rawhide server
(ftp://rawhide.redhat.com/SRPMS/SRPMS/make-3.77-*src.rpm).
+
+4.7. Why do so many programs using math functions fail on my AlphaStation?
+
+{AO} The functions floor() and floorf() use an instruction that is not
+implemented in some old PALcodes of AlphaStations. This may cause
+`Illegal Instruction' core dumps or endless loops in programs that
+catch these signals. Updating the firmware to a 1999 release has
+fixed the problem on an AlphaStation 200 4/166.
+
~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~ ~
@@ -1721,6 +1731,7 @@ Answers were given by:
{GK} Geoffrey Keating, <geoffk@ozemail.com.au>
{HJ} H.J. Lu, <hjl@gnu.org>
{CG} Cristian Gafton, <gafton@redhat.com>
+{AO} Alexandre Oliva, <oliva@lsd.ic.unicamp.br>
Local Variables:
mode:outline
diff --git a/FAQ.in b/FAQ.in
index 391e756eac..61b663ce08 100644
--- a/FAQ.in
+++ b/FAQ.in
@@ -1473,6 +1473,14 @@ filesystem support :-( ). To get a working make you can use either make
3.75 or patch 3.77. A working patch is available via RedHat's Rawhide server
(ftp://rawhide.redhat.com/SRPMS/SRPMS/make-3.77-*src.rpm).
+?? Why do so many programs using math functions fail on my AlphaStation?
+
+{AO} The functions floor() and floorf() use an instruction that is not
+implemented in some old PALcodes of AlphaStations. This may cause
+`Illegal Instruction' core dumps or endless loops in programs that
+catch these signals. Updating the firmware to a 1999 release has
+fixed the problem on an AlphaStation 200 4/166.
+
Answers were given by:
{UD} Ulrich Drepper, <drepper@cygnus.com>
@@ -1487,6 +1495,7 @@ Answers were given by:
{GK} Geoffrey Keating, <geoffk@ozemail.com.au>
{HJ} H.J. Lu, <hjl@gnu.org>
{CG} Cristian Gafton, <gafton@redhat.com>
+{AO} Alexandre Oliva, <oliva@lsd.ic.unicamp.br>
Local Variables:
mode:outline
diff --git a/iconv/gconv.c b/iconv/gconv.c
index 6e3080b0e9..b9c404ac03 100644
--- a/iconv/gconv.c
+++ b/iconv/gconv.c
@@ -39,7 +39,7 @@ __gconv (__gconv_t cd, const unsigned char **inbuf,
assert (converted != NULL);
*converted = 0;
- cd->__data[last_step].__outbuf = *outbuf;
+ cd->__data[last_step].__outbuf = outbuf != NULL ? *outbuf : NULL;
cd->__data[last_step].__outbufend = outbufend;
if (inbuf == NULL || *inbuf == NULL)
diff --git a/iconv/iconv.c b/iconv/iconv.c
index ee16d3b091..c1b96164e5 100644
--- a/iconv/iconv.c
+++ b/iconv/iconv.c
@@ -39,9 +39,12 @@ iconv (iconv_t cd, const char **inbuf, size_t *inbytesleft, char **outbuf,
if (inbuf == NULL || *inbuf == NULL)
{
- result = __gconv (gcd, NULL, NULL, (unsigned char **) outbuf,
- (unsigned char *) (outstart + *outbytesleft),
- &converted);
+ if (outbuf == NULL || *outbuf == NULL)
+ result = __gconv (gcd, NULL, NULL, NULL, NULL, &converted);
+ else
+ result = __gconv (gcd, NULL, NULL, (unsigned char **) outbuf,
+ (unsigned char *) (outstart + *outbytesleft),
+ &converted);
}
else
{
diff --git a/iconvdata/gconv-modules b/iconvdata/gconv-modules
index 9228ff62fa..e64e88e767 100644
--- a/iconvdata/gconv-modules
+++ b/iconvdata/gconv-modules
@@ -648,7 +648,7 @@ module INTERNAL IBM500// IBM500 1
# from to module cost
alias CP850// IBM850//
alias 850// IBM850//
-alias CSPC8MULTILINGUAL// IBM850//
+alias CSPC850MULTILINGUAL// IBM850//
alias OSF10020352// IBM850//
module IBM850// INTERNAL IBM850 1
module INTERNAL IBM850// IBM850 1
@@ -702,7 +702,7 @@ module INTERNAL IBM861// IBM861 1
# from to module cost
alias CP862// IBM862//
alias 862// IBM862//
-alias CSPC8LATINHEBREW// IBM862//
+alias CSPC862LATINHEBREW// IBM862//
alias OSF1002035E// IBM862//
module IBM862// INTERNAL IBM862 1
module INTERNAL IBM862// IBM862 1
@@ -881,6 +881,8 @@ module INTERNAL EUC-JP// EUC-JP 1
# from to module cost
alias EUCCN// EUC-CN//
+alias GB2312// EUC-CN//
+alias csGB2312// EUC-CN//
module EUC-CN// INTERNAL EUC-CN 1
module INTERNAL EUC-CN// EUC-CN 1
diff --git a/iconvdata/johab.c b/iconvdata/johab.c
index 21a9c9b6a6..4cff932c2f 100644
--- a/iconvdata/johab.c
+++ b/iconvdata/johab.c
@@ -64,12 +64,12 @@ static const uint32_t init_to_ucs[19] =
0x314c, 0x314d, 0x314e
};
-static const uint32_t final_to_ucs[27] =
+static const uint32_t final_to_ucs[31] =
{
L'\0', L'\0', 0x3133, L'\0', 0x3135, 0x3136, L'\0', L'\0',
0x313a, 0x313b, 0x314c, 0x313d, 0x313e, 0x313f,
- 0x3140, L'\0', L'\0', 0x3144, L'\0', L'\0', L'\0',
- L'\0', L'\0', L'\0', L'\0', L'\0', L'\0'
+ 0x3140, L'\0', L'\0', L'\0', 0x3144, L'\0', L'\0', L'\0',
+ L'\0', L'\0', L'\0', L'\0', L'\0', L'\0', L'\0', L'\0', L'\0'
};
/* The following three arrays are used to convert
@@ -307,18 +307,18 @@ johab_sym_hanja_to_ucs (uint_fast32_t idx, uint_fast32_t c1, uint_fast32_t c2)
{ \
if (ch >= 0xac00 && ch <= 0xd7a3) \
{ \
- ch -= 0xac00; \
- \
- ch = (init_to_bit[ch / 588] /* 21 * 28 = 588 */ \
- + mid_to_bit[(ch / 28) % 21]/* (ch % (21 * 28)) / 28 */ \
- + final_to_bit[ch % 28]); /* (ch % (21 * 28)) % 28 */ \
- \
if (NEED_LENGTH_TEST && outptr + 2 > outend) \
{ \
result = __GCONV_FULL_OUTPUT; \
break; \
} \
\
+ ch -= 0xac00; \
+ \
+ ch = (init_to_bit[ch / 588] /* 21 * 28 = 588 */ \
+ + mid_to_bit[(ch / 28) % 21]/* (ch % (21 * 28)) / 28 */ \
+ + final_to_bit[ch % 28]); /* (ch % (21 * 28)) % 28 */ \
+ \
*outptr++ = ch / 256; \
*outptr++ = ch % 256; \
} \
@@ -337,9 +337,11 @@ johab_sym_hanja_to_ucs (uint_fast32_t idx, uint_fast32_t c1, uint_fast32_t c2)
*outptr++ = ch / 256; \
*outptr++ = ch % 256; \
} \
- if ((ch >= 0x4e00 && ch <= 0x9fa5) || (ch >= 0xf900 && ch <= 0xfa0b)) \
+ else if ((ch >= 0x4e00 && ch <= 0x9fa5) \
+ || (ch >= 0xf900 && ch <= 0xfa0b)) \
{ \
size_t written; \
+ uint32_t temp; \
\
written = ucs4_to_ksc5601_hanja (ch, outptr, \
(NEED_LENGTH_TEST \
@@ -356,13 +358,13 @@ johab_sym_hanja_to_ucs (uint_fast32_t idx, uint_fast32_t c1, uint_fast32_t c2)
} \
\
outptr[0] -= 0x4a; \
- outptr[1] += 0x80; \
+ outptr[1] -= 0x21; \
\
- outptr[1] += (outptr[0] % 2 \
- ? 0 : (outptr[1] > 0xee ? 0x43 : 0x31)); \
- outptr[1] -= 0xa1; \
- outptr[0] /= 2; \
- outptr[0] += 0xe0; \
+ temp = outptr[0] * 94 + outptr[1]; \
+ \
+ outptr[0] = 0xe0 + temp / 188; \
+ outptr[1] = temp % 188; \
+ outptr[1] += outptr[1] >= 78 ? 0x43 : 0x31; \
\
outptr += 2; \
} \
diff --git a/linuxthreads/ChangeLog b/linuxthreads/ChangeLog
index 867e5e34cc..e994dcc297 100644
--- a/linuxthreads/ChangeLog
+++ b/linuxthreads/ChangeLog
@@ -1,3 +1,8 @@
+1999-12-20 Andreas Jaeger <aj@suse.de>
+
+ * pthread.c (pthread_initialize): Move getrlimit call after
+ setting of errno.
+
1999-12-18 Ulrich Drepper <drepper@cygnus.com>
* Versions: Export pread, __pread64, pread64, pwrite, __pwrite64,
diff --git a/linuxthreads/pthread.c b/linuxthreads/pthread.c
index a9083635b6..dfde08f432 100644
--- a/linuxthreads/pthread.c
+++ b/linuxthreads/pthread.c
@@ -299,14 +299,6 @@ static void pthread_initialize(void)
STACK_SIZE boundary. */
__pthread_initial_thread_bos =
(char *)(((long)CURRENT_STACK_FRAME - 2 * STACK_SIZE) & ~(STACK_SIZE - 1));
- /* Play with the stack size limit to make sure that no stack ever grows
- beyond STACK_SIZE minus one page (to act as a guard page). */
- getrlimit(RLIMIT_STACK, &limit);
- max_stack = STACK_SIZE - __getpagesize();
- if (limit.rlim_cur > max_stack) {
- limit.rlim_cur = max_stack;
- setrlimit(RLIMIT_STACK, &limit);
- }
/* Update the descriptor for the initial thread. */
__pthread_initial_thread.p_pid = __getpid();
/* If we have special thread_self processing, initialize that for the
@@ -317,6 +309,14 @@ static void pthread_initialize(void)
/* The errno/h_errno variable of the main thread are the global ones. */
__pthread_initial_thread.p_errnop = &_errno;
__pthread_initial_thread.p_h_errnop = &_h_errno;
+ /* Play with the stack size limit to make sure that no stack ever grows
+ beyond STACK_SIZE minus one page (to act as a guard page). */
+ getrlimit(RLIMIT_STACK, &limit);
+ max_stack = STACK_SIZE - __getpagesize();
+ if (limit.rlim_cur > max_stack) {
+ limit.rlim_cur = max_stack;
+ setrlimit(RLIMIT_STACK, &limit);
+ }
/* Likewise for the resolver state _res. */
__pthread_initial_thread.p_resp = &_res;
#ifdef __SIGRTMIN
diff --git a/sysdeps/unix/sysv/linux/fxstat64.c b/sysdeps/unix/sysv/linux/fxstat64.c
index b88a78c7a5..e2fce6d466 100644
--- a/sysdeps/unix/sysv/linux/fxstat64.c
+++ b/sysdeps/unix/sysv/linux/fxstat64.c
@@ -24,6 +24,7 @@
#include <sysdep.h>
#include <sys/syscall.h>
+#include "kernel-features.h"
#if __ASSUME_STAT64_SYSCALL == 0
# include <xstatconv.c>
diff --git a/sysdeps/unix/sysv/linux/i386/getmsg.c b/sysdeps/unix/sysv/linux/i386/getmsg.c
new file mode 100644
index 0000000000..6031a1b9cd
--- /dev/null
+++ b/sysdeps/unix/sysv/linux/i386/getmsg.c
@@ -0,0 +1,41 @@
+/* Copyright (C) 1998, 1999 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. */
+
+#include <errno.h>
+#include <stddef.h>
+#include <stropts.h>
+
+#include <sysdep.h>
+#include <sys/syscall.h>
+
+extern int __syscall_getpmsg (int fildes, struct strbuf *ctlptr,
+ struct strbuf *dataptr, int *bandp, int *flagsp);
+
+#ifdef __NR_getpmsg
+int
+getmsg (fildes, ctlptr, dataptr, flagsp)
+ int fildes;
+ struct strbuf *ctlptr;
+ struct strbuf *dataptr;
+ int *flagsp;
+{
+ return INLINE_SYSCALL (getpmsg, 5, fildes, ctlptr, dataptr, NULL, flagsp);
+}
+#else
+# include <sysdeps/generic/getmsg.c>
+#endif
diff --git a/sysdeps/unix/sysv/linux/i386/getpmsg.c b/sysdeps/unix/sysv/linux/i386/getpmsg.c
new file mode 100644
index 0000000000..2fa6d654fa
--- /dev/null
+++ b/sysdeps/unix/sysv/linux/i386/getpmsg.c
@@ -0,0 +1,41 @@
+/* Copyright (C) 1998, 1999 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. */
+
+#include <errno.h>
+#include <stropts.h>
+
+#include <sysdep.h>
+#include <sys/syscall.h>
+
+extern int __syscall_getpmsg (int fildes, struct strbuf *ctlptr,
+ struct strbuf *dataptr, int *bandp, int *flagsp);
+
+#ifdef __NR_getpmsg
+int
+getpmsg (fildes, ctlptr, dataptr, bandp, flagsp)
+ int fildes;
+ struct strbuf *ctlptr;
+ struct strbuf *dataptr;
+ int *bandp;
+ int *flagsp;
+{
+ return INLINE_SYSCALL (getpmsg, 5, fildes, ctlptr, dataptr, bandp, flagsp);
+}
+#else
+# include <sysdeps/generic/getpmsg.c>
+#endif
diff --git a/sysdeps/unix/sysv/linux/i386/putmsg.c b/sysdeps/unix/sysv/linux/i386/putmsg.c
new file mode 100644
index 0000000000..bdb98f8c38
--- /dev/null
+++ b/sysdeps/unix/sysv/linux/i386/putmsg.c
@@ -0,0 +1,42 @@
+/* Copyright (C) 1998, 1999 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. */
+
+#include <errno.h>
+#include <stddef.h>
+#include <stropts.h>
+
+#include <sysdep.h>
+#include <sys/syscall.h>
+
+extern int __syscall_putpmsg (int fildes, const struct strbuf *ctlptr,
+ const struct strbuf *dataptr, int band,
+ int flags);
+
+#ifdef __NR_putpmsg
+int
+putmsg (fildes, ctlptr, dataptr, flags)
+ int fildes;
+ const struct strbuf *ctlptr;
+ const struct strbuf *dataptr;
+ int flags;
+{
+ return INLINE_SYSCALL (putpmsg, 5, fildes, ctlptr, dataptr, -1, flags);
+}
+#else
+# include <sysdeps/generic/putmsg.c>
+#endif
diff --git a/sysdeps/unix/sysv/linux/i386/putpmsg.c b/sysdeps/unix/sysv/linux/i386/putpmsg.c
new file mode 100644
index 0000000000..02d4881a80
--- /dev/null
+++ b/sysdeps/unix/sysv/linux/i386/putpmsg.c
@@ -0,0 +1,42 @@
+/* Copyright (C) 1998, 1999 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. */
+
+#include <errno.h>
+#include <stropts.h>
+
+#include <sysdep.h>
+#include <sys/syscall.h>
+
+extern int __syscall_putpmsg (int fildes, const struct strbuf *ctlptr,
+ const struct strbuf *dataptr, int band,
+ int flags);
+
+#ifdef __NR_putpmsg
+int
+putpmsg (fildes, ctlptr, dataptr, band, flags)
+ int fildes;
+ const struct strbuf *ctlptr;
+ const struct strbuf *dataptr;
+ int band;
+ int flags;
+{
+ return INLINE_SYSCALL (putpmsg, 5, fildes, ctlptr, dataptr, band, flags);
+}
+#else
+# include <sysdeps/generic/putpmsg.c>
+#endif
diff --git a/sysdeps/unix/sysv/linux/lxstat64.c b/sysdeps/unix/sysv/linux/lxstat64.c
index 9db8fcf455..79a29fb894 100644
--- a/sysdeps/unix/sysv/linux/lxstat64.c
+++ b/sysdeps/unix/sysv/linux/lxstat64.c
@@ -24,6 +24,7 @@
#include <sysdep.h>
#include <sys/syscall.h>
+#include "kernel-features.h"
#if __ASSUME_STAT64_SYSCALL == 0
# include <xstatconv.c>
diff --git a/sysdeps/unix/sysv/linux/m68k/getmsg.c b/sysdeps/unix/sysv/linux/m68k/getmsg.c
new file mode 100644
index 0000000000..329cb805ec
--- /dev/null
+++ b/sysdeps/unix/sysv/linux/m68k/getmsg.c
@@ -0,0 +1 @@
+include <sysdeps/unix/sysv/linux/i386/getmsg.c>
diff --git a/sysdeps/unix/sysv/linux/m68k/getpmsg.c b/sysdeps/unix/sysv/linux/m68k/getpmsg.c
new file mode 100644
index 0000000000..5b1b7559fe
--- /dev/null
+++ b/sysdeps/unix/sysv/linux/m68k/getpmsg.c
@@ -0,0 +1 @@
+include <sysdeps/unix/sysv/linux/i386/getpmsg.c>
diff --git a/sysdeps/unix/sysv/linux/m68k/putmsg.c b/sysdeps/unix/sysv/linux/m68k/putmsg.c
new file mode 100644
index 0000000000..c744bf27f1
--- /dev/null
+++ b/sysdeps/unix/sysv/linux/m68k/putmsg.c
@@ -0,0 +1 @@
+include <sysdeps/unix/sysv/linux/i386/putmsg.c>
diff --git a/sysdeps/unix/sysv/linux/m68k/putpmsg.c b/sysdeps/unix/sysv/linux/m68k/putpmsg.c
new file mode 100644
index 0000000000..8744136708
--- /dev/null
+++ b/sysdeps/unix/sysv/linux/m68k/putpmsg.c
@@ -0,0 +1 @@
+include <sysdeps/unix/sysv/linux/i386/putpmsg.c>
diff --git a/sysdeps/unix/sysv/linux/mips/getmsg.c b/sysdeps/unix/sysv/linux/mips/getmsg.c
new file mode 100644
index 0000000000..329cb805ec
--- /dev/null
+++ b/sysdeps/unix/sysv/linux/mips/getmsg.c
@@ -0,0 +1 @@
+include <sysdeps/unix/sysv/linux/i386/getmsg.c>
diff --git a/sysdeps/unix/sysv/linux/mips/getpmsg.c b/sysdeps/unix/sysv/linux/mips/getpmsg.c
new file mode 100644
index 0000000000..5b1b7559fe
--- /dev/null
+++ b/sysdeps/unix/sysv/linux/mips/getpmsg.c
@@ -0,0 +1 @@
+include <sysdeps/unix/sysv/linux/i386/getpmsg.c>
diff --git a/sysdeps/unix/sysv/linux/mips/putmsg.c b/sysdeps/unix/sysv/linux/mips/putmsg.c
new file mode 100644
index 0000000000..c744bf27f1
--- /dev/null
+++ b/sysdeps/unix/sysv/linux/mips/putmsg.c
@@ -0,0 +1 @@
+include <sysdeps/unix/sysv/linux/i386/putmsg.c>
diff --git a/sysdeps/unix/sysv/linux/mips/putpmsg.c b/sysdeps/unix/sysv/linux/mips/putpmsg.c
new file mode 100644
index 0000000000..8744136708
--- /dev/null
+++ b/sysdeps/unix/sysv/linux/mips/putpmsg.c
@@ -0,0 +1 @@
+include <sysdeps/unix/sysv/linux/i386/putpmsg.c>
diff --git a/sysdeps/unix/sysv/linux/powerpc/getmsg.c b/sysdeps/unix/sysv/linux/powerpc/getmsg.c
new file mode 100644
index 0000000000..329cb805ec
--- /dev/null
+++ b/sysdeps/unix/sysv/linux/powerpc/getmsg.c
@@ -0,0 +1 @@
+include <sysdeps/unix/sysv/linux/i386/getmsg.c>
diff --git a/sysdeps/unix/sysv/linux/powerpc/getpmsg.c b/sysdeps/unix/sysv/linux/powerpc/getpmsg.c
new file mode 100644
index 0000000000..5b1b7559fe
--- /dev/null
+++ b/sysdeps/unix/sysv/linux/powerpc/getpmsg.c
@@ -0,0 +1 @@
+include <sysdeps/unix/sysv/linux/i386/getpmsg.c>
diff --git a/sysdeps/unix/sysv/linux/powerpc/putmsg.c b/sysdeps/unix/sysv/linux/powerpc/putmsg.c
new file mode 100644
index 0000000000..c744bf27f1
--- /dev/null
+++ b/sysdeps/unix/sysv/linux/powerpc/putmsg.c
@@ -0,0 +1 @@
+include <sysdeps/unix/sysv/linux/i386/putmsg.c>
diff --git a/sysdeps/unix/sysv/linux/powerpc/putpmsg.c b/sysdeps/unix/sysv/linux/powerpc/putpmsg.c
new file mode 100644
index 0000000000..8744136708
--- /dev/null
+++ b/sysdeps/unix/sysv/linux/powerpc/putpmsg.c
@@ -0,0 +1 @@
+include <sysdeps/unix/sysv/linux/i386/putpmsg.c>
diff --git a/sysdeps/unix/sysv/linux/powerpc/syscalls.list b/sysdeps/unix/sysv/linux/powerpc/syscalls.list
index c207270a86..abe89ed616 100644
--- a/sysdeps/unix/sysv/linux/powerpc/syscalls.list
+++ b/sysdeps/unix/sysv/linux/powerpc/syscalls.list
@@ -14,6 +14,7 @@ rt_sigsuspend - rt_sigsuspend 2 __syscall_rt_sigsuspend
rt_sigtimedwait - rt_sigtimedwait 4 __syscall_rt_sigtimedwait
s_getcwd getcwd getcwd 2 __syscall_getcwd
s_getdents getdents getdents 3 __syscall_getdents
+s_getpmsg getpmsg getpmsg 5 __syscall_getpmsg
s_getpriority getpriority getpriority 2 __syscall_getpriority
s_getresgid getresgid getresgid 3 __syscall_getresgid
s_getresuid getresuid getresuid 3 __syscall_getresuid
@@ -21,6 +22,7 @@ s_getrlimit getrlimit getrlimit 2 __syscall_getrlimit
s_poll poll poll 3 __syscall_poll
s_pread64 pread64 pread 5 __syscall_pread
s_ptrace ptrace ptrace 4 __syscall_ptrace
+s_putpmsg putpmsg putpmsg 5 __syscall_putpmsg
s_pwrite64 pwrite64 pwrite 5 __syscall_pwrite
s_reboot reboot reboot 3 __syscall_reboot
s_setrlimit setrlimit setrlimit 3 __syscall_setrlimit
diff --git a/sysdeps/unix/sysv/linux/xstat64.c b/sysdeps/unix/sysv/linux/xstat64.c
index 07b7f208e4..b2a83e6530 100644
--- a/sysdeps/unix/sysv/linux/xstat64.c
+++ b/sysdeps/unix/sysv/linux/xstat64.c
@@ -1,5 +1,5 @@
/* xstat64 using old-style Unix stat system call.
- Copyright (C) 1991, 1995, 1996, 1997, 1998, 1999 Free Software Foundation, Inc.
+ Copyright (C) 1991, 95, 96, 97, 98, 99 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
@@ -24,6 +24,7 @@
#include <sysdep.h>
#include <sys/syscall.h>
+#include "kernel-features.h"
#if __ASSUME_STAT64_SYSCALL == 0
# include <xstatconv.c>
@@ -63,7 +64,7 @@ __xstat64 (int vers, const char *name, struct stat64 *buf)
have_no_stat64 = 1;
}
# endif
-
+
result = INLINE_SYSCALL (stat, 2, name, &kbuf);
if (result == 0)
result = xstat64_conv (vers, &kbuf, buf);