X-Git-Url: http://git.droids-corp.org/?a=blobdiff_plain;ds=sidebyside;f=drivers%2Fnet%2Fice%2Fice_generic_flow.c;h=1c0adc779167d6e8cfffd0552f3ba35f567a8518;hb=9c9f24e915add431611b0587c1d2b1d154821fe9;hp=5725bff50eef52d0804eba7b81ad30aaa777b5a7;hpb=72d138ff0f58d2cf2c3ef58b0f5c32e186b82a15;p=dpdk.git diff --git a/drivers/net/ice/ice_generic_flow.c b/drivers/net/ice/ice_generic_flow.c index 5725bff50e..1c0adc7791 100644 --- a/drivers/net/ice/ice_generic_flow.c +++ b/drivers/net/ice/ice_generic_flow.c @@ -13,6 +13,7 @@ #include #include #include +#include #include "ice_ethdev.h" #include "ice_generic_flow.h" @@ -463,6 +464,10 @@ static uint64_t ice_get_flow_field(const struct rte_flow_item pattern[], "Invalid VXLAN item"); return 0; } + if (vxlan_mask && vxlan_mask->vni[0] == UINT8_MAX && + vxlan_mask->vni[1] == UINT8_MAX && + vxlan_mask->vni[2] == UINT8_MAX) + input_set |= ICE_INSET_TUN_ID; is_tunnel = 1; break; @@ -481,6 +486,10 @@ static uint64_t ice_get_flow_field(const struct rte_flow_item pattern[], "Invalid NVGRE item"); return 0; } + if (nvgre_mask && nvgre_mask->tni[0] == UINT8_MAX && + nvgre_mask->tni[1] == UINT8_MAX && + nvgre_mask->tni[2] == UINT8_MAX) + input_set |= ICE_INSET_TUN_ID; is_tunnel = 1; break; @@ -664,9 +673,10 @@ ice_flow_flush(struct rte_eth_dev *dev, { struct ice_pf *pf = ICE_DEV_PRIVATE_TO_PF(dev->data->dev_private); struct rte_flow *p_flow; + void *temp; int ret = 0; - TAILQ_FOREACH(p_flow, &pf->flow_list, node) { + TAILQ_FOREACH_SAFE(p_flow, &pf->flow_list, node, temp) { ret = ice_flow_destroy(dev, p_flow, error); if (ret) { rte_flow_error_set(error, -ret,