about summary refs log tree commit diff
path: root/sysdeps/unix/sysv/linux
diff options
context:
space:
mode:
authorUlrich Drepper <drepper@redhat.com>1998-11-12 18:06:31 +0000
committerUlrich Drepper <drepper@redhat.com>1998-11-12 18:06:31 +0000
commitd2537a474cb637bc49abc0baad75c01e5c245752 (patch)
treea6e20bfadb0fc266093fe40639ff7a0bf8b0619f /sysdeps/unix/sysv/linux
parent085320f505022f7fbc53b229ef1dc31826e66c34 (diff)
downloadglibc-d2537a474cb637bc49abc0baad75c01e5c245752.tar.gz
glibc-d2537a474cb637bc49abc0baad75c01e5c245752.tar.xz
glibc-d2537a474cb637bc49abc0baad75c01e5c245752.zip
Update.
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>.
Diffstat (limited to 'sysdeps/unix/sysv/linux')
-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
4 files changed, 141 insertions, 2 deletions
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