]> git.proxmox.com Git - mirror_ubuntu-kernels.git/commitdiff
net/mlx5e: Support adding ingress tc rule when egress device flag is set
authorHadar Hen Zion <hadarh@mellanox.com>
Thu, 1 Dec 2016 12:06:40 +0000 (14:06 +0200)
committerDavid S. Miller <davem@davemloft.net>
Fri, 2 Dec 2016 18:28:38 +0000 (13:28 -0500)
When ndo_setup_tc is called with an egress_dev flag set, it means that
the ndo call was executed on the mirred action (egress) device and not
on the ingress device.

In order to support this kind of ndo_setup_tc call, and insert the
correct decap rule to the hardware, the uplink device on the same eswitch
should be found.

Currently, we use this resolution between the mirred device and the
uplink on the same eswitch to offload vxlan shared device decap rules.

Signed-off-by: Hadar Hen Zion <hadarh@mellanox.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ethernet/mellanox/mlx5/core/en_rep.c

index 08686771f31c4971a8d9b6f8b60e9713003fcf7a..850378893b259c860e15f1a324fe88037b0335ad 100644 (file)
@@ -289,6 +289,14 @@ static int mlx5e_rep_ndo_setup_tc(struct net_device *dev, u32 handle,
        if (TC_H_MAJ(handle) != TC_H_MAJ(TC_H_INGRESS))
                return -EOPNOTSUPP;
 
+       if (tc->egress_dev) {
+               struct mlx5_eswitch *esw = priv->mdev->priv.eswitch;
+               struct net_device *uplink_dev = mlx5_eswitch_get_uplink_netdev(esw);
+
+               return uplink_dev->netdev_ops->ndo_setup_tc(uplink_dev, handle,
+                                                           proto, tc);
+       }
+
        switch (tc->type) {
        case TC_SETUP_CLSFLOWER:
                switch (tc->cls_flower->command) {