aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJames Clarke <jrtc27@jrtc27.com>2017-10-07 18:53:23 +0100
committerDenys Vlasenko <vda.linux@googlemail.com>2017-10-30 16:06:50 +0100
commit518fb3ba193cddc1369090bfdf827618b42791db (patch)
tree437b68db12aaa6910a1f2d717f2374c5ad78acb7
parentd1535216ca27047e3962d61b975bd2a638aa45a2 (diff)
downloadbusybox-w32-518fb3ba193cddc1369090bfdf827618b42791db.tar.gz
busybox-w32-518fb3ba193cddc1369090bfdf827618b42791db.tar.bz2
busybox-w32-518fb3ba193cddc1369090bfdf827618b42791db.zip
udp_io, traceroute: Standardise IPv6 PKTINFO handling to be portable
The current standard (RFC 3542) is for IPV6_RECVPKTINFO to be given to setsockopt, and IPV6_PKTINFO to be used as the packet type. Previously, RFC 2292 required IPV6_PKTINFO to be used for both, but RFC 3542 re-purposed IPV6_PKTINFO when given to setsockopt. The special Linux-specific IPV6_2292PKTINFO has the same semantics as IPV6_PKTINFO in RFC 2292, but was introduced at the same time as IPV6_RECVPKTINFO. Therefore, if we have IPV6_RECVPKTINFO available, we can use the RFC 3542 style, and if not, we assume that only the RFC 2292 API is available, using IPV6_PKTINFO for both. Signed-off-by: James Clarke <jrtc27@jrtc27.com> Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
-rw-r--r--libbb/udp_io.c8
-rw-r--r--networking/traceroute.c8
2 files changed, 9 insertions, 7 deletions
diff --git a/libbb/udp_io.c b/libbb/udp_io.c
index 6e3ef484e..68355e6c4 100644
--- a/libbb/udp_io.c
+++ b/libbb/udp_io.c
@@ -8,6 +8,10 @@
8 */ 8 */
9#include "libbb.h" 9#include "libbb.h"
10 10
11#if defined(IPV6_PKTINFO) && !defined(IPV6_RECVPKTINFO)
12# define IPV6_RECVPKTINFO IPV6_PKTINFO
13#endif
14
11/* 15/*
12 * This asks kernel to let us know dst addr/port of incoming packets 16 * This asks kernel to let us know dst addr/port of incoming packets
13 * We don't check for errors here. Not supported == won't be used 17 * We don't check for errors here. Not supported == won't be used
@@ -18,8 +22,8 @@ socket_want_pktinfo(int fd UNUSED_PARAM)
18#ifdef IP_PKTINFO 22#ifdef IP_PKTINFO
19 setsockopt_1(fd, IPPROTO_IP, IP_PKTINFO); 23 setsockopt_1(fd, IPPROTO_IP, IP_PKTINFO);
20#endif 24#endif
21#if ENABLE_FEATURE_IPV6 && defined(IPV6_PKTINFO) 25#if ENABLE_FEATURE_IPV6 && defined(IPV6_RECVPKTINFO)
22 setsockopt_1(fd, IPPROTO_IPV6, IPV6_PKTINFO); 26 setsockopt_1(fd, IPPROTO_IPV6, IPV6_RECVPKTINFO);
23#endif 27#endif
24} 28}
25 29
diff --git a/networking/traceroute.c b/networking/traceroute.c
index df7122047..6dcbc2faa 100644
--- a/networking/traceroute.c
+++ b/networking/traceroute.c
@@ -311,6 +311,9 @@
311# ifndef SOL_IPV6 311# ifndef SOL_IPV6
312# define SOL_IPV6 IPPROTO_IPV6 312# define SOL_IPV6 IPPROTO_IPV6
313# endif 313# endif
314# if defined(IPV6_PKTINFO) && !defined(IPV6_RECVPKTINFO)
315# define IPV6_RECVPKTINFO IPV6_PKTINFO
316# endif
314#endif 317#endif
315 318
316#include "libbb.h" 319#include "libbb.h"
@@ -911,12 +914,7 @@ common_traceroute_main(int op, char **argv)
911#if ENABLE_TRACEROUTE6 914#if ENABLE_TRACEROUTE6
912 if (af == AF_INET6) { 915 if (af == AF_INET6) {
913 xmove_fd(xsocket(AF_INET6, SOCK_RAW, IPPROTO_ICMPV6), rcvsock); 916 xmove_fd(xsocket(AF_INET6, SOCK_RAW, IPPROTO_ICMPV6), rcvsock);
914# ifdef IPV6_RECVPKTINFO
915 setsockopt_1(rcvsock, SOL_IPV6, IPV6_RECVPKTINFO); 917 setsockopt_1(rcvsock, SOL_IPV6, IPV6_RECVPKTINFO);
916 setsockopt_1(rcvsock, SOL_IPV6, IPV6_2292PKTINFO);
917# else
918 setsockopt_1(rcvsock, SOL_IPV6, IPV6_PKTINFO);
919# endif
920 } else 918 } else
921#endif 919#endif
922 { 920 {