From: Saeed Mahameed Date: Sat, 9 May 2020 07:06:35 +0000 (-0700) Subject: Merge branch 'mlx5-next' of git://git.kernel.org/pub/scm/linux/kernel/git/mellanox... X-Git-Tag: v5.15~3723^2~237^2~13 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=76cd622fe2c2b10c1f0a7311ca797feccacc329d;p=platform%2Fkernel%2Flinux-starfive.git Merge branch 'mlx5-next' of git://git./linux/kernel/git/mellanox/linux This merge includes updates to bonding driver needed for the rdma stack, to avoid conflicts with the RDMA branch. Maor Gottlieb Says: ==================== Bonding: Add support to get xmit slave The following series adds support to get the LAG master xmit slave by introducing new .ndo - ndo_get_xmit_slave. Every LAG module can implement it and it first implemented in the bond driver. This is follow-up to the RFC discussion [1]. The main motivation for doing this is for drivers that offload part of the LAG functionality. For example, Mellanox Connect-X hardware implements RoCE LAG which selects the TX affinity when the resources are created and port is remapped when it goes down. The first part of this patchset introduces the new .ndo and add the support to the bonding module. The second part adds support to get the RoCE LAG xmit slave by building skb of the RoCE packet based on the AH attributes and call to the new .ndo. The third part change the mlx5 driver driver to set the QP's affinity port according to the slave which found by the .ndo. ==================== Signed-off-by: Saeed Mahameed --- 76cd622fe2c2b10c1f0a7311ca797feccacc329d diff --cc drivers/net/bonding/bond_alb.c index 3a598d04b156,e863c694c309..095ea51d1853 --- a/drivers/net/bonding/bond_alb.c +++ b/drivers/net/bonding/bond_alb.c @@@ -1328,14 -1329,16 +1328,14 @@@ static netdev_tx_t bond_do_alb_xmit(str } /* no suitable interface, frame not sent */ - bond_tx_drop(bond->dev, skb); -out: - return NETDEV_TX_OK; + return bond_tx_drop(bond->dev, skb); } - netdev_tx_t bond_tlb_xmit(struct sk_buff *skb, struct net_device *bond_dev) + struct slave *bond_xmit_tlb_slave_get(struct bonding *bond, + struct sk_buff *skb) { - struct bonding *bond = netdev_priv(bond_dev); - struct ethhdr *eth_data; struct slave *tx_slave = NULL; + struct ethhdr *eth_data; u32 hash_index; skb_reset_mac_header(skb); diff --cc drivers/net/bonding/bond_main.c index 4f9e7c421f57,39b1ad7edbb4..a25c65d4af71 --- a/drivers/net/bonding/bond_main.c +++ b/drivers/net/bonding/bond_main.c @@@ -3952,10 -3951,10 +3951,10 @@@ static struct slave *bond_get_slave_by_ if (--i < 0) break; if (bond_slave_can_tx(slave)) - return bond_dev_queue_xmit(bond, skb, slave->dev); + return slave; } - + /* no slave that can tx has been found */ - return bond_tx_drop(bond->dev, skb); + return NULL; } /** @@@ -4024,12 -4022,32 +4022,31 @@@ static struct slave *bond_xmit_roundrob non_igmp: slave_cnt = READ_ONCE(bond->slave_cnt); if (likely(slave_cnt)) { - slave_id = bond_rr_gen_slave_id(bond); - return bond_xmit_slave_id(bond, skb, slave_id % slave_cnt); + slave_id = bond_rr_gen_slave_id(bond) % slave_cnt; + return bond_get_slave_by_id(bond, slave_id); } + return NULL; + } + + static netdev_tx_t bond_xmit_roundrobin(struct sk_buff *skb, + struct net_device *bond_dev) + { + struct bonding *bond = netdev_priv(bond_dev); + struct slave *slave; + + slave = bond_xmit_roundrobin_slave_get(bond, skb); - if (slave) - bond_dev_queue_xmit(bond, skb, slave->dev); - else - bond_tx_drop(bond_dev, skb); - return NETDEV_TX_OK; ++ if (likely(slave)) ++ return bond_dev_queue_xmit(bond, skb, slave->dev); ++ + return bond_tx_drop(bond_dev, skb); } + static struct slave *bond_xmit_activebackup_slave_get(struct bonding *bond, + struct sk_buff *skb) + { + return rcu_dereference(bond->curr_active_slave); + } + /* In active-backup mode, we know that bond->curr_active_slave is always valid if * the bond has a usable interface. */ @@@ -4039,11 -4057,13 +4056,11 @@@ static netdev_tx_t bond_xmit_activeback struct bonding *bond = netdev_priv(bond_dev); struct slave *slave; - slave = rcu_dereference(bond->curr_active_slave); + slave = bond_xmit_activebackup_slave_get(bond, skb); if (slave) - bond_dev_queue_xmit(bond, skb, slave->dev); - else - bond_tx_drop(bond_dev, skb); + return bond_dev_queue_xmit(bond, skb, slave->dev); - return NETDEV_TX_OK; + return bond_tx_drop(bond_dev, skb); } /* Use this to update slave_array when (a) it's not appropriate to update @@@ -4178,17 -4254,17 +4251,15 @@@ static netdev_tx_t bond_3ad_xor_xmit(st struct net_device *dev) { struct bonding *bond = netdev_priv(dev); - struct slave *slave; struct bond_up_slave *slaves; - unsigned int count; + struct slave *slave; - slaves = rcu_dereference(bond->slave_arr); - count = slaves ? READ_ONCE(slaves->count) : 0; - if (likely(count)) { - slave = slaves->arr[bond_xmit_hash(bond, skb) % count]; + slaves = rcu_dereference(bond->usable_slaves); + slave = bond_xmit_3ad_xor_slave_get(bond, skb, slaves); + if (likely(slave)) - bond_dev_queue_xmit(bond, skb, slave->dev); - else - bond_tx_drop(dev, skb); + return bond_dev_queue_xmit(bond, skb, slave->dev); - } + - return NETDEV_TX_OK; + return bond_tx_drop(dev, skb); } /* in broadcast mode, we send everything to all usable interfaces. */