summaryrefslogtreecommitdiff
path: root/drivers/infiniband/core/device.c
diff options
context:
space:
mode:
authorParav Pandit <parav@mellanox.com>2018-08-28 15:08:41 +0300
committerJason Gunthorpe <jgg@mellanox.com>2018-09-06 13:45:38 -0600
commit93688ddbe1da1ead030b210dadc5a8cfbff95849 (patch)
tree1b71a0e7e6df09572d2758f55c5633353b16bca1 /drivers/infiniband/core/device.c
parent722c7b2bfeadbae8d9aaa08552c456e09d17a7f7 (diff)
downloadlwn-93688ddbe1da1ead030b210dadc5a8cfbff95849.tar.gz
lwn-93688ddbe1da1ead030b210dadc5a8cfbff95849.zip
RDMA/core: No need to protect kfree with spin lock and semaphore
While unregistering a client, only context removal should be protected with lock. There is no need to protect a freeing of such context which is already removed from the list. Signed-off-by: Parav Pandit <parav@mellanox.com> Reviewed-by: Daniel Jurgens <danielj@mellanox.com> Signed-off-by: Leon Romanovsky <leonro@mellanox.com> Signed-off-by: Jason Gunthorpe <jgg@mellanox.com>
Diffstat (limited to 'drivers/infiniband/core/device.c')
-rw-r--r--drivers/infiniband/core/device.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/drivers/infiniband/core/device.c b/drivers/infiniband/core/device.c
index 6d8ac51a39cc..9bc5ba2f488e 100644
--- a/drivers/infiniband/core/device.c
+++ b/drivers/infiniband/core/device.c
@@ -700,9 +700,9 @@ void ib_unregister_client(struct ib_client *client)
down_write(&lists_rwsem);
spin_lock_irqsave(&device->client_data_lock, flags);
list_del(&found_context->list);
- kfree(found_context);
spin_unlock_irqrestore(&device->client_data_lock, flags);
up_write(&lists_rwsem);
+ kfree(found_context);
}
mutex_unlock(&device_mutex);