net/mlx5e: IPoIB, Drop multicast packets that this interface sent
[ Upstream commit 8b46d424a743ddfef8056d5167f13ee7ebd1dcad ] After enabled loopback packets for IPoIB, we need to drop these packets that this HCA has replicated and came back to the same interface that sent them. Fixes: 4c6c615e3f30 ("net/mlx5e: IPoIB, Add PKEY child interface nic profile") Signed-off-by: Erez Shitrit <erezsh@mellanox.com> Reviewed-by: Alex Vesker <valex@mellanox.com> Signed-off-by: Saeed Mahameed <saeedm@mellanox.com> Signed-off-by: Sasha Levin <sashal@kernel.org>
This commit is contained in:
parent
fa408bbe10
commit
916f41e406
@ -1428,6 +1428,7 @@ out:
|
||||
|
||||
#ifdef CONFIG_MLX5_CORE_IPOIB
|
||||
|
||||
#define MLX5_IB_GRH_SGID_OFFSET 8
|
||||
#define MLX5_IB_GRH_DGID_OFFSET 24
|
||||
#define MLX5_GID_SIZE 16
|
||||
|
||||
@ -1441,6 +1442,7 @@ static inline void mlx5i_complete_rx_cqe(struct mlx5e_rq *rq,
|
||||
struct net_device *netdev;
|
||||
struct mlx5e_priv *priv;
|
||||
char *pseudo_header;
|
||||
u32 flags_rqpn;
|
||||
u32 qpn;
|
||||
u8 *dgid;
|
||||
u8 g;
|
||||
@ -1462,7 +1464,8 @@ static inline void mlx5i_complete_rx_cqe(struct mlx5e_rq *rq,
|
||||
tstamp = &priv->tstamp;
|
||||
stats = &priv->channel_stats[rq->ix].rq;
|
||||
|
||||
g = (be32_to_cpu(cqe->flags_rqpn) >> 28) & 3;
|
||||
flags_rqpn = be32_to_cpu(cqe->flags_rqpn);
|
||||
g = (flags_rqpn >> 28) & 3;
|
||||
dgid = skb->data + MLX5_IB_GRH_DGID_OFFSET;
|
||||
if ((!g) || dgid[0] != 0xff)
|
||||
skb->pkt_type = PACKET_HOST;
|
||||
@ -1471,9 +1474,15 @@ static inline void mlx5i_complete_rx_cqe(struct mlx5e_rq *rq,
|
||||
else
|
||||
skb->pkt_type = PACKET_MULTICAST;
|
||||
|
||||
/* TODO: IB/ipoib: Allow mcast packets from other VFs
|
||||
* 68996a6e760e5c74654723eeb57bf65628ae87f4
|
||||
/* Drop packets that this interface sent, ie multicast packets
|
||||
* that the HCA has replicated.
|
||||
*/
|
||||
if (g && (qpn == (flags_rqpn & 0xffffff)) &&
|
||||
(memcmp(netdev->dev_addr + 4, skb->data + MLX5_IB_GRH_SGID_OFFSET,
|
||||
MLX5_GID_SIZE) == 0)) {
|
||||
skb->dev = NULL;
|
||||
return;
|
||||
}
|
||||
|
||||
skb_pull(skb, MLX5_IB_GRH_BYTES);
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user