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:
parent
16508bfd08
commit
d564eea7ce
@ -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";
|
||||
|
Loading…
Reference in New Issue
Block a user