net/mlx4: fix empty Ethernet spec with VLAN

When the ETH spec is empty MLX4 PMD doesn't allow match other criteria,
which means the flow should be promisc one.

Currently, PMD validates this by setting flow->promisc bit when ETH spec
is empty and checking whether there is other rte_flow_item followed
when flow->promisc is on.

However, commit [1] adds support to match traffic only on VLAN id, the
above validation logic should be changed accordingly.

This patch changes the above validate logic by skipping flow->promisc
check if this item is VLAN.

[1]:
Fixes: c0d2392631 ("net/mlx4: support flow w/o ETH spec and with VLAN")
Cc: stable@dpdk.org

Signed-off-by: Xiaoyu Min <jackmin@nvidia.com>
Acked-by: Matan Azrad <matan@nvidia.com>
This commit is contained in:
Xiaoyu Min 2021-11-22 21:53:29 +08:00 committed by Raslan Darawsheh
parent 16508bfd08
commit d564eea7ce

View File

@ -713,7 +713,8 @@ mlx4_flow_prepare(struct mlx4_priv *priv,
flow->internal = 1;
continue;
}
if (flow->promisc || flow->allmulti) {
if ((item->type != RTE_FLOW_ITEM_TYPE_VLAN && flow->promisc) ||
flow->allmulti) {
msg = "mlx4 does not support additional matching"
" criteria combined with indiscriminate"
" matching on Ethernet headers";