Commit ca21cb7f authored by Jason Gunthorpe's avatar Jason Gunthorpe

RDMA/cm: Fix checking for allowed duplicate listens

The test here typod the cm_id_priv to use, it used the one that was
freshly allocated. By definition the allocated one has the matching
cm_handler and zero context, so the condition was always true.

Instead check that the existing listening ID is compatible with the
proposed handler so that it can be shared, as was originally intended.

Fixes: 067b171b ("IB/cm: Share listening CM IDs")
Link: https://lore.kernel.org/r/20200310092545.251365-3-leon@kernel.orgSigned-off-by: default avatarLeon Romanovsky <leonro@mellanox.com>
Signed-off-by: default avatarJason Gunthorpe <jgg@mellanox.com>
parent e8dc4e88
...@@ -1181,7 +1181,8 @@ struct ib_cm_id *ib_cm_insert_listen(struct ib_device *device, ...@@ -1181,7 +1181,8 @@ struct ib_cm_id *ib_cm_insert_listen(struct ib_device *device,
/* Find an existing ID */ /* Find an existing ID */
cm_id_priv = cm_find_listen(device, service_id); cm_id_priv = cm_find_listen(device, service_id);
if (cm_id_priv) { if (cm_id_priv) {
if (cm_id->cm_handler != cm_handler || cm_id->context) { if (cm_id_priv->id.cm_handler != cm_handler ||
cm_id_priv->id.context) {
/* Sharing an ib_cm_id with different handlers is not /* Sharing an ib_cm_id with different handlers is not
* supported */ * supported */
spin_unlock_irqrestore(&cm.lock, flags); spin_unlock_irqrestore(&cm.lock, flags);
......
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