about summary refs log tree commit diff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog68
-rw-r--r--linuxthreads/ChangeLog5
-rw-r--r--linuxthreads/sysdeps/unix/sysv/linux/bits/local_lim.h12
-rw-r--r--manual/top-menu.texi2
-rw-r--r--string/bits/string2.h8
-rw-r--r--sysdeps/gnu/bits/utmp.h2
-rw-r--r--sysdeps/gnu/bits/utmpx.h10
-rw-r--r--sysdeps/unix/sysv/linux/Dist1
-rw-r--r--sysdeps/unix/sysv/linux/Makefile2
-rw-r--r--sysdeps/unix/sysv/linux/bits/local_lim.h14
-rw-r--r--sysdeps/unix/sysv/linux/netlink/netlink.h126
11 files changed, 237 insertions, 13 deletions
diff --git a/ChangeLog b/ChangeLog
index 8175e0b6df..7966eccb53 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,71 @@
+1998-11-12  Ulrich Drepper  <drepper@cygnus.com>
+
+	* inet/netinet/in.h: Add a few more IPPROTO_* macros.
+
+	* libio/Makefile (headers): Add bits/stdio.h.
+	* libio/iofread_u.c: Undefine fread_unlocked before definition.
+	* libio/iofwrite_u.c: Undefine fwrite_unlocked before definition.
+	* libio/stdio.h: Move optimizations into ...
+	* libio/bits/stdio.h: ...here.  New file.
+
+	* libio/iofread.c: Pretty print.
+
+1998-11-12  Mark Kettenis  <kettenis@phys.uva.nl>
+
+	* sysdeps/gnu/bits/utmpx.h: Protect members of struct
+	__exit_status with `__'.  Rename pad member of struct utmpx to
+	__unused.
+	(RUN_LVL): Define unconditionally.
+	* sysdeps/gnu/bits/utmp.h: Rename pad member of struct utmpx to
+	__unused.
+
+1998-11-12  Philip Blundell  <philb@gnu.org>
+
+	* sysdeps/unix/sysv/linux/netlink/netlink.h: New file, support for
+	Linux AF_NETLINK sockets (needed since the kernel version is
+	unusable).
+	* sysdeps/unix/sysv/linux/Makefile: Install it.
+	* sysdeps/unix/sysv/linux/Dist: Distribute it.
+
+1998-11-12  Andreas Jaeger  <aj@arthur.rhein-neckar.de>
+
+	* timezone/tst-timezone.c (tests): Add entry for America/Chicago
+	to test for bug in PR libc/863.
+
+1998-11-12  Ulrich Drepper  <drepper@cygnus.com>
+
+	* sysdeps/unix/sysv/linux/mips/bits/fcntl.h: Cleanup comment.
+
+	* elf/dynamic-link.h (_ELF_DYNAMIC_DO_RELOC): Rename macro
+	parameter lazy to do_lazy to avoid clashing with struct member name.
+	Reported by Ralf Baechle <ralf@uni-koblenz.de>.
+
+1998-11-10  H.J. Lu  <hjl@gnu.org>
+
+	* sysdeps/unix/sysv/linux/bits/local_lim.h: Undefine NR_OPEN
+	if it is defined in <linux/limits.h>.
+
+1998-11-09 13:07 -0500  Zack Weinberg  <zack@rabi.phys.columbia.edu>
+
+	* include/protocols/routed.h: Include the real header with
+	a full path from the top of the source tree.
+	* include/protocols/rwhod.h: Likewise.
+	* include/protocols/talkd.h: Likewise.
+	* include/protocols/timed.h: Likewise.
+
+	* timezone/Makefile: Don't include z.ZONE files if no_deps
+	is set, not if avoid-generated is set.
+
+1998-11-12  Ulrich Drepper  <drepper@cygnus.com>
+
+	* signal/signal.h: Undo last change.  Get definition of timespec
+	if __USE_POSIX199309.
+
+	* string/bits/string2.h (__strpbrk_c2): Add intermediate cast to
+	size_t to prevent gcc warning when using -Wqual-cast.
+	(__strpbrk_c3): Likewise.
+	Suggested by Alan Curry <pacman@cqc.com>.
+
 1998-11-11  Roland McGrath  <roland@baalperazim.frob.com>
 
 	* hurd/hurdsig.c (_hurdsig_init): Add assertion that no pending,
diff --git a/linuxthreads/ChangeLog b/linuxthreads/ChangeLog
index dc044ad2ae..e09b59957a 100644
--- a/linuxthreads/ChangeLog
+++ b/linuxthreads/ChangeLog
@@ -1,3 +1,8 @@
+1998-11-10  H.J. Lu  <hjl@gnu.org>
+
+	* sysdeps/unix/sysv/linux/bits/local_lim.h: Undefine NR_OPEN
+	if it is defined in <linux/limits.h>.
+
 1998-10-29 14:28  Ulrich Drepper  <drepper@cygnus.com>
 
 	* spinlock.h (__pthread_trylock): Define inline.
diff --git a/linuxthreads/sysdeps/unix/sysv/linux/bits/local_lim.h b/linuxthreads/sysdeps/unix/sysv/linux/bits/local_lim.h
index f884863ffa..545a90b2ed 100644
--- a/linuxthreads/sysdeps/unix/sysv/linux/bits/local_lim.h
+++ b/linuxthreads/sysdeps/unix/sysv/linux/bits/local_lim.h
@@ -17,9 +17,21 @@
    write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
    Boston, MA 02111-1307, USA.  */
 
+/* The kernel header pollutes the namespace with the NR_OPEN symbol.
+   Remove this after including the header if necessary.  */
+#ifndef NR_OPEN
+# define __undef_NR_OPEN
+#endif
+
 /* The kernel sources contain a file with all the needed information.  */
 #include <linux/limits.h>
 
+/* Have to remove NR_OPEN?  */
+#ifdef __undef_NR_OPEN
+# undef NR_OPEN
+# undef __undef_NR_OPEN
+#endif
+
 /* The number of data keys per process.  */
 #define _POSIX_THREAD_KEYS_MAX	128
 /* This is the value this implementation supports.  */
diff --git a/manual/top-menu.texi b/manual/top-menu.texi
index b08ab50d3a..f14e172794 100644
--- a/manual/top-menu.texi
+++ b/manual/top-menu.texi
@@ -1150,8 +1150,10 @@ Floating Type Macros
 Installation
 
 * Configuring and compiling::   How to compile and test GNU libc.
+* Running make install::        How to install it once you've got it compiled.
 * Tools for Compilation::       You'll need these first.
 * Supported Configurations::    What it runs on, what it doesn't.
+* Linux::                       Specific advice for Linux systems.
 * Reporting Bugs::              So they'll get fixed.
 
 Maintenance
diff --git a/string/bits/string2.h b/string/bits/string2.h
index 4efa5251f7..4904a3e4c0 100644
--- a/string/bits/string2.h
+++ b/string/bits/string2.h
@@ -822,7 +822,7 @@ __strpbrk_c2 (__const char *__s, char __accept1, char __accept2)
   /* Please note that __accept1 and __accept2 never can be '\0'.  */
   while (*__s != '\0' && *__s != __accept1 && *__s != __accept2)
     ++__s;
-  return *__s == '\0' ? NULL : (char *) __s;
+  return *__s == '\0' ? NULL : (char *) (size_t) __s;
 }
 
 __STRING_INLINE char *__strpbrk_c3 (__const char *__s, char __accept1,
@@ -835,7 +835,7 @@ __strpbrk_c3 (__const char *__s, char __accept1, char __accept2,
   while (*__s != '\0' && *__s != __accept1 && *__s != __accept2
 	 && *__s != __accept3)
     ++__s;
-  return *__s == '\0' ? NULL : (char *) __s;
+  return *__s == '\0' ? NULL : (char *) (size_t) __s;
 }
 #endif
 
@@ -845,7 +845,7 @@ __strpbrk_c3 (__const char *__s, char __accept1, char __accept2,
 # define strstr(haystack, needle) \
   (__extension__ (__builtin_constant_p (needle) && __string2_1bptr_p (needle) \
 		  ? (((__const char *) (needle))[0] == '\0'		      \
-		     ? (char *) (haystack)				      \
+		     ? (char *) (size_t) (haystack)			      \
 		     : (((__const char *) (needle))[1] == '\0'		      \
 			? strchr (haystack,				      \
 				  ((__const char *) (needle))[0]) 	      \
@@ -1011,7 +1011,7 @@ __strsep_g (char **__s, __const char *__reject)
 #endif
 
 /* We need the memory allocation functions for inline strdup().
-   Referring to stdlib.h (even minimally) is not allowed 
+   Referring to stdlib.h (even minimally) is not allowed
    in any of the tight standards compliant modes.  */
 #ifdef __USE_MISC
 
diff --git a/sysdeps/gnu/bits/utmp.h b/sysdeps/gnu/bits/utmp.h
index 6a0beb61a9..9310e33ef9 100644
--- a/sysdeps/gnu/bits/utmp.h
+++ b/sysdeps/gnu/bits/utmp.h
@@ -63,7 +63,7 @@ struct utmp
     long ut_session;		/* Session ID, used for windowing.  */
     struct timeval ut_tv;	/* Time entry was made.  */
     int32_t ut_addr_v6[4];	/* Internet address of remote host.  */
-    char pad[20];		/* Reserved for future use.  */
+    char __unused[20];		/* Reserved for future use.  */
   };
 
 /* Backwards compatibility hacks.  */
diff --git a/sysdeps/gnu/bits/utmpx.h b/sysdeps/gnu/bits/utmpx.h
index b367bfba3c..b7613a1bee 100644
--- a/sysdeps/gnu/bits/utmpx.h
+++ b/sysdeps/gnu/bits/utmpx.h
@@ -40,8 +40,8 @@
    type is used in `struct utmpx' below.  */
 struct __exit_status
   {
-    short int e_termination;	/* Process termination status.  */
-    short int e_exit;		/* Process exit status.  */
+    short int __e_termination;	/* Process termination status.  */
+    short int __e_exit;		/* Process exit status.  */
   };
 
 
@@ -59,16 +59,14 @@ struct utmpx
   long int ut_session;		/* Session ID, used for windowing.  */
   struct timeval ut_tv;		/* Time entry was made.  */
   __int32_t ut_addr_v6[4];	/* Internet address of remote host.  */
-  char pad[20];			/* Reserved for future use.  */
+  char __unused[20];		/* Reserved for future use.  */
 };
 
 
 /* Values for the `ut_type' field of a `struct utmpx'.  */
 #define EMPTY		0	/* No valid user accounting information.  */
 
-#ifdef __USE_GNU
-# define RUN_LVL	1	/* The system's runlevel.  */
-#endif
+#define RUN_LVL		1	/* The system's runlevel.  */
 #define BOOT_TIME	2	/* Time of system boot.  */
 #define NEW_TIME	3	/* Time after system clock changed.  */
 #define OLD_TIME	4	/* Time when system clock changed.  */
diff --git a/sysdeps/unix/sysv/linux/Dist b/sysdeps/unix/sysv/linux/Dist
index 43ab8ba39f..5573247711 100644
--- a/sysdeps/unix/sysv/linux/Dist
+++ b/sysdeps/unix/sysv/linux/Dist
@@ -35,6 +35,7 @@ netinet/if_tr.h
 netinet/igmp.h
 netinet/in_systm.h
 netinet/ip_fw.h
+netlink/netlink.h
 netpacket/packet.h
 netipx/ipx.h
 netrom/netrom.h
diff --git a/sysdeps/unix/sysv/linux/Makefile b/sysdeps/unix/sysv/linux/Makefile
index fe357bcb05..206bce4787 100644
--- a/sysdeps/unix/sysv/linux/Makefile
+++ b/sysdeps/unix/sysv/linux/Makefile
@@ -84,7 +84,7 @@ sysdep_headers += sys/socketvar.h netinet/in_systm.h netinet/ip_fw.h \
 		  netinet/if_fddi.h netinet/if_tr.h netinet/igmp.h \
 		  netipx/ipx.h netash/ash.h netax25/ax25.h netatalk/at.h \
 		  netrom/netrom.h netpacket/packet.h netrose/rose.h \
-		  neteconet/ec.h
+		  neteconet/ec.h netlink/netlink.h
 endif
 
 # Don't compile the ctype glue code, since there is no old non-GNU C library.
diff --git a/sysdeps/unix/sysv/linux/bits/local_lim.h b/sysdeps/unix/sysv/linux/bits/local_lim.h
index 2674aa709e..9c69e4bdc9 100644
--- a/sysdeps/unix/sysv/linux/bits/local_lim.h
+++ b/sysdeps/unix/sysv/linux/bits/local_lim.h
@@ -1,5 +1,5 @@
 /* Minimum guaranteed maximum values for system limits.  Linux version.
-   Copyright (C) 1993, 1994, 1995, 1996, 1997 Free Software Foundation, Inc.
+   Copyright (C) 1993, 94, 95, 96, 97, 98 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
@@ -17,9 +17,21 @@
    write to the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
    Boston, MA 02111-1307, USA.  */
 
+/* The kernel header pollutes the namespace with the NR_OPEN symbol.
+   Remove this after including the header if necessary.  */
+#ifndef NR_OPEN
+# define __undef_NR_OPEN
+#endif
+
 /* The kernel sources contain a file with all the needed information.  */
 #include <linux/limits.h>
 
+/* Have to remove NR_OPEN?  */
+#ifdef __undef_NR_OPEN
+# undef NR_OPEN
+# undef __undef_NR_OPEN
+#endif
+
 /* Maximum amount by which a process can descrease its asynchronous I/O
    priority level.  */
 #define AIO_PRIO_DELTA_MAX	20
diff --git a/sysdeps/unix/sysv/linux/netlink/netlink.h b/sysdeps/unix/sysv/linux/netlink/netlink.h
new file mode 100644
index 0000000000..9d75698d8e
--- /dev/null
+++ b/sysdeps/unix/sysv/linux/netlink/netlink.h
@@ -0,0 +1,126 @@
+/* Definitions for use with Linux AF_NETLINK sockets.
+   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.  */
+
+#ifndef __NETLINK_NETLINK_H
+#define __NETLINK_NETLINK_H	1
+
+#include <features.h>
+
+#include <sys/types.h>
+#include <bits/sockaddr.h>
+
+__BEGIN_DECLS
+
+struct sockaddr_nl
+  {
+    __SOCKADDR_COMMON (nl_);
+    unsigned short nl_pad;		/* zero.  */
+    uint32_t nl_pid;			/* process pid.  */
+    uint32_t nl_groups;			/* multicast groups mask.  */
+  };
+
+#define NETLINK_ROUTE		0	/* Routing/device hook.  */
+#define NETLINK_SKIP		1	/* Reserved for ENskip.  */
+#define NETLINK_USERSOCK	2	/* Reserved for user mode
+					   socket protocolss.  */
+#define NETLINK_FIREWALL	3	/* Firewalling hook.  */
+#define NETLINK_ARPD		8
+#define NETLINK_ROUTE6		11	/* AF_INET6 route comm channel */
+#define NETLINK_IP6_FW		13
+#define NETLINK_TAPBASE		16	/* 16 to 31 are ethertap */
+
+#define MAX_LINKS 32
+
+struct nlmsghdr
+  {
+    uint32_t nlmsg_len;		/* Length of message including header */
+    uint16_t nlmsg_type;	/* Message content */
+    uint16_t nlmsg_flags;	/* Additional flags */
+    uint32_t nlmsg_seq;		/* Sequence number */
+    uint32_t nlmsg_pid;		/* Sending process PID */
+  };
+
+/* Flag bits */
+#define NLM_F_REQUEST	1	/* Message is a request.  */
+#define NLM_F_MULTI	2	/* Multipart message, terminated by
+				   NLMSG_DONE.  */
+#define NLM_F_ACK	4	/* If operation succeeds, reply with ack.  */
+#define NLM_F_ECHO	8	/* Echo this request.  */
+
+/* Modifiers to GET request */
+#define NLM_F_ROOT	0x100	/* specify tree	root.  */
+#define NLM_F_MATCH	0x200	/* return all matching.  */
+#define NLM_F_ATOMIC	0x400	/* atomic GET.  */
+#define NLM_F_DUMP	(NLM_F_ROOT|NLM_F_MATCH)
+
+/* Modifiers to NEW request */
+#define NLM_F_REPLACE	0x100	/* Override existing.  */
+#define NLM_F_EXCL	0x200	/* Do not touch, if it exists.  */
+#define NLM_F_CREATE	0x400	/* Create, if it does not exist.  */
+#define NLM_F_APPEND	0x800	/* Add to end of list.  */
+
+/*
+   4.4BSD ADD		NLM_F_CREATE|NLM_F_EXCL
+   4.4BSD CHANGE	NLM_F_REPLACE
+
+   True CHANGE		NLM_F_CREATE|NLM_F_REPLACE
+   Append		NLM_F_CREATE
+   Check		NLM_F_EXCL
+ */
+
+#define NLMSG_ALIGNTO	4
+
+#define NLMSG_ALIGN(len) \
+	(((len) + NLMSG_ALIGNTO - 1) & ~(NLMSG_ALIGNTO - 1))
+
+#define NLMSG_LENGTH(len) \
+	((len) + NLMSG_ALIGN (sizeof (struct nlmsghdr)))
+
+#define NLMSG_SPACE(len) \
+	NLMSG_ALIGN (NLMSG_LENGTH (len))
+
+#define NLMSG_DATA(nlh) \
+	((void *) (((char *) nlh) + NLMSG_LENGTH (0)))
+
+#define NLMSG_NEXT(nlh, len) \
+	 ((len) -= NLMSG_ALIGN ((nlh)->nlmsg_len),			      \
+	  (struct nlmsghdr *) (((char *) (nlh))				      \
+			       + NLMSG_ALIGN ((nlh)->nlmsg_len)))
+
+#define NLMSG_OK(nlh, len) \
+	((len) > 0 && (nlh)->nlmsg_len >= sizeof (struct nlmsghdr)
+	 && (nlh)->nlmsg_len <= (len))
+
+#define NLMSG_PAYLOAD(nlh,len) \
+	((nlh)->nlmsg_len - NLMSG_SPACE (len))
+
+#define NLMSG_NOOP		0x1	/* Nothing.  */
+#define NLMSG_ERROR		0x2	/* Error.  */
+#define NLMSG_DONE		0x3	/* End of a dump.  */
+#define NLMSG_OVERRUN		0x4	/* Data lost.  */
+
+struct nlmsgerr
+  {
+    int	error;
+    struct nlmsghdr msg;
+  };
+
+#define NET_MAJOR 36		/* Major 36 is reserved for networking 						*/
+
+#endif