svn commit: r303658 - in stable/11/sys: compat/svr4 net
Gleb Smirnoff
glebius at FreeBSD.org
Tue Aug 2 13:57:21 UTC 2016
Author: glebius
Date: Tue Aug 2 13:57:20 2016
New Revision: 303658
URL: https://svnweb.freebsd.org/changeset/base/303658
Log:
Merge r303263:
Partially revert r257696/r257713, which have an issue with writing to user
controlled address. Restore the old code that emulated OSIOCGIFCONF in if.c.
Approved by: re (kib)
Modified:
stable/11/sys/compat/svr4/svr4_sockio.c
stable/11/sys/net/if.c
Directory Properties:
stable/11/ (props changed)
Modified: stable/11/sys/compat/svr4/svr4_sockio.c
==============================================================================
--- stable/11/sys/compat/svr4/svr4_sockio.c Tue Aug 2 12:18:06 2016 (r303657)
+++ stable/11/sys/compat/svr4/svr4_sockio.c Tue Aug 2 13:57:20 2016 (r303658)
@@ -73,6 +73,8 @@ bsd_to_svr4_flags(bf)
return sf;
}
+#define OSIOCGIFCONF _IOWR('i', 20, struct ifconf)
+
int
svr4_sock_ioctl(fp, td, retval, fd, cmd, data)
struct file *fp;
@@ -144,7 +146,6 @@ svr4_sock_ioctl(fp, td, retval, fd, cmd,
case SVR4_SIOCGIFCONF:
{
struct svr4_ifconf sc;
- struct ifconf *ifc;
if ((error = copyin(data, &sc, sizeof(sc))) != 0)
return error;
@@ -153,19 +154,9 @@ svr4_sock_ioctl(fp, td, retval, fd, cmd,
sizeof(struct ifreq), sizeof(struct svr4_ifreq),
sc.svr4_ifc_len));
- ifc = (struct ifconf *)≻
- ifc->ifc_req->ifr_addr.sa_family =
- sc.svr4_ifc_req->svr4_ifr_addr.sa_family;
- ifc->ifc_req->ifr_addr.sa_len =
- sizeof(struct osockaddr);
-
- error = fo_ioctl(fp, SIOCGIFCONF, &sc, td->td_ucred,
- td);
-
- sc.svr4_ifc_req->svr4_ifr_addr.sa_family =
- ifc->ifc_req->ifr_addr.sa_family;
-
- if (error != 0)
+ if ((error = fo_ioctl(fp, OSIOCGIFCONF,
+ (caddr_t) &sc, td->td_ucred,
+ td)) != 0)
return error;
DPRINTF(("SIOCGIFCONF\n"));
Modified: stable/11/sys/net/if.c
==============================================================================
--- stable/11/sys/net/if.c Tue Aug 2 12:18:06 2016 (r303657)
+++ stable/11/sys/net/if.c Tue Aug 2 13:57:20 2016 (r303658)
@@ -2699,6 +2699,9 @@ ifhwioctl(u_long cmd, struct ifnet *ifp,
return (error);
}
+/* COMPAT_SVR4 */
+#define OSIOCGIFCONF _IOWR('i', 20, struct ifconf)
+
#ifdef COMPAT_FREEBSD32
struct ifconf32 {
int32_t ifc_len;
@@ -2738,6 +2741,7 @@ ifioctl(struct socket *so, u_long cmd, c
switch (cmd) {
case SIOCGIFCONF:
+ case OSIOCGIFCONF: /* COMPAT_SVR4 */
error = ifconf(cmd, data);
CURVNET_RESTORE();
return (error);
@@ -3009,6 +3013,15 @@ again:
if (prison_if(curthread->td_ucred, sa) != 0)
continue;
addrs++;
+ /* COMPAT_SVR4 */
+ if (cmd == OSIOCGIFCONF) {
+ struct osockaddr *osa =
+ (struct osockaddr *)&ifr.ifr_addr;
+ ifr.ifr_addr = *sa;
+ osa->sa_family = sa->sa_family;
+ sbuf_bcat(sb, &ifr, sizeof(ifr));
+ max_len += sizeof(ifr);
+ } else
if (sa->sa_len <= sizeof(*sa)) {
ifr.ifr_addr = *sa;
sbuf_bcat(sb, &ifr, sizeof(ifr));
More information about the svn-src-stable-11
mailing list