Commit 777a8b32 authored by Parav Pandit's avatar Parav Pandit Committed by Doug Ledford

IB/core: Use rdma_read_gid_l2_fields to compare GID L2 fields

Current code tries to derive VLAN ID and compares it with GID
attribute for matching entry. This raw search fails on macvlan
netdevice as its not a VLAN device, but its an upper device of a VLAN
netdevice.

Due to this limitation, incoming QP1 packets fail to match in the
GID table. Such packets are dropped.

Hence, to support it, use the existing rdma_read_gid_l2_fields()
that takes care of diffferent device types.

Fixes: dbf727de ("IB/core: Use GID table in AH creation and dmac resolution")
Signed-off-by: default avatarParav Pandit <parav@mellanox.com>
Signed-off-by: default avatarLeon Romanovsky <leonro@mellanox.com>
Link: https://lore.kernel.org/r/20191002121750.17313-1-leon@kernel.orgSigned-off-by: default avatarDoug Ledford <dledford@redhat.com>
parent b806c94e
...@@ -662,16 +662,17 @@ static bool find_gid_index(const union ib_gid *gid, ...@@ -662,16 +662,17 @@ static bool find_gid_index(const union ib_gid *gid,
void *context) void *context)
{ {
struct find_gid_index_context *ctx = context; struct find_gid_index_context *ctx = context;
u16 vlan_id = 0xffff;
int ret;
if (ctx->gid_type != gid_attr->gid_type) if (ctx->gid_type != gid_attr->gid_type)
return false; return false;
if ((!!(ctx->vlan_id != 0xffff) == !is_vlan_dev(gid_attr->ndev)) || ret = rdma_read_gid_l2_fields(gid_attr, &vlan_id, NULL);
(is_vlan_dev(gid_attr->ndev) && if (ret)
vlan_dev_vlan_id(gid_attr->ndev) != ctx->vlan_id))
return false; return false;
return true; return ctx->vlan_id == vlan_id;
} }
static const struct ib_gid_attr * static const struct ib_gid_attr *
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment