ip6_gre: use actual protocol to select xmit
When the payload is a VLAN encapsulated IPv6/IPv6 frame, we can skip the 802.1q/802.1ad ethertypes and jump to the actual protocol. This way we treat IPv4/IPv6 frames as IP instead of as "other". Signed-off-by: Matthias May <matthias.may@westermo.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
Родитель
41337f52b9
Коммит
3f8a8447fd
|
@ -916,6 +916,7 @@ static netdev_tx_t ip6gre_tunnel_xmit(struct sk_buff *skb,
|
||||||
{
|
{
|
||||||
struct ip6_tnl *t = netdev_priv(dev);
|
struct ip6_tnl *t = netdev_priv(dev);
|
||||||
struct net_device_stats *stats = &t->dev->stats;
|
struct net_device_stats *stats = &t->dev->stats;
|
||||||
|
__be16 payload_protocol;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
if (!pskb_inet_may_pull(skb))
|
if (!pskb_inet_may_pull(skb))
|
||||||
|
@ -924,7 +925,8 @@ static netdev_tx_t ip6gre_tunnel_xmit(struct sk_buff *skb,
|
||||||
if (!ip6_tnl_xmit_ctl(t, &t->parms.laddr, &t->parms.raddr))
|
if (!ip6_tnl_xmit_ctl(t, &t->parms.laddr, &t->parms.raddr))
|
||||||
goto tx_err;
|
goto tx_err;
|
||||||
|
|
||||||
switch (skb->protocol) {
|
payload_protocol = skb_protocol(skb, true);
|
||||||
|
switch (payload_protocol) {
|
||||||
case htons(ETH_P_IP):
|
case htons(ETH_P_IP):
|
||||||
ret = ip6gre_xmit_ipv4(skb, dev);
|
ret = ip6gre_xmit_ipv4(skb, dev);
|
||||||
break;
|
break;
|
||||||
|
|
Загрузка…
Ссылка в новой задаче