Save owning PID to id-priv when creating id's/accepting connections.

Signed-off-by: Nir Muchtar <[email protected]>
---
 drivers/infiniband/core/cma.c |    9 +++++++++
 1 files changed, 9 insertions(+), 0 deletions(-)

diff --git a/drivers/infiniband/core/cma.c b/drivers/infiniband/core/cma.c
index 6436995..03f9649 100644
--- a/drivers/infiniband/core/cma.c
+++ b/drivers/infiniband/core/cma.c
@@ -135,6 +135,7 @@ struct rdma_id_private {
        u32                     qp_num;
        u8                      srq;
        u8                      tos;
+       pid_t                   owner;
 };
 
 struct cma_multicast {
@@ -419,6 +420,7 @@ struct rdma_cm_id *rdma_create_id(rdma_cm_event_handler 
event_handler,
        if (!id_priv)
                return ERR_PTR(-ENOMEM);
 
+       id_priv->owner = current->pid;
        id_priv->state = RDMA_CM_IDLE;
        id_priv->id.context = context;
        id_priv->id.event_handler = event_handler;
@@ -2672,8 +2674,14 @@ int rdma_accept(struct rdma_cm_id *id, struct 
rdma_conn_param *conn_param)
 {
        struct rdma_id_private *id_priv;
        int ret;
+       unsigned long flags;
 
        id_priv = container_of(id, struct rdma_id_private, id);
+
+       spin_lock_irqsave(&id_priv->lock, flags);
+       id_priv->owner = current->pid;
+       spin_unlock_irqrestore(&id_priv->lock, flags);
+
        if (!cma_comp(id_priv, RDMA_CM_CONNECT))
                return -EINVAL;
 
@@ -3313,6 +3321,7 @@ static int cma_get_id_stats(struct sk_buff *skb, struct 
netlink_callback *cb)
                        id_stats->port_space = id->ps;
                        id_stats->cm_state = id_priv->state;
                        id_stats->qp_num = id_priv->qp_num;
+                       id_stats->pid = id_priv->owner;
 
                        i_id++;
                }
-- 
1.7.1

--
To unsubscribe from this list: send the line "unsubscribe linux-rdma" in
the body of a message to [email protected]
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to