From: Jan Engelhardt Date: Tue, 15 Jan 2008 07:41:34 +0000 (-0800) Subject: [NETFILTER]: xt_pkttype: Add explicit check for IPv4 X-Git-Tag: firefly_0821_release~23655^2~729 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=13b0e83b5b52d1a0ab87772ecc93fe91b2740386;p=firefly-linux-kernel-4.4.55.git [NETFILTER]: xt_pkttype: Add explicit check for IPv4 In the PACKET_LOOPBACK case, the skb data was always interpreted as IPv4, but that is not valid for IPv6, obviously. Fix this by adding an extra condition to check for AF_INET. Signed-off-by: Jan Engelhardt Signed-off-by: Patrick McHardy Signed-off-by: David S. Miller --- diff --git a/net/netfilter/xt_pkttype.c b/net/netfilter/xt_pkttype.c index 276244902ab5..080f3246eee7 100644 --- a/net/netfilter/xt_pkttype.c +++ b/net/netfilter/xt_pkttype.c @@ -31,7 +31,8 @@ pkttype_mt(const struct sk_buff *skb, const struct net_device *in, const struct xt_pkttype_info *info = matchinfo; if (skb->pkt_type == PACKET_LOOPBACK) - type = ipv4_is_multicast(ip_hdr(skb)->daddr) + type = match->family == AF_INET && + ipv4_is_multicast(ip_hdr(skb)->daddr) ? PACKET_MULTICAST : PACKET_BROADCAST; else