From mboxrd@z Thu Jan 1 00:00:00 1970 From: Bernhard Thaler Subject: [PATCHv3 4/4] netfilter: bridge: rename br_parse_ip_options Date: Wed, 25 Mar 2015 08:48:45 +0100 Message-ID: <5512685D.2010804@wvnet.at> Mime-Version: 1.0 Content-Type: text/plain; charset=windows-1252 Content-Transfer-Encoding: 7bit Cc: netfilter-devel@vger.kernel.org, fw@strlen.de, Bernhard Thaler To: pablo@netfilter.org, kadlec@blackhole.kfki.hu Return-path: Received: from smarthost2.wvnet.at ([62.212.174.131]:59381 "EHLO mx-out.wvnet.at" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1750735AbbCYHsx (ORCPT ); Wed, 25 Mar 2015 03:48:53 -0400 Received: from smtp.wvnet.at (localhost [127.0.0.1]) by mx-out.wvnet.at (Postfix) with ESMTP id 98C2636E18E for ; Wed, 25 Mar 2015 08:48:52 +0100 (CET) In-Reply-To: 20150324121420.GB1685@breakpoint.cc Sender: netfilter-devel-owner@vger.kernel.org List-ID: br_parse_ip_options() does not parse any IP options, it validates IP packets as a whole and the function name is misleading. Rename br_parse_ip_options(). Signed-off-by: Bernhard Thaler --- v3 * re-assignment of iph variable needed because pskb_may_pull() can invalidate the network header * same patch as v1 again v2 * first patch did not contain statement removing double iph variable assignment net/bridge/br_netfilter.c | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/net/bridge/br_netfilter.c b/net/bridge/br_netfilter.c index 0e129fb..2d73565 100644 --- a/net/bridge/br_netfilter.c +++ b/net/bridge/br_netfilter.c @@ -198,7 +198,7 @@ static inline void nf_bridge_save_header(struct sk_buff *skb) * expected format */ -static int br_parse_ip_options(struct sk_buff *skb) +static int br_validate_ipv4(struct sk_buff *skb) { const struct iphdr *iph; struct net_device *dev = skb->dev; @@ -300,7 +300,7 @@ bad: return -1; } -/* Equivalent to br_parse_ip_options for IPv6 */ +/* Equivalent to br_validate_ipv4 for IPv6 */ static int br_validate_ipv6(struct sk_buff *skb) { const struct ipv6hdr *hdr; @@ -718,7 +718,7 @@ static unsigned int br_nf_pre_routing(const struct nf_hook_ops *ops, nf_bridge_pull_encap_header_rcsum(skb); - if (br_parse_ip_options(skb)) + if (br_validate_ipv4(skb)) return NF_DROP; nf_bridge_put(skb->nf_bridge); @@ -819,7 +819,7 @@ static unsigned int br_nf_forward_ip(const struct nf_hook_ops *ops, nf_bridge->mask |= BRNF_PKT_TYPE; } - if (pf == NFPROTO_IPV4 && br_parse_ip_options(skb)) + if (pf == NFPROTO_IPV4 && br_validate_ipv4(skb)) return NF_DROP; /* The physdev module checks on this */ @@ -914,7 +914,7 @@ static int br_nf_dev_queue_xmit(struct sk_buff *skb) * boundaries by preserving frag_list rather than refragmenting. */ if (skb->protocol == htons(ETH_P_IP)) { - if (br_parse_ip_options(skb)) + if (br_validate_ipv4(skb)) /* Drop invalid packet */ return NF_DROP; IPCB(skb)->frag_max_size = BR_INPUT_SKB_CB(skb)->frag_max_size; -- 1.7.10.4