I think this change already went in dpdk-next-net: commit 61e99d7e944885e8d625ded41b5877653e0b637e Author: Yunjian Wang <wangyunj...@huawei.com> Date: Tue Aug 7 16:10:46 2018 +0800
net/bonding: add support to match on 0x88A8 ethertype We assume VLAN ethtertype is 0x8100 in get_vlan_offset() function, but it could be 0x88A8 if QinQ is supported. Fixes: 06fe78b98ccd ("bond: add mode 6") Cc: sta...@dpdk.org Signed-off-by: Yunjian Wang <wangyunj...@huawei.com> Acked-by: Chas Williams <ch...@att.com> On Fri, Sep 14, 2018 at 9:52 PM Lilijun <jerry.lili...@huawei.com> wrote: > > For QinQ packet with ether type 0x88a8, dpdk bond's xmit hash policy is > not worked to get the ip or port field. > > Signed-off-by: Lilijun <jerry.lili...@huawei.com> > --- > drivers/net/bonding/rte_eth_bond_pmd.c | 3 ++- > 1 file changed, 2 insertions(+), 1 deletion(-) > > diff --git a/drivers/net/bonding/rte_eth_bond_pmd.c > b/drivers/net/bonding/rte_eth_bond_pmd.c > index 58f7377..4417422 100644 > --- a/drivers/net/bonding/rte_eth_bond_pmd.c > +++ b/drivers/net/bonding/rte_eth_bond_pmd.c > @@ -37,7 +37,8 @@ > { > size_t vlan_offset = 0; > > - if (rte_cpu_to_be_16(ETHER_TYPE_VLAN) == *proto) { > + if (rte_cpu_to_be_16(ETHER_TYPE_VLAN) == *proto || > + rte_cpu_to_be_16(ETHER_TYPE_QINQ) == *proto) { > struct vlan_hdr *vlan_hdr = (struct vlan_hdr *)(eth_hdr + 1); > > vlan_offset = sizeof(struct vlan_hdr); > -- > 1.8.4.msysgit.0 > >