net/mlx5: Introduce egress acl forward-to-vport capability
authorVu Pham <vuhuong@mellanox.com>
Tue, 3 Mar 2020 00:15:19 +0000 (16:15 -0800)
committerSaeed Mahameed <saeedm@mellanox.com>
Sat, 7 Mar 2020 21:19:25 +0000 (13:19 -0800)
commit86f5d0f3d4995b8b8909da7eea235e5bc1ceefbe
tree75013b6bed4fcf0426ae83f32380595d269e2104
parent1326034b3ce7073e3ed74bd0f4d24afee96a9e07
net/mlx5: Introduce egress acl forward-to-vport capability

Add HCA_CAP.egress_acl_forward_to_vport field to check whether HW
supports e-switch vport's egress acl to forward packets to other
e-switch vport or not.

By default E-Switch egress ACL forwards eswitch vports egress packets
to their corresponding NIC/VF vports.

With this cap enabled, the driver is allowed to alter this behavior
and forward packets to arbitrary NIC/VF vports with the following
limitations:

   a. Multiple processing paths are supported if all of the following
      conditions are met:
      - HCA_CAP.egress_acl_forward_to_vport is set ==1.
      - A destination of type Flow Table only appears once, as the
        last destination in the list.
      - Vport destination is supported if
        HCA_CAP.egress_acl_forward_to_vport==1. Vport must not be
        the Uplink.
   b. Flow_tag not supported.
   c. This table is only applicable after an FDB table is created.
   d. Push VLAN action is not supported.
   e. Pop VLAN action cannot be added concurrently to this table and
      FDB table.

This feature will be used during port failover in bonding scenario
where two VFs representors are bonded to handle failover egress traffic
(VM's ingress/receive traffic).

Signed-off-by: Vu Pham <vuhuong@mellanox.com>
Signed-off-by: Saeed Mahameed <saeedm@mellanox.com>
include/linux/mlx5/mlx5_ifc.h