diff options
author | Quentin Armitage <quentin@armitage.org.uk> | 2014-07-23 04:58:01 -0400 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2014-07-23 18:13:26 -0400 |
commit | f5220d63991f3fcb3d19efe8af0c8f75dcf0309b (patch) | |
tree | 60887bb186ce7fb67160cabb858f52c231c30c9e /net/ipv4/raw.c | |
parent | 92bab4e71522767bd9033fff60744b111b015fef (diff) |
ipv4: Make IP_MULTICAST_ALL and IP_MSFILTER work on raw sockets
Currently, although IP_MULTICAST_ALL and IP_MSFILTER ioctl calls succeed on
raw sockets, there is no code to implement the functionality on received
packets; it is only implemented for UDP sockets. The raw(7) man page states:
"In addition, all ip(7) IPPROTO_IP socket options valid for datagram sockets
are supported", which implies these ioctls should work on raw sockets.
To fix this, add a call to ip_mc_sf_allow on raw sockets.
This should not break any existing code, since the current position of
not calling ip_mc_sf_filter makes it behave as if neither the IP_MULTICAST_ALL
nor the IP_MSFILTER ioctl had been called. Adding the call to ip_mc_sf_allow
will therefore maintain the current behaviour so long as IP_MULTICAST_ALL and
IP_MSFILTER ioctls are not called. Any code that currently is calling
IP_MULTICAST_ALL or IP_MSFILTER ioctls on raw sockets presumably is wanting
the filter to be applied, although no filtering will currently be occurring.
Signed-off-by: Quentin Armitage <quentin@armitage.org.uk>
Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'net/ipv4/raw.c')
-rw-r--r-- | net/ipv4/raw.c | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/net/ipv4/raw.c b/net/ipv4/raw.c index 2054d7136c62..739db3100c23 100644 --- a/net/ipv4/raw.c +++ b/net/ipv4/raw.c | |||
@@ -58,6 +58,7 @@ | |||
58 | #include <linux/in_route.h> | 58 | #include <linux/in_route.h> |
59 | #include <linux/route.h> | 59 | #include <linux/route.h> |
60 | #include <linux/skbuff.h> | 60 | #include <linux/skbuff.h> |
61 | #include <linux/igmp.h> | ||
61 | #include <net/net_namespace.h> | 62 | #include <net/net_namespace.h> |
62 | #include <net/dst.h> | 63 | #include <net/dst.h> |
63 | #include <net/sock.h> | 64 | #include <net/sock.h> |
@@ -174,7 +175,9 @@ static int raw_v4_input(struct sk_buff *skb, const struct iphdr *iph, int hash) | |||
174 | 175 | ||
175 | while (sk) { | 176 | while (sk) { |
176 | delivered = 1; | 177 | delivered = 1; |
177 | if (iph->protocol != IPPROTO_ICMP || !icmp_filter(sk, skb)) { | 178 | if ((iph->protocol != IPPROTO_ICMP || !icmp_filter(sk, skb)) && |
179 | ip_mc_sf_allow(sk, iph->daddr, iph->saddr, | ||
180 | skb->dev->ifindex)) { | ||
178 | struct sk_buff *clone = skb_clone(skb, GFP_ATOMIC); | 181 | struct sk_buff *clone = skb_clone(skb, GFP_ATOMIC); |
179 | 182 | ||
180 | /* Not releasing hash table! */ | 183 | /* Not releasing hash table! */ |