net/ice: fix VXLAN flow director creation
In original implementation, error returned when creating VXLAN flow
director with SCTP or TCP as layer 4 protocol of inner segment.
There are several root causes for the error:
1. ice_fdir_input_set_hdrs() set ICE_FLOW_SEG_HDR_UDP into protocol
header flag of inner segment of VXLAN FDIR rule, even if it shall be
ICE_FLOW_SEG_HDR_TCP or ICE_FLOW_SEG_HDR_SCTP
2. ice_fdir_input_set_hdrs() set ICE_FLOW_SEG_HDR_VXLAN into protocol
header flag of segments of VXLAN FDIR rule, it not necessary, and can
be set automatically by ice_flow_set_fld() later
3. flow type: ICE_FLTR_PTYPE_NONF_IPV4_UDP_VXLAN hides the flow type of
inner segment of VXLAN FDIR rule, then further causes function:
ice_fdir_get_gen_prgm_pkt() cannot write correct protocol id into inner
segment of training packet.
This patch fixes those defects described above.
Fixes: 855d23a07b
("net/ice: support VXLAN VNI field in flow director")
Cc: stable@dpdk.org
Signed-off-by: Dapeng Yu <dapengx.yu@intel.com>
Acked-by: Qi Zhang <qi.z.zhang@intel.com>
This commit is contained in:
parent
a7e1e2f764
commit
a87688852d
@ -806,6 +806,28 @@ ice_fdir_cross_prof_conflict(struct ice_pf *pf,
|
||||
(pf, cflct_ptype, is_tunnel))
|
||||
goto err;
|
||||
break;
|
||||
case ICE_FLTR_PTYPE_NONF_IPV4_UDP_VXLAN_IPV4_UDP:
|
||||
case ICE_FLTR_PTYPE_NONF_IPV4_UDP_VXLAN_IPV4_TCP:
|
||||
case ICE_FLTR_PTYPE_NONF_IPV4_UDP_VXLAN_IPV4_SCTP:
|
||||
cflct_ptype = ICE_FLTR_PTYPE_NONF_IPV4_UDP_VXLAN_IPV4_OTHER;
|
||||
if (!ice_fdir_prof_resolve_conflict
|
||||
(pf, cflct_ptype, is_tunnel))
|
||||
goto err;
|
||||
break;
|
||||
case ICE_FLTR_PTYPE_NONF_IPV4_UDP_VXLAN_IPV4_OTHER:
|
||||
cflct_ptype = ICE_FLTR_PTYPE_NONF_IPV4_UDP_VXLAN_IPV4_UDP;
|
||||
if (!ice_fdir_prof_resolve_conflict
|
||||
(pf, cflct_ptype, is_tunnel))
|
||||
goto err;
|
||||
cflct_ptype = ICE_FLTR_PTYPE_NONF_IPV4_UDP_VXLAN_IPV4_TCP;
|
||||
if (!ice_fdir_prof_resolve_conflict
|
||||
(pf, cflct_ptype, is_tunnel))
|
||||
goto err;
|
||||
cflct_ptype = ICE_FLTR_PTYPE_NONF_IPV4_UDP_VXLAN_IPV4_SCTP;
|
||||
if (!ice_fdir_prof_resolve_conflict
|
||||
(pf, cflct_ptype, is_tunnel))
|
||||
goto err;
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
@ -988,11 +1010,12 @@ ice_fdir_input_set_hdrs(enum ice_fltr_ptype flow, struct ice_flow_seg_info *seg)
|
||||
ICE_FLOW_SET_HDRS(seg, ICE_FLOW_SEG_HDR_IPV6 |
|
||||
ICE_FLOW_SEG_HDR_IPV_FRAG);
|
||||
break;
|
||||
case ICE_FLTR_PTYPE_NONF_IPV4_UDP_VXLAN:
|
||||
ICE_FLOW_SET_HDRS(seg, ICE_FLOW_SEG_HDR_UDP |
|
||||
ICE_FLOW_SEG_HDR_IPV4 |
|
||||
ICE_FLOW_SEG_HDR_VXLAN |
|
||||
ICE_FLOW_SEG_HDR_IPV_OTHER);
|
||||
case ICE_FLTR_PTYPE_NONF_IPV4_UDP_VXLAN_IPV4_UDP:
|
||||
case ICE_FLTR_PTYPE_NONF_IPV4_UDP_VXLAN_IPV4_TCP:
|
||||
case ICE_FLTR_PTYPE_NONF_IPV4_UDP_VXLAN_IPV4_SCTP:
|
||||
break;
|
||||
case ICE_FLTR_PTYPE_NONF_IPV4_UDP_VXLAN_IPV4_OTHER:
|
||||
ICE_FLOW_SET_HDRS(seg, ICE_FLOW_SEG_HDR_IPV_OTHER);
|
||||
break;
|
||||
case ICE_FLTR_PTYPE_NONF_IPV4_GTPU:
|
||||
ICE_FLOW_SET_HDRS(seg, ICE_FLOW_SEG_HDR_GTPU_IP |
|
||||
@ -2136,8 +2159,18 @@ ice_fdir_parse_pattern(__rte_unused struct ice_adapter *ad,
|
||||
else if (tunnel_type == ICE_FDIR_TUNNEL_TYPE_GTPU_EH &&
|
||||
flow_type == ICE_FLTR_PTYPE_NONF_IPV6_UDP)
|
||||
flow_type = ICE_FLTR_PTYPE_NONF_IPV6_GTPU_EH;
|
||||
else if (tunnel_type == ICE_FDIR_TUNNEL_TYPE_VXLAN)
|
||||
flow_type = ICE_FLTR_PTYPE_NONF_IPV4_UDP_VXLAN;
|
||||
else if (tunnel_type == ICE_FDIR_TUNNEL_TYPE_VXLAN &&
|
||||
flow_type == ICE_FLTR_PTYPE_NONF_IPV4_UDP)
|
||||
flow_type = ICE_FLTR_PTYPE_NONF_IPV4_UDP_VXLAN_IPV4_UDP;
|
||||
else if (tunnel_type == ICE_FDIR_TUNNEL_TYPE_VXLAN &&
|
||||
flow_type == ICE_FLTR_PTYPE_NONF_IPV4_TCP)
|
||||
flow_type = ICE_FLTR_PTYPE_NONF_IPV4_UDP_VXLAN_IPV4_TCP;
|
||||
else if (tunnel_type == ICE_FDIR_TUNNEL_TYPE_VXLAN &&
|
||||
flow_type == ICE_FLTR_PTYPE_NONF_IPV4_SCTP)
|
||||
flow_type = ICE_FLTR_PTYPE_NONF_IPV4_UDP_VXLAN_IPV4_SCTP;
|
||||
else if (tunnel_type == ICE_FDIR_TUNNEL_TYPE_VXLAN &&
|
||||
flow_type == ICE_FLTR_PTYPE_NONF_IPV4_OTHER)
|
||||
flow_type = ICE_FLTR_PTYPE_NONF_IPV4_UDP_VXLAN_IPV4_OTHER;
|
||||
|
||||
filter->tunnel_type = tunnel_type;
|
||||
filter->input.flow_type = flow_type;
|
||||
|
Loading…
Reference in New Issue
Block a user