RDMA/vmw_pvrdma: Use atomic memory allocation in create AH
authorGal Pressman <galpress@amazon.com>
Mon, 10 Dec 2018 15:17:25 +0000 (17:17 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 5 Dec 2019 14:37:14 +0000 (15:37 +0100)
[ Upstream commit a276a4d93bf1580d737f38d1810e5f4b166f3edd ]

Create address handle callback should not sleep, use GFP_ATOMIC instead of
GFP_KERNEL for memory allocation.

Fixes: 29c8d9eba550 ("IB: Add vmw_pvrdma driver")
Cc: Adit Ranadive <aditr@vmware.com>
Signed-off-by: Gal Pressman <galpress@amazon.com>
Reviewed-by: Yuval Shaia <yuval.shaia@oracle.com>
Signed-off-by: Jason Gunthorpe <jgg@mellanox.com>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/infiniband/hw/vmw_pvrdma/pvrdma_verbs.c

index aa533f08e017136341e764ea868296d875715b13..5c7aa6ff153823275678932c4e154733c8127b94 100644 (file)
@@ -550,7 +550,7 @@ struct ib_ah *pvrdma_create_ah(struct ib_pd *pd, struct rdma_ah_attr *ah_attr,
        if (!atomic_add_unless(&dev->num_ahs, 1, dev->dsr->caps.max_ah))
                return ERR_PTR(-ENOMEM);
 
-       ah = kzalloc(sizeof(*ah), GFP_KERNEL);
+       ah = kzalloc(sizeof(*ah), GFP_ATOMIC);
        if (!ah) {
                atomic_dec(&dev->num_ahs);
                return ERR_PTR(-ENOMEM);