IB/cm: Send no match if a SIDR REQ does not match a listen
authorSean Hefty <sean.hefty@intel.com>
Mon, 2 Jul 2007 23:14:14 +0000 (16:14 -0700)
committerRoland Dreier <rolandd@cisco.com>
Wed, 11 Jul 2007 04:52:28 +0000 (21:52 -0700)
If a SIDR REQ does not match a listen, we should reply with status
value 1 (service ID not supported), rather than dropping through to
the default case of status 2 (rejected by service provider).

Doing this also fixes a bug where the cm_id_priv is removed from the
remote_sidr_table twice.

Signed-off-by: Sean Hefty <sean.hefty@intel.com>
Signed-off-by: Roland Dreier <rolandd@cisco.com>
drivers/infiniband/core/cm.c

index 9135a8c1d4acd42b4d9c3000648730c2ebe8d985..9820c67ba47dd2566eaaac76cce25e5a0ebdc834 100644 (file)
@@ -2808,9 +2808,8 @@ static int cm_sidr_req_handler(struct cm_work *work)
                                        sidr_req_msg->service_id,
                                        sidr_req_msg->private_data);
        if (!cur_cm_id_priv) {
-               rb_erase(&cm_id_priv->sidr_id_node, &cm.remote_sidr_table);
                spin_unlock_irq(&cm.lock);
-               /* todo: reply with no match */
+               cm_reject_sidr_req(cm_id_priv, IB_SIDR_UNSUPPORTED);
                goto out; /* No match. */
        }
        atomic_inc(&cur_cm_id_priv->refcount);