git: 01e9cbc4c56d - main - Use thunks for compat ioctls using struct ifgroupreq.
John Baldwin
jhb at FreeBSD.org
Wed May 5 20:59:39 UTC 2021
The branch main has been updated by jhb:
URL: https://cgit.FreeBSD.org/src/commit/?id=01e9cbc4c56d6eecc52f1e4547d56124243f0dd2
commit 01e9cbc4c56d6eecc52f1e4547d56124243f0dd2
Author: John Baldwin <jhb at FreeBSD.org>
AuthorDate: 2021-05-05 20:59:00 +0000
Commit: John Baldwin <jhb at FreeBSD.org>
CommitDate: 2021-05-05 20:59:00 +0000
Use thunks for compat ioctls using struct ifgroupreq.
Reviewed by: brooks, kib
Obtained from: CheriBSD
Sponsored by: DARPA
Differential Revision: https://reviews.freebsd.org/D29893
---
sys/net/if.c | 99 +++++++++++++++++++++++++++---------------------------------
sys/net/if.h | 2 --
2 files changed, 45 insertions(+), 56 deletions(-)
diff --git a/sys/net/if.c b/sys/net/if.c
index 2517c1f7e5bc..9b461a15a57a 100644
--- a/sys/net/if.c
+++ b/sys/net/if.c
@@ -166,6 +166,10 @@ struct ifgroupreq32 {
uint32_t ifgru_groups;
} ifgr_ifgru;
};
+#define SIOCAIFGROUP32 _IOC_NEWTYPE(SIOCAIFGROUP, struct ifgroupreq32)
+#define SIOCGIFGROUP32 _IOC_NEWTYPE(SIOCGIFGROUP, struct ifgroupreq32)
+#define SIOCDIFGROUP32 _IOC_NEWTYPE(SIOCDIFGROUP, struct ifgroupreq32)
+#define SIOCGIFGMEMB32 _IOC_NEWTYPE(SIOCGIFGMEMB, struct ifgroupreq32)
struct ifmediareq32 {
char ifm_name[IFNAMSIZ];
@@ -178,16 +182,7 @@ struct ifmediareq32 {
};
#define SIOCGIFMEDIA32 _IOC_NEWTYPE(SIOCGIFMEDIA, struct ifmediareq32)
#define SIOCGIFXMEDIA32 _IOC_NEWTYPE(SIOCGIFXMEDIA, struct ifmediareq32)
-
-#define _CASE_IOC_IFGROUPREQ_32(cmd) \
- _IOC_NEWTYPE((cmd), struct ifgroupreq32): case
-#else /* !COMPAT_FREEBSD32 */
-#define _CASE_IOC_IFGROUPREQ_32(cmd)
-#endif /* !COMPAT_FREEBSD32 */
-
-#define CASE_IOC_IFGROUPREQ(cmd) \
- _CASE_IOC_IFGROUPREQ_32(cmd) \
- (cmd)
+#endif /* COMPAT_FREEBSD32 */
union ifreq_union {
struct ifreq ifr;
@@ -196,13 +191,6 @@ union ifreq_union {
#endif
};
-union ifgroupreq_union {
- struct ifgroupreq ifgr;
-#ifdef COMPAT_FREEBSD32
- struct ifgroupreq32 ifgr32;
-#endif
-};
-
SYSCTL_NODE(_net, PF_LINK, link, CTLFLAG_RW | CTLFLAG_MPSAFE, 0,
"Link layers");
SYSCTL_NODE(_net_link, 0, generic, CTLFLAG_RW | CTLFLAG_MPSAFE, 0,
@@ -1663,33 +1651,6 @@ if_delgroups(struct ifnet *ifp)
IFNET_WUNLOCK();
}
-static char *
-ifgr_group_get(void *ifgrp)
-{
- union ifgroupreq_union *ifgrup;
-
- ifgrup = ifgrp;
-#ifdef COMPAT_FREEBSD32
- if (SV_CURPROC_FLAG(SV_ILP32))
- return (&ifgrup->ifgr32.ifgr_ifgru.ifgru_group[0]);
-#endif
- return (&ifgrup->ifgr.ifgr_ifgru.ifgru_group[0]);
-}
-
-static struct ifg_req *
-ifgr_groups_get(void *ifgrp)
-{
- union ifgroupreq_union *ifgrup;
-
- ifgrup = ifgrp;
-#ifdef COMPAT_FREEBSD32
- if (SV_CURPROC_FLAG(SV_ILP32))
- return ((struct ifg_req *)(uintptr_t)
- ifgrup->ifgr32.ifgr_ifgru.ifgru_groups);
-#endif
- return (ifgrup->ifgr.ifgr_ifgru.ifgru_groups);
-}
-
/*
* Stores all groups from an interface in memory pointed to by ifgr.
*/
@@ -1709,7 +1670,7 @@ if_getgroup(struct ifgroupreq *ifgr, struct ifnet *ifp)
}
len = ifgr->ifgr_len;
- ifgp = ifgr_groups_get(ifgr);
+ ifgp = ifgr->ifgr_groups;
/* XXX: wire */
CK_STAILQ_FOREACH(ifgl, &ifp->if_groups, ifgl_next) {
if (len < sizeof(ifgrq))
@@ -1754,7 +1715,7 @@ if_getgroupmembers(struct ifgroupreq *ifgr)
}
len = ifgr->ifgr_len;
- ifgp = ifgr_groups_get(ifgr);
+ ifgp = ifgr->ifgr_groups;
CK_STAILQ_FOREACH(ifgm, &ifg->ifg_members, ifgm_next) {
if (len < sizeof(ifgrq)) {
IFNET_RUNLOCK();
@@ -2881,16 +2842,17 @@ ifhwioctl(u_long cmd, struct ifnet *ifp, caddr_t data, struct thread *td)
error = if_gethwaddr(ifp, ifr);
break;
- case CASE_IOC_IFGROUPREQ(SIOCAIFGROUP):
+ case SIOCAIFGROUP:
error = priv_check(td, PRIV_NET_ADDIFGROUP);
if (error)
return (error);
- if ((error = if_addgroup(ifp,
- ifgr_group_get((struct ifgroupreq *)data))))
+ error = if_addgroup(ifp,
+ ((struct ifgroupreq *)data)->ifgr_group);
+ if (error != 0)
return (error);
break;
- case CASE_IOC_IFGROUPREQ(SIOCGIFGROUP):
+ case SIOCGIFGROUP:
{
struct epoch_tracker et;
@@ -2900,12 +2862,13 @@ ifhwioctl(u_long cmd, struct ifnet *ifp, caddr_t data, struct thread *td)
break;
}
- case CASE_IOC_IFGROUPREQ(SIOCDIFGROUP):
+ case SIOCDIFGROUP:
error = priv_check(td, PRIV_NET_DELIFGROUP);
if (error)
return (error);
- if ((error = if_delgroup(ifp,
- ifgr_group_get((struct ifgroupreq *)data))))
+ error = if_delgroup(ifp,
+ ((struct ifgroupreq *)data)->ifgr_group);
+ if (error != 0)
return (error);
break;
@@ -2936,12 +2899,14 @@ ifioctl(struct socket *so, u_long cmd, caddr_t data, struct thread *td)
union {
struct ifconf ifc;
struct ifdrv ifd;
+ struct ifgroupreq ifgr;
struct ifmediareq ifmr;
} thunk;
caddr_t saved_data;
u_long saved_cmd;
struct ifconf32 *ifc32;
struct ifdrv32 *ifd32;
+ struct ifgroupreq32 *ifgr32;
struct ifmediareq32 *ifmr32;
#endif
struct ifnet *ifp;
@@ -2984,6 +2949,28 @@ ifioctl(struct socket *so, u_long cmd, caddr_t data, struct thread *td)
data = (caddr_t)&thunk.ifd;
cmd = _IOC_NEWTYPE(cmd, struct ifdrv);
break;
+ case SIOCAIFGROUP32:
+ case SIOCGIFGROUP32:
+ case SIOCDIFGROUP32:
+ case SIOCGIFGMEMB32:
+ ifgr32 = (struct ifgroupreq32 *)data;
+ memcpy(thunk.ifgr.ifgr_name, ifgr32->ifgr_name,
+ sizeof(thunk.ifgr.ifgr_name));
+ thunk.ifgr.ifgr_len = ifgr32->ifgr_len;
+ switch (cmd) {
+ case SIOCAIFGROUP32:
+ case SIOCDIFGROUP32:
+ memcpy(thunk.ifgr.ifgr_group, ifgr32->ifgr_group,
+ sizeof(thunk.ifgr.ifgr_group));
+ break;
+ case SIOCGIFGROUP32:
+ case SIOCGIFGMEMB32:
+ thunk.ifgr.ifgr_groups = PTRIN(ifgr32->ifgr_groups);
+ break;
+ }
+ data = (caddr_t)&thunk.ifgr;
+ cmd = _IOC_NEWTYPE(cmd, struct ifgroupreq);
+ break;
case SIOCGIFMEDIA32:
case SIOCGIFXMEDIA32:
ifmr32 = (struct ifmediareq32 *)data;
@@ -3039,7 +3026,7 @@ ifioctl(struct socket *so, u_long cmd, caddr_t data, struct thread *td)
error = if_clone_list((struct if_clonereq *)data);
goto out_noref;
- case CASE_IOC_IFGROUPREQ(SIOCGIFGMEMB):
+ case SIOCGIFGMEMB:
error = if_getgroupmembers((struct ifgroupreq *)data);
goto out_noref;
@@ -3115,6 +3102,10 @@ out_noref:
("ifd_len was updated %u -> %zu", ifd32->ifd_len,
thunk.ifd.ifd_len));
break;
+ case SIOCGIFGROUP32:
+ case SIOCGIFGMEMB32:
+ ifgr32->ifgr_len = thunk.ifgr.ifgr_len;
+ break;
case SIOCGIFMEDIA32:
case SIOCGIFXMEDIA32:
ifmr32->ifm_current = thunk.ifmr.ifm_current;
diff --git a/sys/net/if.h b/sys/net/if.h
index e6073563bce2..782e792cf87c 100644
--- a/sys/net/if.h
+++ b/sys/net/if.h
@@ -530,10 +530,8 @@ struct ifgroupreq {
char ifgru_group[IFNAMSIZ];
struct ifg_req *ifgru_groups;
} ifgr_ifgru;
-#ifndef _KERNEL
#define ifgr_group ifgr_ifgru.ifgru_group
#define ifgr_groups ifgr_ifgru.ifgru_groups
-#endif
};
/*
More information about the dev-commits-src-main
mailing list