Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/netbsd-8]: src Pull up following revision(s) (requested by tih in ticket...
details: https://anonhg.NetBSD.org/src/rev/a48bbdff6af2
branches: netbsd-8
changeset: 851493:a48bbdff6af2
user: martin <martin%NetBSD.org@localhost>
date: Sun Mar 18 10:57:01 2018 +0000
description:
Pull up following revision(s) (requested by tih in ticket #639):
sys/kern/uipc_socket.c: revision 1.258
sys/kern/uipc_socket.c: revision 1.259
sys/netinet/ip_input.c: revision 1.364 (via patch)
sys/netinet/ip_output.c: revision 1.289
sys/netinet/in.h: revision 1.102
sys/netinet/in_pcb.c: revision 1.181
share/man/man9/sockopt.9: revision 1.11
sys/netinet/in_pcb.h: revision 1.65
sys/sys/socketvar.h: revision 1.146
sys/kern/uipc_syscalls.c: revision 1.189
sys/netinet/ip_output.c: revision 1.290
share/man/man4/ip.4: revision 1.41
share/man/man4/ip.4: revision 1.42
sys/kern/uipc_syscalls.c: revision 1.190
pass valsize for getsockopt like we do for setsockopt
make sure that we have enough space, don't require the exact size
(Tom Ivar Helbekkmo)
1) "#define ipi_spec_dst ipi_addr" in <netinet/in.h>
2) Change the IP_RECVPKTINFO option to control the generation of
IP_PKTINFO control messages, the way it's done in Solaris.
3) Remove the superfluous IP_RECVPKTINFO control message.
4) Change the IP_PKTINFO option to do different things depending on
the parameter it's supplied with:
- If it's sizeof(int), assume it's being used as in Linux:
- If it's non-zero, turn on the IP_RECVPKTINFO option.
- If it's zero, turn off the IP_RECVPKTINFO option.
- If it's sizeof(struct in_pktinfo), assume it's being used as in
Solaris, to set a default for the source interface and/or
source address for outgoing packets on the socket.
5) Return what Linux or Solaris compatible code expects, depending
on data size, and just added a fallback to a Linux (and current NetBSD)
compatible value if the size is unknown (as it is now), or,
in the future, if the calling application specifies a receiving
buffer that doesn't match either data item.
From: Tom Ivar Helbekkmo
new sentence-new line
Remove comment now that the getsockopt code passes the size.
Add a new sockopt member to keep track of the actual size of the option
that should be returned to the caller in getsockopt(2).
(Tom Ivar Helbekkmo)
diffstat:
share/man/man4/ip.4 | 62 +++++++++++++++++++++-----
share/man/man9/sockopt.9 | 7 +-
sys/kern/uipc_socket.c | 15 ++++-
sys/kern/uipc_syscalls.c | 11 +++-
sys/netinet/in.h | 10 +++-
sys/netinet/in_pcb.c | 5 +-
sys/netinet/in_pcb.h | 9 +--
sys/netinet/ip_input.c | 13 +----
sys/netinet/ip_output.c | 108 ++++++++++++++++++++++++++++++++++++++--------
sys/sys/socketvar.h | 3 +-
10 files changed, 179 insertions(+), 64 deletions(-)
diffs (truncated from 565 to 300 lines):
diff -r 4740aca6c7ed -r a48bbdff6af2 share/man/man4/ip.4
--- a/share/man/man4/ip.4 Sun Mar 18 10:20:38 2018 +0000
+++ b/share/man/man4/ip.4 Sun Mar 18 10:57:01 2018 +0000
@@ -1,4 +1,4 @@
-.\" $NetBSD: ip.4,v 1.36.20.1 2017/12/21 21:08:13 snj Exp $
+.\" $NetBSD: ip.4,v 1.36.20.2 2018/03/18 10:57:02 martin Exp $
.\"
.\" Copyright (c) 1983, 1991, 1993
.\" The Regents of the University of California. All rights reserved.
@@ -29,7 +29,7 @@
.\"
.\" @(#)ip.4 8.2 (Berkeley) 11/30/93
.\"
-.Dd August 10, 2017
+.Dd December 31, 2017
.Dt IP 4
.Os
.Sh NAME
@@ -111,8 +111,8 @@
.Ed
.Pp
The
-.Dv IP_PKTINFO
-option can be used to turn on receiving of information about the source
+.Dv IP_RECVPKTINFO
+option can be used to turn on receiving of information about the destination
address of the packet, and the interface index.
The information is passed in a
.Vt struct in_pktinfo
@@ -132,13 +132,25 @@
.Pp
For
.Xr sendmsg 2 ,
-the source address or output interface can be specified by adding
+the source address or output interface can be specified by adding an
.Dv IP_PKTINFO
-to the control part of the message on a
+message to the control part of the message on a
.Dv SOCK_DGRAM
or
.Dv SOCK_RAW
socket.
+Setting ipi_ifindex will cause the primary address of that interface
+to be used; setting ipi_addr will directly choose that address.
+The IP_PKTINFO cmsghdr structure from a received message may be
+used unchanged, in which case the outgoing message will be sent
+from the address the incoming message was received on.
+.Pp
+Setting the
+.Dv IP_PKTINFO
+option on a socket, with the same
+.Vt struct in_pktinfo
+structure, will set the default source address to be used until set
+again, unless explicitly overridden on a per-packet basis, as above.
.Pp
The
.Dv IP_PORTALGO
@@ -199,6 +211,19 @@
cmsg_type = IP_RECVDSTADDR
.Ed
.Pp
+For
+.Xr sendmsg 2 ,
+the source address can be specified by adding
+.Dv IP_SENDSRCADDR
+to the control part of the message on a
+.Dv SOCK_DGRAM
+or
+.Dv SOCK_RAW
+socket.
+The IP_RECVDSTADDR cmsghdr structure from a received message may
+be used unchanged, in which case the outgoing message will be sent
+from the address the incoming message was received on.
+.Pp
If the
.Dv IP_RECVIF
option is enabled on a
@@ -219,12 +244,6 @@
cmsg_type = IP_RECVIF
.Ed
.Pp
-The
-.Dv IP_RECVPKTINFO
-option is similar to the
-.Dv IP_PKTINFO
-one, only in this case the inbound information is returned.
-.Pp
If the
.Dv IP_RECVTTL
option is enabled on a
@@ -491,6 +510,25 @@
The IP option field was improperly formed; an option field was
shorter than the minimum value or longer than the option buffer provided.
.El
+.Sh COMPATIBILITY
+The
+.Dv IP_RECVPKTINFO
+option is used because it is directly compatible with Solaris, AIX, etc.,
+and the
+.Dv IP_PKTINFO
+option is intended to be used in their manner, to set the default source
+address for outgoing packets on a
+.Dv SOCK_DGRAM
+or
+.Dv SOCK_RAW
+socket.
+For compatibility with Linux, however, if you attempt to set the
+.Dv IP_PKTINFO
+option, using an integer parameter as a boolean value, this will
+transparently manipulate the
+.Dv IP_RECVPKTINFO
+option instead.
+Source code compatbility with both environments is thus maintained.
.Sh SEE ALSO
.Xr getsockopt 2 ,
.Xr recv 2 ,
diff -r 4740aca6c7ed -r a48bbdff6af2 share/man/man9/sockopt.9
--- a/share/man/man9/sockopt.9 Sun Mar 18 10:20:38 2018 +0000
+++ b/share/man/man9/sockopt.9 Sun Mar 18 10:57:01 2018 +0000
@@ -1,4 +1,4 @@
-.\" $NetBSD: sockopt.9,v 1.10 2017/01/16 12:54:25 njoly Exp $
+.\" $NetBSD: sockopt.9,v 1.10.4.1 2018/03/18 10:57:01 martin Exp $
.\"
.\" Copyright (c) 2008 Iain Hibbert
.\" All rights reserved.
@@ -23,7 +23,7 @@
.\" (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
.\" THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
.\"
-.Dd September 4, 2009
+.Dd January 3, 2018
.Dt SOCKOPT 9
.Os
.Sh NAME
@@ -57,6 +57,7 @@
int sopt_level; /* option level */
int sopt_name; /* option name */
size_t sopt_size; /* data length */
+ size_t sopt_retsize; /* returned data length */
void * sopt_data; /* data pointer */
uint8_t sopt_buf[sizeof(int)]; /* internal storage */
};
@@ -133,7 +134,7 @@
which will not fail.
.It Fn sockopt_setint "sopt" "value"
Common case of set sockopt integer value.
-The sockpt structure must contain an int sized data field or be previously
+The sockopt structure must contain an int sized data field or be previously
unset, in which case the data pointer will be set to the internal storage.
.El
.Sh CODE REFERENCES
diff -r 4740aca6c7ed -r a48bbdff6af2 sys/kern/uipc_socket.c
--- a/sys/kern/uipc_socket.c Sun Mar 18 10:20:38 2018 +0000
+++ b/sys/kern/uipc_socket.c Sun Mar 18 10:57:01 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: uipc_socket.c,v 1.255 2017/05/27 21:02:56 bouyer Exp $ */
+/* $NetBSD: uipc_socket.c,v 1.255.2.1 2018/03/18 10:57:01 martin Exp $ */
/*-
* Copyright (c) 2002, 2007, 2008, 2009 The NetBSD Foundation, Inc.
@@ -71,7 +71,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: uipc_socket.c,v 1.255 2017/05/27 21:02:56 bouyer Exp $");
+__KERNEL_RCSID(0, "$NetBSD: uipc_socket.c,v 1.255.2.1 2018/03/18 10:57:01 martin Exp $");
#ifdef _KERNEL_OPT
#include "opt_compat_netbsd.h"
@@ -2109,8 +2109,12 @@
return error;
}
- KASSERT(sopt->sopt_size == len);
+ if (sopt->sopt_size < len)
+ return EINVAL;
+
memcpy(sopt->sopt_data, buf, len);
+ sopt->sopt_retsize = len;
+
return 0;
}
@@ -2169,9 +2173,12 @@
return error;
}
- KASSERT(sopt->sopt_size == len);
+ if (sopt->sopt_size < len)
+ return EINVAL;
+
m_copydata(m, 0, len, sopt->sopt_data);
m_freem(m);
+ sopt->sopt_retsize = len;
return 0;
}
diff -r 4740aca6c7ed -r a48bbdff6af2 sys/kern/uipc_syscalls.c
--- a/sys/kern/uipc_syscalls.c Sun Mar 18 10:20:38 2018 +0000
+++ b/sys/kern/uipc_syscalls.c Sun Mar 18 10:57:01 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: uipc_syscalls.c,v 1.186 2017/02/03 16:06:45 christos Exp $ */
+/* $NetBSD: uipc_syscalls.c,v 1.186.6.1 2018/03/18 10:57:01 martin Exp $ */
/*-
* Copyright (c) 2008, 2009 The NetBSD Foundation, Inc.
@@ -61,7 +61,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: uipc_syscalls.c,v 1.186 2017/02/03 16:06:45 christos Exp $");
+__KERNEL_RCSID(0, "$NetBSD: uipc_syscalls.c,v 1.186.6.1 2018/03/18 10:57:01 martin Exp $");
#ifdef _KERNEL_OPT
#include "opt_pipe.h"
@@ -1235,7 +1235,10 @@
if ((error = fd_getsock1(SCARG(uap, s), &so, &fp)) != 0)
return (error);
- sockopt_init(&sopt, SCARG(uap, level), SCARG(uap, name), 0);
+ if (valsize > MCLBYTES)
+ return EINVAL;
+
+ sockopt_init(&sopt, SCARG(uap, level), SCARG(uap, name), valsize);
if (fp->f_flag & FNOSIGPIPE)
so->so_options |= SO_NOSIGPIPE;
@@ -1246,7 +1249,7 @@
goto out;
if (valsize > 0) {
- len = min(valsize, sopt.sopt_size);
+ len = min(valsize, sopt.sopt_retsize);
error = copyout(sopt.sopt_data, SCARG(uap, val), len);
if (error)
goto out;
diff -r 4740aca6c7ed -r a48bbdff6af2 sys/netinet/in.h
--- a/sys/netinet/in.h Sun Mar 18 10:20:38 2018 +0000
+++ b/sys/netinet/in.h Sun Mar 18 10:57:01 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: in.h,v 1.100.6.2 2018/02/11 21:17:34 snj Exp $ */
+/* $NetBSD: in.h,v 1.100.6.3 2018/03/18 10:57:01 martin Exp $ */
/*
* Copyright (c) 1982, 1986, 1990, 1993
@@ -289,8 +289,10 @@
#define IP_IPSEC_POLICY 22 /* struct; get/set security policy */
#define IP_RECVTTL 23 /* bool; receive IP TTL w/dgram */
#define IP_MINTTL 24 /* minimum TTL for packet or drop */
-#define IP_PKTINFO 25 /* int; send interface and src addr */
-#define IP_RECVPKTINFO 26 /* int; send interface and dst addr */
+#define IP_PKTINFO 25 /* struct; set default src if/addr */
+#define IP_RECVPKTINFO 26 /* int; receive dst if/addr w/dgram */
+
+#define IP_SENDSRCADDR IP_RECVDSTADDR /* FreeBSD compatibility */
/*
* Information sent in the control message of a datagram socket for
@@ -301,6 +303,8 @@
unsigned int ipi_ifindex; /* interface index */
};
+#define ipi_spec_dst ipi_addr /* Solaris/Linux compatibility */
+
/*
* Defaults and limits for options
*/
diff -r 4740aca6c7ed -r a48bbdff6af2 sys/netinet/in_pcb.c
--- a/sys/netinet/in_pcb.c Sun Mar 18 10:20:38 2018 +0000
+++ b/sys/netinet/in_pcb.c Sun Mar 18 10:57:01 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: in_pcb.c,v 1.178.4.2 2018/01/02 10:20:34 snj Exp $ */
+/* $NetBSD: in_pcb.c,v 1.178.4.3 2018/03/18 10:57:01 martin Exp $ */
/*
* Copyright (C) 1995, 1996, 1997, and 1998 WIDE Project.
@@ -93,7 +93,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: in_pcb.c,v 1.178.4.2 2018/01/02 10:20:34 snj Exp $");
+__KERNEL_RCSID(0, "$NetBSD: in_pcb.c,v 1.178.4.3 2018/03/18 10:57:01 martin Exp $");
#ifdef _KERNEL_OPT
#include "opt_inet.h"
@@ -204,6 +204,7 @@
inp->inp_errormtu = -1;
inp->inp_portalgo = PORTALGO_DEFAULT;
inp->inp_bindportonsend = false;
+ inp->inp_prefsrcip.s_addr = INADDR_ANY;
#if defined(IPSEC)
if (ipsec_enabled) {
int error = ipsec_init_pcbpolicy(so, &inp->inp_sp);
diff -r 4740aca6c7ed -r a48bbdff6af2 sys/netinet/in_pcb.h
--- a/sys/netinet/in_pcb.h Sun Mar 18 10:20:38 2018 +0000
+++ b/sys/netinet/in_pcb.h Sun Mar 18 10:57:01 2018 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: in_pcb.h,v 1.63.6.1 2017/12/21 21:08:13 snj Exp $ */
+/* $NetBSD: in_pcb.h,v 1.63.6.2 2018/03/18 10:57:01 martin Exp $ */
Home |
Main Index |
Thread Index |
Old Index