diff options
Diffstat (limited to 'package/iproute2')
-rw-r--r-- | package/iproute2/Config.in | 4 | ||||
-rw-r--r-- | package/iproute2/iproute2-2.6.37-optional-ipv6.patch | 94 |
2 files changed, 94 insertions, 4 deletions
diff --git a/package/iproute2/Config.in b/package/iproute2/Config.in index 2412d8e83..b6ee86e9b 100644 --- a/package/iproute2/Config.in +++ b/package/iproute2/Config.in @@ -1,11 +1,7 @@ config BR2_PACKAGE_IPROUTE2 bool "iproute2" - depends on BR2_INET_IPV6 help Kernel routing and traffic control utilities. Provides things like ip and tc. http://www.linuxfoundation.org/collaborate/workgroups/networking/iproute2 - -comment "iproute2 requires a toolchain with IPv6 support" - depends on !BR2_INET_IPV6 diff --git a/package/iproute2/iproute2-2.6.37-optional-ipv6.patch b/package/iproute2/iproute2-2.6.37-optional-ipv6.patch new file mode 100644 index 000000000..ef22c2212 --- /dev/null +++ b/package/iproute2/iproute2-2.6.37-optional-ipv6.patch @@ -0,0 +1,94 @@ +[PATCH] fix build on uClibc without IPv6 support + +Disable IPv6 support code when building with uClibc configured without IPv6 +support. + +Signed-off-by: Peter Korsgaard <jacmet@sunsite.dk> +--- + ip/ip6tunnel.c | 6 ++++++ + ip/ipprefix.c | 8 ++++++++ + ip/iptunnel.c | 6 ++++++ + 3 files changed, 20 insertions(+) + +Index: iproute2-2.6.37-orig/ip/ip6tunnel.c +=================================================================== +--- iproute2-2.6.37-orig.orig/ip/ip6tunnel.c ++++ iproute2-2.6.37-orig/ip/ip6tunnel.c +@@ -20,6 +20,10 @@ + * Masahide NAKAMURA @USAGI + */ + ++#include <features.h> ++#if defined(__UCLIBC__) && !defined (__UCLIBC_HAS_IPV6__) ++#else ++ + #include <stdio.h> + #include <string.h> + #include <stdlib.h> +@@ -410,3 +414,5 @@ int do_ip6tunnel(int argc, char **argv) + fprintf(stderr, "Command \"%s\" is unknown, try \"ip -f inet6 tunnel help\".\n", *argv); + exit(-1); + } ++ ++#endif /* no ipv6 */ +Index: iproute2-2.6.37-orig/ip/ipprefix.c +=================================================================== +--- iproute2-2.6.37-orig.orig/ip/ipprefix.c ++++ iproute2-2.6.37-orig/ip/ipprefix.c +@@ -22,11 +22,17 @@ + * Authors: + * Masahide NAKAMURA @USAGI + */ ++#include <features.h> ++#if defined(__UCLIBC__) && !defined (__UCLIBC_HAS_IPV6__) ++#define NO_IPV6 ++#endif + + #include <stdio.h> + #include <stdlib.h> + #include <string.h> ++#ifndef NO_IPV6 + #include <netinet/icmp6.h> ++#endif + #include "utils.h" + + /* prefix flags; see kernel's net/ipv6/addrconf.c and include/net/if_inet6.h */ +@@ -62,10 +68,12 @@ int print_prefix(const struct sockaddr_n + fprintf(stderr, "wrong family %d\n", prefix->prefix_family); + return 0; + } ++#ifdef ND_OPT_PREFIX_INFORMATION + if (prefix->prefix_type != ND_OPT_PREFIX_INFORMATION) { + fprintf(stderr, "wrong ND type %d\n", prefix->prefix_type); + return 0; + } ++#endif + + parse_rtattr(tb, RTA_MAX, RTM_RTA(prefix), len); + +Index: iproute2-2.6.37-orig/ip/iptunnel.c +=================================================================== +--- iproute2-2.6.37-orig.orig/ip/iptunnel.c ++++ iproute2-2.6.37-orig/ip/iptunnel.c +@@ -9,6 +9,10 @@ + * Authors: Alexey Kuznetsov, <kuznet@ms2.inr.ac.ru> + * + */ ++#include <features.h> ++#if defined(__UCLIBC__) && !defined (__UCLIBC_HAS_IPV6__) ++#define NO_IPV6 ++#endif + + #include <stdio.h> + #include <stdlib.h> +@@ -601,8 +605,10 @@ int do_iptunnel(int argc, char **argv) + * protocol-independent because of unarranged structure between + * IPv4 and IPv6. + */ ++#ifndef NO_IPV6 + case AF_INET6: + return do_ip6tunnel(argc, argv); ++#endif + default: + fprintf(stderr, "Unsupported family:%d\n", preferred_family); + exit(-1); |