summaryrefslogtreecommitdiff
path: root/packages/iputils
diff options
context:
space:
mode:
authorDenys Dmytriyenko <denis@denix.org>2009-03-17 14:32:59 -0400
committerDenys Dmytriyenko <denis@denix.org>2009-03-17 14:32:59 -0400
commit709c4d66e0b107ca606941b988bad717c0b45d9b (patch)
tree37ee08b1eb308f3b2b6426d5793545c38396b838 /packages/iputils
parentfa6cd5a3b993f16c27de4ff82b42684516d433ba (diff)
rename packages/ to recipes/ per earlier agreement
See links below for more details: http://thread.gmane.org/gmane.comp.handhelds.openembedded/21326 http://thread.gmane.org/gmane.comp.handhelds.openembedded/21816 Signed-off-by: Denys Dmytriyenko <denis@denix.org> Acked-by: Mike Westerhof <mwester@dls.net> Acked-by: Philip Balister <philip@balister.org> Acked-by: Khem Raj <raj.khem@gmail.com> Acked-by: Marcin Juszkiewicz <hrw@openembedded.org> Acked-by: Koen Kooi <koen@openembedded.org> Acked-by: Frans Meulenbroeks <fransmeulenbroeks@gmail.com>
Diffstat (limited to 'packages/iputils')
-rw-r--r--packages/iputils/files/debian-fixes.patch133
-rw-r--r--packages/iputils/files/glibc-2.4-compat.patch78
-rw-r--r--packages/iputils/files/iputils-retvals.patch49
-rw-r--r--packages/iputils/files/makefile.patch49
-rw-r--r--packages/iputils/files/remove-glibc-headers.patch944
-rw-r--r--packages/iputils/files/standard-header-types.patch1072
-rw-r--r--packages/iputils/files/tracepath6-mtu-opt.patch35
-rw-r--r--packages/iputils/iputils_20020927.bb74
8 files changed, 0 insertions, 2434 deletions
diff --git a/packages/iputils/files/debian-fixes.patch b/packages/iputils/files/debian-fixes.patch
deleted file mode 100644
index 1b014f07f9..0000000000
--- a/packages/iputils/files/debian-fixes.patch
+++ /dev/null
@@ -1,133 +0,0 @@
-Fixes taken from the lastest debian .deb pacakge (20020927-3).
-
---- iputils-20020927.orig/ping.c
-+++ iputils-20020927/ping.c
-@@ -232,7 +232,7 @@
- if (argc == 1)
- options |= F_NUMERIC;
- } else {
-- hp = gethostbyname(target);
-+ hp = gethostbyname2(target, AF_INET);
- if (!hp) {
- fprintf(stderr, "ping: unknown host %s\n", target);
- exit(2);
-@@ -373,8 +373,13 @@
- (1<<ICMP_PARAMETERPROB)|
- (1<<ICMP_REDIRECT)|
- (1<<ICMP_ECHOREPLY));
-- if (setsockopt(icmp_sock, SOL_RAW, ICMP_FILTER, (char*)&filt, sizeof(filt)) == -1)
-+ if (setsockopt(icmp_sock, SOL_RAW, ICMP_FILTER,
-+ (char*)&filt, sizeof(filt)) == -1)
-+ {
- perror("WARNING: setsockopt(ICMP_FILTER)");
-+ fprintf(stderr,
-+ "Do you have CONFIG_SOCKET in your kernel?");
-+ }
- }
-
- hold = 1;
-@@ -848,9 +853,36 @@
- case ICMP_SR_FAILED:
- printf("Source Route Failed\n");
- break;
-+ case ICMP_NET_UNKNOWN:
-+ printf("Destination Net Unknown\n");
-+ break;
-+ case ICMP_HOST_UNKNOWN:
-+ printf("Destination Host Unknown\n");
-+ break;
-+ case ICMP_HOST_ISOLATED:
-+ printf("Source Host Isolated\n");
-+ break;
-+ case ICMP_NET_ANO:
-+ printf("Destination Net Prohibited\n");
-+ break;
-+ case ICMP_HOST_ANO:
-+ printf("Destination Host Prohibited\n");
-+ break;
-+ case ICMP_NET_UNR_TOS:
-+ printf("Destination Net Unreachable for Type of Service\n");
-+ break;
-+ case ICMP_HOST_UNR_TOS:
-+ printf("Destination Host Unreachable for Type of Service\n");
-+ break;
- case ICMP_PKT_FILTERED:
- printf("Packet filtered\n");
- break;
-+ case ICMP_PREC_VIOLATION:
-+ printf("Precedence Violation\n");
-+ break;
-+ case ICMP_PREC_CUTOFF:
-+ printf("Precedence Cutoff\n");
-+ break;
- default:
- printf("Dest Unreachable, Bad Code: %d\n", code);
- break;
---- iputils-20020927.orig/ping6.c
-+++ iputils-20020927/ping6.c
-@@ -440,7 +440,6 @@
- /*
- * select icmp echo reply as icmp type to receive
- */
--
- ICMPV6_FILTER_SETBLOCKALL(&filter);
-
- if (!working_recverr) {
---- iputils-20020927.orig/tracepath.c
-+++ iputils-20020927/tracepath.c
-@@ -307,9 +307,9 @@
- base_port = atoi(p+1);
- } else
- base_port = 44444;
-- he = gethostbyname(argv[0]);
-+ he = gethostbyname2(argv[0], AF_INET);
- if (he == NULL) {
-- herror("gethostbyname");
-+ herror("gethostbyname2");
- exit(1);
- }
- memcpy(&target.sin_addr, he->h_addr, 4);
---- iputils-20020927.orig/traceroute6.c
-+++ iputils-20020927/traceroute6.c
-@@ -441,7 +441,7 @@
- * to fix something send the patch to me for sanity checking.
- * "datalen" patch is a shit. */
- if ((unsigned int)datalen == 0)
-- datalen == sizeof(struct pkt_format);
-+ datalen = sizeof(struct pkt_format);
- }
-
- if (datalen < (int)sizeof(struct pkt_format) || datalen >= MAXPACKET) {
---- iputils-20020927.orig/ping_common.c
-+++ iputils-20020927/ping_common.c
-@@ -435,6 +435,7 @@
- if (options & F_SO_DONTROUTE)
- setsockopt(icmp_sock, SOL_SOCKET, SO_DONTROUTE, (char *)&hold, sizeof(hold));
-
-+#ifndef __sparc__ /* XXX SO_TIMESTAMP seems broken on sparc */
- #ifdef SO_TIMESTAMP
- if (!(options&F_LATENCY)) {
- int on = 1;
-@@ -442,6 +443,7 @@
- fprintf(stderr, "Warning: no SO_TIMESTAMP support, falling back to SIOCGSTAMP\n");
- }
- #endif
-+#endif /* __sparc__ */
-
- /* Set some SNDTIMEO to prevent blocking forever
- * on sends, when device is too slow or stalls. Just put limit
-@@ -817,7 +819,8 @@
- }
- if (pipesize > 1)
- printf(", pipe %d", pipesize);
-- if (ntransmitted > 1 && (!interval || (options&(F_FLOOD|F_ADAPTIVE)))) {
-+ if (ntransmitted > 1 && nreceived &&
-+ (!interval || (options&(F_FLOOD|F_ADAPTIVE)))) {
- int ipg = (1000000*(long long)tv.tv_sec+tv.tv_usec)/(ntransmitted-1);
- printf(", ipg/ewma %d.%03d/%d.%03d ms",
- ipg/1000, ipg%1000, rtt/8000, (rtt/8)%1000);
-@@ -851,4 +854,3 @@
- }
- fprintf(stderr, "\n");
- }
--
diff --git a/packages/iputils/files/glibc-2.4-compat.patch b/packages/iputils/files/glibc-2.4-compat.patch
deleted file mode 100644
index 736d660c3d..0000000000
--- a/packages/iputils/files/glibc-2.4-compat.patch
+++ /dev/null
@@ -1,78 +0,0 @@
-This patch renames the ICMP6 variables to the new names, as used in glibc
-2.4. It also provides a header which will define the new names to the old
-names - as used in glibc < 2.4 and uclibc, so that it'll build on
-uclibc, glibc < 2.4 and glibc 2.4.
-
---- iputils/ping6.c 2006/07/10 02:23:05 1.1
-+++ iputils/ping6.c 2006/07/10 02:30:06
-@@ -71,6 +71,7 @@
- #include <netinet/in.h>
- #include <netinet/ip6.h>
- #include <netinet/icmp6.h>
-+#include "glibc_compat.h"
-
- /* define to specify we want type0 routing headers */
- #define IPV6_SRCRT_TYPE_0 0
-@@ -86,7 +87,6 @@
- #define HAVE_SIN6_SCOPEID 1
- #endif
-
--
- uint32_t flowlabel;
- uint32_t tclass;
- struct cmsghdr *srcrt;
-@@ -781,7 +781,7 @@
- case ICMP6_DST_UNREACH_ADMIN:
- printf("Administratively prohibited");
- break;
-- case ICMP6_DST_UNREACH_NOTNEIGHBOR:
-+ case ICMP6_DST_UNREACH_BEYONDSCOPE:
- printf("Not neighbour");
- break;
- case ICMP6_DST_UNREACH_ADDR:
-@@ -827,13 +827,13 @@
- case ICMP6_ECHO_REPLY:
- printf("Echo reply");
- break;
-- case ICMP6_MEMBERSHIP_QUERY:
-+ case MLD_LISTENER_QUERY:
- printf("MLD Query");
- break;
-- case ICMP6_MEMBERSHIP_REPORT:
-+ case MLD_LISTENER_REPORT:
- printf("MLD Report");
- break;
-- case ICMP6_MEMBERSHIP_REDUCTION:
-+ case MLD_LISTENER_REDUCTION:
- printf("MLD Reduction");
- break;
- default:
---- /dev/null 2006-07-03 23:05:35.026189000 +1000
-+++ iputils/glibc_compat.h 2006-07-10 12:30:04.000000000 +1000
-@@ -0,0 +1,26 @@
-+/*
-+ * glibc 2.4 renamed some of the IPv6 related constants.
-+ *
-+ * We use the new names and rename them back the old names if the new names
-+ * are not definied anyway.
-+ */
-+#ifndef GLIBC_COMPAT
-+#define GLIBC_COMPAT
-+
-+#ifndef ICMP6_DST_UNREACH_BEYONDSCOPE
-+#define ICMP6_DST_UNREACH_BEYONDSCOPE ICMP6_DST_UNREACH_NOTNEIGHBOR
-+#endif
-+
-+#ifndef MLD_LISTENER_QUERY
-+#define MLD_LISTENER_QUERY ICMP6_MEMBERSHIP_QUERY
-+#endif
-+
-+#ifndef MLD_LISTENER_REPORT
-+#define MLD_LISTENER_REPORT ICMP6_MEMBERSHIP_REPORT
-+#endif
-+
-+#ifndef MLD_LISTENER_REDUCTION
-+#define MLD_LISTENER_REDUCTION ICMP6_MEMBERSHIP_REDUCTION
-+#endif
-+
-+#endif
diff --git a/packages/iputils/files/iputils-retvals.patch b/packages/iputils/files/iputils-retvals.patch
deleted file mode 100644
index 73ef8a364e..0000000000
--- a/packages/iputils/files/iputils-retvals.patch
+++ /dev/null
@@ -1,49 +0,0 @@
-From the fedora core SRPM. Outputs error message and exists if the
-command is not suid root or run as user root.
-
---- iputils/traceroute6.c.old 2004-12-07 11:08:57.000000000 +0100
-+++ iputils/traceroute6.c 2004-12-07 11:14:09.397575536 +0100
-@@ -352,8 +352,11 @@
- icmp_sock = socket(AF_INET6, SOCK_RAW, IPPROTO_ICMPV6);
- socket_errno = errno;
-
-- setuid(getuid());
--
-+ if(setuid(getuid()) != 0)
-+ {
-+ perror("traceroute: setuid()");
-+ exit(-1);
-+ }
- on = 1;
- seq = tos = 0;
- to = (struct sockaddr_in6 *)&whereto;
---- iputils/ping6.c.old 2004-12-07 11:08:57.000000000 +0100
-+++ iputils/ping6.c 2004-12-07 11:13:40.707937024 +0100
-@@ -223,7 +223,11 @@
- socket_errno = errno;
-
- uid = getuid();
-- setuid(uid);
-+ if(setuid(uid) != 0)
-+ {
-+ perror("ping: setuid()");
-+ exit(-1);
-+ }
-
- source.sin6_family = AF_INET6;
- memset(&firsthop, 0, sizeof(firsthop));
---- iputils/ping.c.old 2004-12-07 11:08:57.000000000 +0100
-+++ iputils/ping.c 2004-12-07 11:13:27.523941296 +0100
-@@ -119,7 +119,11 @@
- socket_errno = errno;
-
- uid = getuid();
-- setuid(uid);
-+ if(setuid(uid) != 0)
-+ {
-+ perror("ping: setuid()");
-+ exit(-1);
-+ }
-
- source.sin_family = AF_INET;
-
diff --git a/packages/iputils/files/makefile.patch b/packages/iputils/files/makefile.patch
deleted file mode 100644
index 6cc35ad978..0000000000
--- a/packages/iputils/files/makefile.patch
+++ /dev/null
@@ -1,49 +0,0 @@
-Update the makefile: Stop building it as a debug version by default,
-remove the manual mangling of the include directories and don't build
-the clockdiff, rdisc, tftp or rarpd components (everyone uses version
-provided by other packages.)
-
---- new/Makefile 2005/11/14 13:34:06 1.1
-+++ new/Makefile 2005/11/14 13:40:13
-@@ -1,37 +1,17 @@
--# Path to parent kernel include files directory
--KERNEL_INCLUDE=/usr/src/linux/include
--LIBC_INCLUDE=/usr/include
--
--DEFINES=
--
- #options if you have a bind>=4.9.4 libresolv (or, maybe, glibc)
- LDLIBS=-lresolv
--ADDLIB=
--
--ifeq ($(LIBC_INCLUDE)/socketbits.h,$(wildcard $(LIBC_INCLUDE)/socketbits.h))
-- ifeq ($(LIBC_INCLUDE)/net/if_packet.h,$(wildcard $(LIBC_INCLUDE)/net/if_packet.h))
-- GLIBCFIX=-Iinclude-glibc -include include-glibc/glibc-bugs.h
-- endif
--endif
--ifeq ($(LIBC_INCLUDE)/bits/socket.h,$(wildcard $(LIBC_INCLUDE)/bits/socket.h))
-- GLIBCFIX=-Iinclude-glibc -include include-glibc/glibc-bugs.h
--endif
--
--
--#options if you compile with libc5, and without a bind>=4.9.4 libresolv
--# NOT AVAILABLE. Please, use libresolv.
-
- CC=gcc
- # What a pity, all new gccs are buggy and -Werror does not work. Sigh.
- #CCOPT=-D_GNU_SOURCE -O2 -Wstrict-prototypes -Wall -g -Werror
--CCOPT=-D_GNU_SOURCE -O2 -Wstrict-prototypes -Wall -g
--CFLAGS=$(CCOPT) $(GLIBCFIX) -I$(KERNEL_INCLUDE) -I../include $(DEFINES)
-+CCOPT=-D_GNU_SOURCE -O2 -Wstrict-prototypes -Wall
-+CFLAGS=$(CCOPT) -I$(KERNEL_INCLUDE) $(DEFINES)
-
--IPV4_TARGETS=tracepath ping clockdiff rdisc arping tftpd rarpd
-+IPV4_TARGETS=tracepath ping arping
- IPV6_TARGETS=tracepath6 traceroute6 ping6
- TARGETS=$(IPV4_TARGETS) $(IPV6_TARGETS)
-
--all: check-kernel $(TARGETS)
-+all: $(TARGETS)
-
-
- tftpd: tftpd.o tftpsubs.o
diff --git a/packages/iputils/files/remove-glibc-headers.patch b/packages/iputils/files/remove-glibc-headers.patch
deleted file mode 100644
index 0930acd656..0000000000
--- a/packages/iputils/files/remove-glibc-headers.patch
+++ /dev/null
@@ -1,944 +0,0 @@
-We are not using the local glibc headers for now.
-Remove them to keep them out of the way.
-
-diff -durN orig/include-glibc/bits/socket.h new/include-glibc/bits/socket.h
---- orig/include-glibc/bits/socket.h 2005-11-14 22:37:26.000000000 +1100
-+++ new/include-glibc/bits/socket.h 1970-01-01 10:00:00.000000000 +1000
-@@ -1,280 +0,0 @@
--/* System-specific socket constants and types. Linux version.
-- Copyright (C) 1991, 92, 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
-- 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 _SOCKETBITS_H
--
--#define _SOCKETBITS_H 1
--#include <features.h>
--
--#define __need_size_t
--#define __need_NULL
--#include <stddef.h>
--
--
--__BEGIN_DECLS
--
--/* Type for length arguments in socket calls. */
--#ifndef __socklen_t_defined
--typedef unsigned int socklen_t;
--# define __socklen_t_defined
--#endif
--
--/* Types of sockets. */
--enum __socket_type
--{
--#ifndef __mips__
-- SOCK_STREAM = 1, /* Sequenced, reliable, connection-based
-- byte streams. */
--#define SOCK_STREAM SOCK_STREAM
-- SOCK_DGRAM = 2, /* Connectionless, unreliable datagrams
-- of fixed maximum length. */
--#define SOCK_DGRAM SOCK_DGRAM
--#else
-- SOCK_STREAM = 2, /* Sequenced, reliable, connection-based
-- byte streams. */
--#define SOCK_STREAM SOCK_STREAM
-- SOCK_DGRAM = 1, /* Connectionless, unreliable datagrams
-- of fixed maximum length. */
--#define SOCK_DGRAM SOCK_DGRAM
--#endif
-- SOCK_RAW = 3, /* Raw protocol interface. */
--#define SOCK_RAW SOCK_RAW
-- SOCK_RDM = 4, /* Reliably-delivered messages. */
--#define SOCK_RDM SOCK_RDM
-- SOCK_SEQPACKET = 5, /* Sequenced, reliable, connection-based,
-- datagrams of fixed maximum length. */
--#define SOCK_SEQPACKET SOCK_SEQPACKET
-- SOCK_PACKET = 10 /* Linux specific way of getting packets
-- at the dev level. For writing rarp and
-- other similar things on the user level. */
--#define SOCK_PACKET SOCK_PACKET
--};
--
--/* Protocol families. */
--#define PF_UNSPEC 0 /* Unspecified. */
--#define PF_LOCAL 1 /* Local to host (pipes and file-domain). */
--#define PF_UNIX PF_LOCAL /* Old BSD name for PF_LOCAL. */
--#define PF_FILE PF_LOCAL /* POSIX name for PF_LOCAL. */
--#define PF_INET 2 /* IP protocol family. */
--#define PF_AX25 3 /* Amateur Radio AX.25. */
--#define PF_IPX 4 /* Novell Internet Protocol. */
--#define PF_APPLETALK 5 /* Don't use this. */
--#define PF_NETROM 6 /* Amateur radio NetROM. */
--#define PF_BRIDGE 7 /* Multiprotocol bridge. */
--#define PF_AAL5 8 /* Reserved for Werner's ATM. */
--#define PF_X25 9 /* Reserved for X.25 project. */
--#define PF_INET6 10 /* IP version 6. */
--#define PF_ROSE 11 /* Amateur Radio X.25 PLP */
--#define PF_DECnet 12 /* Reserved for DECnet project */
--#define PF_NETBEUI 13 /* Reserved for 802.2LLC project*/
--#define PF_SECURITY 14 /* Security callback pseudo AF */
--#define PF_KEY 15 /* PF_KEY key management API */
--#define PF_NETLINK 16
--#define PF_ROUTE PF_NETLINK /* Alias to emulate 4.4BSD */
--#define PF_PACKET 17 /* Packet family */
--#define PF_MAX 32 /* For now.. */
--
--/* Address families. */
--#define AF_UNSPEC PF_UNSPEC
--#define AF_LOCAL PF_LOCAL
--#define AF_UNIX PF_UNIX
--#define AF_FILE PF_FILE
--#define AF_INET PF_INET
--#define AF_AX25 PF_AX25
--#define AF_IPX PF_IPX
--#define AF_APPLETALK PF_APPLETALK
--#define AF_NETROM PF_NETROM
--#define AF_BRIDGE PF_BRIDGE
--#define AF_AAL5 PF_AAL5
--#define AF_X25 PF_X25
--#define AF_INET6 PF_INET6
--#define AF_ROSE PF_ROSE
--#define AF_DECnet PF_DECnet
--#define AF_NETBEUI PF_NETBEUI
--#define AF_SECURITY PF_SECURITY
--#define pseudo_AF_KEY pseudo_PF_KEY
--#define AF_NETLINK PF_NETLINK
--#define AF_ROUTE PF_ROUTE
--#define AF_PACKET PF_PACKET
--#define AF_MAX PF_MAX
--
--/* Socket level values. Others are defined in the appropriate headers.
--
-- XXX These definitions also should go into the appropriate headers as
-- far as they are available. */
--#define SOL_IPV6 41
--#define SOL_ICMPV6 58
--#define SOL_RAW 255
--#define SOL_AX25 257
--#define SOL_ATALK 258
--#define SOL_NETROM 259
--#define SOL_ROSE 260
--#define SOL_DECNET 261
--#define SOL_X25 262
--
--/* Maximum queue length specifiable by listen. */
--#define SOMAXCONN 128
--
--/* Get the definition of the macro to define the common sockaddr members. */
--#if __GLIBC_MINOR__ >= 1
--#include <bits/sockaddr.h>
--#else
--#include <sockaddrcom.h>
--#endif
--
--/* Structure describing a generic socket address. */
--struct sockaddr
-- {
-- __SOCKADDR_COMMON (sa_); /* Common data: address family and length. */
-- char sa_data[14]; /* Address data. */
-- };
--
--
--/* Bits in the FLAGS argument to `send', `recv', et al. */
--enum
-- {
-- MSG_OOB = 0x01, /* Process out-of-band data. */
--#define MSG_OOB MSG_OOB
-- MSG_PEEK = 0x02, /* Peek at incoming messages. */
--#define MSG_PEEK MSG_PEEK
-- MSG_DONTROUTE = 0x04, /* Don't use local routing. */
--#define MSG_DONTROUTE MSG_DONTROUTE
-- MSG_CTRUNC = 0x08, /* Control data lost before delivery. */
--#define MSG_CTRUNC MSG_CTRUNC
-- MSG_PROBE = 0x10,
--#define MSG_PROBE MSG_PROBE
-- MSG_TRUNC = 0x20,
--#define MSG_TRUNC MSG_TRUNC
-- MSG_DONTWAIT = 0x40,
--#define MSG_DONTWAIT MSG_DONTWAIT
-- MSG_WAITALL = 0x100,
--#define MSG_WAITALL MSG_WAITALL
-- MSG_CONFIRM = 0x800,
--#define MSG_CONFIRM MSG_CONFIRM
-- MSG_ERRQUEUE = 0x2000,
--#define MSG_ERRQUEUE MSG_ERRQUEUE
-- MSG_NOSIGNAL = 0x4000,
--#define MSG_NOSIGNAL MSG_NOSIGNAL
-- };
--
--/* Structure describing messages sent by
-- `sendmsg' and received by `recvmsg'. */
--struct msghdr
-- {
-- __ptr_t msg_name; /* Address to send to/receive from. */
-- socklen_t msg_namelen; /* Length of address data. */
--
-- struct iovec *msg_iov; /* Vector of data to send/receive into. */
-- size_t msg_iovlen; /* Number of elements in the vector. */
--
-- __ptr_t msg_control; /* Ancillary data (eg BSD filedesc passing). */
-- size_t msg_controllen; /* Ancillary data buffer length. */
--
-- int msg_flags; /* Flags on received message. */
-- };
--
--/* Structure used for storage of ancillary data object information. */
--struct cmsghdr
-- {
-- size_t cmsg_len; /* Length of data in cmsg_data plus length
-- of cmsghdr structure. */
-- int cmsg_level; /* Originating protocol. */
-- int cmsg_type; /* Protocol specific type. */
--#if !defined __STRICT_ANSI__ && defined __GNUC__ && __GNUC__ >= 2
-- unsigned char __cmsg_data[0]; /* Ancillary data. */
--#endif
-- };
--
--/* Ancillary data object manipulation macros. */
--#if !defined __STRICT_ANSI__ && defined __GNUC__ && __GNUC__ >= 2
--# define CMSG_DATA(cmsg) ((cmsg)->__cmsg_data)
--#else
--# define CMSG_DATA(cmsg) ((unsigned char *) ((struct cmsghdr *) (cmsg) + 1))
--#endif
--#define CMSG_NXTHDR(mhdr, cmsg) __cmsg_nxthdr (mhdr, cmsg)
--#define CMSG_FIRSTHDR(mhdr) \
-- ((size_t) (mhdr)->msg_controllen >= sizeof (struct cmsghdr) \
-- ? (struct cmsghdr *) (mhdr)->msg_control : (struct cmsghdr *) NULL)
--#define CMSG_ALIGN(len) ( ((len)+sizeof(long)-1) & ~(sizeof(long)-1) )
--#define CMSG_SPACE(len) (CMSG_ALIGN(sizeof(struct cmsghdr)) + CMSG_ALIGN(len))
--#define CMSG_LEN(len) (CMSG_ALIGN(sizeof(struct cmsghdr)) + (len))
--
--
--#ifndef _EXTERN_INLINE
--# define _EXTERN_INLINE extern __inline
--#endif
--extern struct cmsghdr *__cmsg_nxthdr __P ((struct msghdr *__mhdr,
-- struct cmsghdr *__cmsg));
--_EXTERN_INLINE struct cmsghdr *
--__cmsg_nxthdr (struct msghdr *__mhdr, struct cmsghdr *__cmsg)
--{
-- if ((size_t) __cmsg->cmsg_len < sizeof (struct cmsghdr))
-- /* The kernel header does this so there may be a reason. */
-- return NULL;
--
-- __cmsg = (struct cmsghdr *)
-- ((unsigned char *) __cmsg + CMSG_ALIGN(__cmsg->cmsg_len));
--
-- if ( (unsigned char *) (__cmsg + 1) >=
-- (unsigned char *) __mhdr->msg_control + __mhdr->msg_controllen)
-- /* No more entries. */
-- return NULL;
-- return __cmsg;
--}
--
--/* Socket level message types. This must match the definitions in
-- <linux/socket.h>. */
--enum
-- {
-- SCM_RIGHTS = 0x01, /* Data array contains access rights. */
--#define SCM_RIGHTS SCM_RIGHTS
-- SCM_CREDENTIALS = 0x02, /* Data array is `struct ucred'. */
--#define SCM_CREDENTIALS SCM_CREDENTIALS
-- };
--
--
--
--/* Get socket manipulation related informations from kernel headers. */
--#ifdef THIS_IS_CRAP
--#ifndef _LINUX_TYPES_H
--# define _LINUX_TYPES_H
--#endif
--#endif
--
--#include <asm/socket.h>
--#include <asm/types.h>
--
--struct ucred
--{
-- __u32 pid;
-- __u32 uid;
-- __u32 gid;
--};
--
--
--/* Structure used to manipulate the SO_LINGER option. */
--struct linger
-- {
-- int l_onoff; /* Nonzero to linger on close. */
-- int l_linger; /* Time to linger. */
-- };
--
--__END_DECLS
--
--#endif /* socketbits.h */
-diff -durN orig/include-glibc/bits/sockunion.h new/include-glibc/bits/sockunion.h
---- orig/include-glibc/bits/sockunion.h 2005-11-14 22:37:26.000000000 +1100
-+++ new/include-glibc/bits/sockunion.h 1970-01-01 10:00:00.000000000 +1000
-@@ -1,25 +0,0 @@
--
--/* I cannot describe, how I laughed, when saw, that now sys/socket.h
-- includes ALL OF networking include files. 8)8)8)
--
-- Bravo! Aah, they forgot sockaddr_ll, sockaddr_pkt and sockaddr_nl...
-- Not a big problem, we only start the way to single UNIVERSAL include file:
--
-- #include <GNU-Gnu_is_Not_Unix.h>.
--
-- Jokes apart, it is full crap. Removed.
-- --ANK
--
-- */
--
--/* Union of all sockaddr types (required by IPv6 Basic API). This is
-- somewhat evil. */
--/* 8)8) Well, ipngwg really does strange things sometimes, but
-- not in such extent! It is removed long ago --ANK
-- */
--
--union sockaddr_union
-- {
-- struct sockaddr sa;
-- char __maxsize[128];
-- };
-diff -durN orig/include-glibc/glibc-bugs.h new/include-glibc/glibc-bugs.h
---- orig/include-glibc/glibc-bugs.h 2005-11-14 22:37:26.000000000 +1100
-+++ new/include-glibc/glibc-bugs.h 1970-01-01 10:00:00.000000000 +1000
-@@ -1,20 +0,0 @@
--#ifndef __GLIBC_BUGS_H__
--#define __GLIBC_BUGS_H__ 1
--
--#include <features.h>
--#include <sys/types.h>
--
--#if defined(__GLIBC__) && __GLIBC__ >= 2
--
--#ifndef __KERNEL_STRICT_NAMES
--#define __KERNEL_STRICT_NAMES 1
--#endif
--
--#include <linux/types.h>
--
--typedef __u16 in_port_t;
--typedef __u32 in_addr_t;
--
--#endif
--
--#endif
-diff -durN orig/include-glibc/netinet/in.h new/include-glibc/netinet/in.h
---- orig/include-glibc/netinet/in.h 2005-11-14 22:37:26.000000000 +1100
-+++ new/include-glibc/netinet/in.h 1970-01-01 10:00:00.000000000 +1000
-@@ -1,11 +0,0 @@
--#ifndef _NETINET_IN_H
--#define _NETINET_IN_H 1
--
--#include "glibc-bugs.h"
--#include <sys/socket.h>
--#include <sys/types.h>
--#include <linux/in.h>
--
--#define SOL_IP 0
--
--#endif /* netinet/in.h */
-diff -durN orig/include-glibc/netinet/ip.h new/include-glibc/netinet/ip.h
---- orig/include-glibc/netinet/ip.h 2005-11-14 22:37:26.000000000 +1100
-+++ new/include-glibc/netinet/ip.h 1970-01-01 10:00:00.000000000 +1000
-@@ -1,98 +0,0 @@
--#ifndef __NETINET_IP_H
--#define __NETINET_IP_H 1
--
--#include <glibc-bugs.h>
--#include <netinet/in.h>
--
--#include <linux/ip.h>
--
--#ifdef __USE_BSD
--/*
-- * Copyright (c) 1982, 1986, 1993
-- * The Regents of the University of California. All rights reserved.
-- *
-- * Redistribution and use in source and binary forms, with or without
-- * modification, are permitted provided that the following conditions
-- * are met:
-- * 1. Redistributions of source code must retain the above copyright
-- * notice, this list of conditions and the following disclaimer.
-- * 2. Redistributions in binary form must reproduce the above copyright
-- * notice, this list of conditions and the following disclaimer in the
-- * documentation and/or other materials provided with the distribution.
-- * 3. All advertising materials mentioning features or use of this software
-- * must display the following acknowledgement:
-- * This product includes software developed by the University of
-- * California, Berkeley and its contributors.
-- * 4. Neither the name of the University nor the names of its contributors
-- * may be used to endorse or promote products derived from this software
-- * without specific prior written permission.
-- *
-- * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
-- * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
-- * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
-- * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
-- * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
-- * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
-- * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
-- * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
-- * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
-- * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
-- * SUCH DAMAGE.
-- *
-- * @(#)ip.h 8.1 (Berkeley) 6/10/93
-- */
--
--/*
-- * Definitions for internet protocol version 4.
-- * Per RFC 791, September 1981.
-- */
--
--/*
-- * Structure of an internet header, naked of options.
-- */
--struct ip
-- {
--#if __BYTE_ORDER == __LITTLE_ENDIAN
-- u_int8_t ip_hl:4; /* header length */
-- u_int8_t ip_v:4; /* version */
--#endif
--#if __BYTE_ORDER == __BIG_ENDIAN
-- u_int8_t ip_v:4; /* version */
-- u_int8_t ip_hl:4; /* header length */
--#endif
-- u_int8_t ip_tos; /* type of service */
-- u_short ip_len; /* total length */
-- u_short ip_id; /* identification */
-- u_short ip_off; /* fragment offset field */
--#define IP_RF 0x8000 /* reserved fragment flag */
--#define IP_DF 0x4000 /* dont fragment flag */
--#define IP_MF 0x2000 /* more fragments flag */
--#define IP_OFFMASK 0x1fff /* mask for fragmenting bits */
-- u_int8_t ip_ttl; /* time to live */
-- u_int8_t ip_p; /* protocol */
-- u_short ip_sum; /* checksum */
-- struct in_addr ip_src, ip_dst; /* source and dest address */
-- };
--
--/*
-- * Time stamp option structure.
-- */
--struct ip_timestamp
-- {
-- u_int8_t ipt_code; /* IPOPT_TS */
-- u_int8_t ipt_len; /* size of structure (variable) */
-- u_int8_t ipt_ptr; /* index of current entry */
--#if __BYTE_ORDER == __LITTLE_ENDIAN
-- u_int8_t ipt_flg:4; /* flags, see below */
-- u_int8_t ipt_oflw:4; /* overflow counter */
--#endif
--#if __BYTE_ORDER == __BIG_ENDIAN
-- u_int8_t ipt_oflw:4; /* overflow counter */
-- u_int8_t ipt_flg:4; /* flags, see below */
--#endif
-- u_int32_t data[9];
-- };
--#endif /* __USE_BSD */
--
--
--#endif /* netinet/ip.h */
-diff -durN orig/include-glibc/netinet/ip_icmp.h new/include-glibc/netinet/ip_icmp.h
---- orig/include-glibc/netinet/ip_icmp.h 2005-11-14 22:37:26.000000000 +1100
-+++ new/include-glibc/netinet/ip_icmp.h 1970-01-01 10:00:00.000000000 +1000
-@@ -1,199 +0,0 @@
--#ifndef __NETINET_IP_ICMP_H
--#define __NETINET_IP_ICMP_H 1
--
--
--#include <asm/types.h>
--#include <linux/icmp.h>
--
--#ifdef __USE_BSD
--/*
-- * Copyright (c) 1982, 1986, 1993
-- * The Regents of the University of California. All rights reserved.
-- *
-- * Redistribution and use in source and binary forms, with or without
-- * modification, are permitted provided that the following conditions
-- * are met:
-- * 1. Redistributions of source code must retain the above copyright
-- * notice, this list of conditions and the following disclaimer.
-- * 2. Redistributions in binary form must reproduce the above copyright
-- * notice, this list of conditions and the following disclaimer in the
-- * documentation and/or other materials provided with the distribution.
-- * 3. All advertising materials mentioning features or use of this software
-- * must display the following acknowledgement:
-- * This product includes software developed by the University of
-- * California, Berkeley and its contributors.
-- * 4. Neither the name of the University nor the names of its contributors
-- * may be used to endorse or promote products derived from this software
-- * without specific prior written permission.
-- *
-- * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
-- * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
-- * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
-- * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
-- * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
-- * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
-- * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
-- * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
-- * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
-- * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
-- * SUCH DAMAGE.
-- *
-- * @(#)ip_icmp.h 8.1 (Berkeley) 6/10/93
-- */
--
--#include <netinet/in.h>
--#include <netinet/ip.h>
--
--/*
-- * Internal of an ICMP Router Advertisement
-- */
--struct icmp_ra_addr
--{
-- u_int32_t ira_addr;
-- u_int32_t ira_preference;
--};
--
--struct icmp
--{
-- u_int8_t icmp_type; /* type of message, see below */
-- u_int8_t icmp_code; /* type sub code */
-- u_int16_t icmp_cksum; /* ones complement checksum of struct */
-- union
-- {
-- u_char ih_pptr; /* ICMP_PARAMPROB */
-- struct in_addr ih_gwaddr; /* gateway address */
-- struct ih_idseq /* echo datagram */
-- {
-- u_int16_t icd_id;
-- u_int16_t icd_seq;
-- } ih_idseq;
-- u_int32_t ih_void;
--
-- /* ICMP_UNREACH_NEEDFRAG -- Path MTU Discovery (RFC1191) */
-- struct ih_pmtu
-- {
-- u_int16_t ipm_void;
-- u_int16_t ipm_nextmtu;
-- } ih_pmtu;
--
-- struct ih_rtradv
-- {
-- u_int8_t irt_num_addrs;
-- u_int8_t irt_wpa;
-- u_int16_t irt_lifetime;
-- } ih_rtradv;
-- } icmp_hun;
--#define icmp_pptr icmp_hun.ih_pptr
--#define icmp_gwaddr icmp_hun.ih_gwaddr
--#define icmp_id icmp_hun.ih_idseq.icd_id
--#define icmp_seq icmp_hun.ih_idseq.icd_seq
--#define icmp_void icmp_hun.ih_void
--#define icmp_pmvoid icmp_hun.ih_pmtu.ipm_void
--#define icmp_nextmtu icmp_hun.ih_pmtu.ipm_nextmtu
--#define icmp_num_addrs icmp_hun.ih_rtradv.irt_num_addrs
--#define icmp_wpa icmp_hun.ih_rtradv.irt_wpa
--#define icmp_lifetime icmp_hun.ih_rtradv.irt_lifetime
-- union
-- {
-- struct
-- {
-- u_int32_t its_otime;
-- u_int32_t its_rtime;
-- u_int32_t its_ttime;
-- } id_ts;
-- struct
-- {
-- struct ip idi_ip;
-- /* options and then 64 bits of data */
-- } id_ip;
-- struct icmp_ra_addr id_radv;
-- u_int32_t id_mask;
-- u_int8_t id_data[1];
-- } icmp_dun;
--#define icmp_otime icmp_dun.id_ts.its_otime
--#define icmp_rtime icmp_dun.id_ts.its_rtime
--#define icmp_ttime icmp_dun.id_ts.its_ttime
--#define icmp_ip icmp_dun.id_ip.idi_ip
--#define icmp_radv icmp_dun.id_radv
--#define icmp_mask icmp_dun.id_mask
--#define icmp_data icmp_dun.id_data
--};
--
--/*
-- * Lower bounds on packet lengths for various types.
-- * For the error advice packets must first insure that the
-- * packet is large enough to contain the returned ip header.
-- * Only then can we do the check to see if 64 bits of packet
-- * data have been returned, since we need to check the returned
-- * ip header length.
-- */
--#define ICMP_MINLEN 8 /* abs minimum */
--#define ICMP_TSLEN (8 + 3 * sizeof (n_time)) /* timestamp */
--#define ICMP_MASKLEN 12 /* address mask */
--#define ICMP_ADVLENMIN (8 + sizeof (struct ip) + 8) /* min */
--#ifndef _IP_VHL
--#define ICMP_ADVLEN(p) (8 + ((p)->icmp_ip.ip_hl << 2) + 8)
-- /* N.B.: must separately check that ip_hl >= 5 */
--#else
--#define ICMP_ADVLEN(p) (8 + (IP_VHL_HL((p)->icmp_ip.ip_vhl) << 2) + 8)
-- /* N.B.: must separately check that header length >= 5 */
--#endif
--
--/* Definition of type and code fields. */
--/* defined above: ICMP_ECHOREPLY, ICMP_REDIRECT, ICMP_ECHO */
--#define ICMP_UNREACH 3 /* dest unreachable, codes: */
--#define ICMP_SOURCEQUENCH 4 /* packet lost, slow down */
--#define ICMP_ROUTERADVERT 9 /* router advertisement */
--#define ICMP_ROUTERSOLICIT 10 /* router solicitation */
--#define ICMP_TIMXCEED 11 /* time exceeded, code: */
--#define ICMP_PARAMPROB 12 /* ip header bad */
--#define ICMP_TSTAMP 13 /* timestamp request */
--#define ICMP_TSTAMPREPLY 14 /* timestamp reply */
--#define ICMP_IREQ 15 /* information request */
--#define ICMP_IREQREPLY 16 /* information reply */
--#define ICMP_MASKREQ 17 /* address mask request */
--#define ICMP_MASKREPLY 18 /* address mask reply */
--
--#define ICMP_MAXTYPE 18
--
--/* UNREACH codes */
--#define ICMP_UNREACH_NET 0 /* bad net */
--#define ICMP_UNREACH_HOST 1 /* bad host */