[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-Id: <20190626.192829.1694521513812984310.davem@davemloft.net>
Date: Wed, 26 Jun 2019 19:28:29 -0700 (PDT)
From: David Miller <davem@...emloft.net>
To: yuehaibing@...wei.com
Cc: sdf@...gle.com, jianbol@...lanox.com, jiri@...lanox.com,
mirq-linux@...e.qmqm.pl, willemb@...gle.com, sdf@...ichev.me,
jiri@...nulli.us, linux-kernel@...r.kernel.org,
netdev@...r.kernel.org
Subject: Re: [PATCH v2] flow_dissector: Fix vlan header offset in
__skb_flow_dissect
From: YueHaibing <yuehaibing@...wei.com>
Date: Mon, 24 Jun 2019 11:49:13 +0800
> @@ -998,6 +998,9 @@ bool __skb_flow_dissect(const struct net *net,
> skb && skb_vlan_tag_present(skb)) {
> proto = skb->protocol;
> } else {
> + if (dissector_vlan == FLOW_DISSECTOR_KEY_MAX)
> + nhoff -= sizeof(*vlan);
> +
But this is wrong when we are being called via eth_get_headlen(), in
that case nhoff will be sizeof(struct ethhdr).
Powered by blists - more mailing lists