aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndrey V. Elsukov <ae@FreeBSD.org>2021-08-05 08:51:46 +0000
committerAndrey V. Elsukov <ae@FreeBSD.org>2021-08-06 09:57:59 +0000
commitd477a7feed177d0ad5c12bc6e2cce804d427ed38 (patch)
treeaa845ff312b42360c0b509d700f4a2003372cadf
parentbb5cd80e8b42b31a2229077a7e93ffd3585eeb78 (diff)
downloadsrc-d477a7feed177d0ad5c12bc6e2cce804d427ed38.tar.gz
src-d477a7feed177d0ad5c12bc6e2cce804d427ed38.zip
Fix panic in IPv6 multicast code.
Add check that ifp supports IPv6 multicasts in in6_getmulti. This fixes panic when user application tries to join into multicast group on an interface that doesn't support IPv6 multicasts, like IFT_PFLOG interfaces. PR: 257302 Reviewed by: melifaro MFC after: 1 week Differential Revision: https://reviews.freebsd.org/D31420
-rw-r--r--sys/netinet6/in6_mcast.c11
1 files changed, 10 insertions, 1 deletions
diff --git a/sys/netinet6/in6_mcast.c b/sys/netinet6/in6_mcast.c
index 0744a1178fc7..7326befc6d01 100644
--- a/sys/netinet6/in6_mcast.c
+++ b/sys/netinet6/in6_mcast.c
@@ -374,9 +374,18 @@ in6_getmulti(struct ifnet *ifp, const struct in6_addr *group,
IN6_MULTI_LIST_LOCK();
IF_ADDR_WLOCK(ifp);
NET_EPOCH_ENTER(et);
- inm = in6m_lookup_locked(ifp, group);
+ /*
+ * Does ifp support IPv6 multicasts?
+ */
+ if (ifp->if_afdata[AF_INET6] == NULL)
+ error = ENODEV;
+ else
+ inm = in6m_lookup_locked(ifp, group);
NET_EPOCH_EXIT(et);
+ if (error != 0)
+ goto out_locked;
+
if (inm != NULL) {
/*
* If we already joined this group, just bump the