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