IB/cm: Tidy remaining cm_msg free paths
[sfrench/cifs-2.6.git] / drivers / infiniband / core / cm.c
index 8dbc39ea46123c0fc915fa02c68635a3c1287647..1f0bc31ca0e298d20f9ef3ede66d95dd23f3449f 100644 (file)
@@ -367,6 +367,16 @@ out:
        return ERR_PTR(ret);
 }
 
+static void cm_free_msg(struct ib_mad_send_buf *msg)
+{
+       struct cm_id_private *cm_id_priv = msg->context[0];
+
+       if (msg->ah)
+               rdma_destroy_ah(msg->ah, 0);
+       cm_deref_id(cm_id_priv);
+       ib_free_send_mad(msg);
+}
+
 static struct ib_mad_send_buf *
 cm_alloc_priv_msg(struct cm_id_private *cm_id_priv)
 {
@@ -420,15 +430,6 @@ static int cm_create_response_msg_ah(struct cm_port *port,
        return 0;
 }
 
-static void cm_free_msg(struct ib_mad_send_buf *msg)
-{
-       if (msg->ah)
-               rdma_destroy_ah(msg->ah, 0);
-       if (msg->context[0])
-               cm_deref_id(msg->context[0]);
-       ib_free_send_mad(msg);
-}
-
 static int cm_alloc_response_msg(struct cm_port *port,
                                 struct ib_mad_recv_wc *mad_recv_wc,
                                 struct ib_mad_send_buf **msg)
@@ -3455,7 +3456,6 @@ static int cm_apr_handler(struct cm_work *work)
        }
        cm_id_priv->id.lap_state = IB_CM_LAP_IDLE;
        ib_cancel_mad(cm_id_priv->av.port->mad_agent, cm_id_priv->msg);
-       cm_id_priv->msg = NULL;
        cm_queue_work_unlock(cm_id_priv, work);
        return 0;
 out: