> -----Original Message-----
> From: Pawel Wodkowski <[email protected]>
> Sent: Tuesday, August 11, 2020 4:31 AM
> To: [email protected]
> Cc: Pawel Wodkowski <[email protected]>; Zhang, Qi Z
> <[email protected]>; Zhao1, Wei <[email protected]>; Guo, Jia
> <[email protected]>
> Subject: [PATCH] net/ixgbe: fix fdir flows with RTE_FLOW_ITEM_TYPE_RAW
>
> Flows like IP4 / UDP / RAW are not working because after parsing
> RTE_FLOW_ITEM_TYPE_RAW item pointer is not advanced. This make whole
> parsing fail.
>
> Fixes: f35fec63dde1 ("net/ixgbe: enable flex bytes for generic flow API")
> Cc: [email protected]
> Signed-off-by: Pawel Wodkowski <[email protected]>
> ---
> drivers/net/ixgbe/ixgbe_flow.c | 2 ++
> 1 file changed, 2 insertions(+)
>
> diff --git a/drivers/net/ixgbe/ixgbe_flow.c b/drivers/net/ixgbe/ixgbe_flow.c
> index b2a2bfc02..a2cb599b1 100644
> --- a/drivers/net/ixgbe/ixgbe_flow.c
> +++ b/drivers/net/ixgbe/ixgbe_flow.c
> @@ -2251,6 +2251,8 @@ ixgbe_parse_fdir_filter_normal(struct rte_eth_dev
> *dev,
> (((uint16_t)raw_spec->pattern[1]) << 8) |
> raw_spec->pattern[0];
> rule->flex_bytes_offset = raw_spec->offset;
> +
> + item = next_no_fuzzy_pattern(pattern, item);
why we need to advance item pointer?
The next branch will advance it and compare with RTe_FLOW_ITEM_TYPE_END.
Can you double check if your pattern is IPv4/UDP/RAW/END ?
> }
>
> if (item->type != RTE_FLOW_ITEM_TYPE_END) {
> --
> 2.17.1