Commit 8489c1d9 authored by Eric Dumazet's avatar Eric Dumazet Committed by David S. Miller

net: raw: revert unrelated change

Commit 5640f768 ("net: use a per task frag allocator")
accidentally contained an unrelated change to net/ipv4/raw.c,
later committed (without the pr_err() debugging bits) in
net tree as commit ab43ed8b (ipv4: raw: fix icmp_filter())

This patch reverts this glitch, noticed by Stephen Rothwell.
Reported-by: default avatarStephen Rothwell <sfr@canb.auug.org.au>
Signed-off-by: default avatarEric Dumazet <edumazet@google.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
parent 82c93fcc
...@@ -131,23 +131,18 @@ static struct sock *__raw_v4_lookup(struct net *net, struct sock *sk, ...@@ -131,23 +131,18 @@ static struct sock *__raw_v4_lookup(struct net *net, struct sock *sk,
* 0 - deliver * 0 - deliver
* 1 - block * 1 - block
*/ */
static int icmp_filter(const struct sock *sk, const struct sk_buff *skb) static __inline__ int icmp_filter(struct sock *sk, struct sk_buff *skb)
{ {
struct icmphdr _hdr; int type;
const struct icmphdr *hdr;
if (!pskb_may_pull(skb, sizeof(struct icmphdr)))
pr_err("icmp_filter skb_transport_offset %d data-head %ld len %d/%d\n",
skb_transport_offset(skb), skb->data - skb->head, skb->len, skb->data_len);
hdr = skb_header_pointer(skb, skb_transport_offset(skb),
sizeof(_hdr), &_hdr);
pr_err("head %p data %p hdr %p type %d\n", skb->head, skb->data, hdr, hdr ? hdr->type : -1);
if (!hdr)
return 1; return 1;
if (hdr->type < 32) { type = icmp_hdr(skb)->type;
if (type < 32) {
__u32 data = raw_sk(sk)->filter.data; __u32 data = raw_sk(sk)->filter.data;
return ((1U << hdr->type) & data) != 0; return ((1 << type) & data) != 0;
} }
/* Do not block unknown ICMP types */ /* Do not block unknown ICMP types */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment