RDMA/cma: Fix rdma_resolve_route() memory leak
authorGerd Rausch <gerd.rausch@oracle.com>
Thu, 24 Jun 2021 18:55:31 +0000 (11:55 -0700)
committerJason Gunthorpe <jgg@nvidia.com>
Fri, 25 Jun 2021 15:00:19 +0000 (12:00 -0300)
Fix a memory leak when "mda_resolve_route() is called more than once on
the same "rdma_cm_id".

This is possible if cma_query_handler() triggers the
RDMA_CM_EVENT_ROUTE_ERROR flow which puts the state machine back and
allows rdma_resolve_route() to be called again.

Link: https://lore.kernel.org/r/f6662b7b-bdb7-2706-1e12-47c61d3474b6@oracle.com
Signed-off-by: Gerd Rausch <gerd.rausch@oracle.com>
Signed-off-by: Jason Gunthorpe <jgg@nvidia.com>
drivers/infiniband/core/cma.c

index 9dfb07a16ab189e654c48f166d3b32555d79ae9e..420de383c03991f0831261c764c883047e1d3dc6 100644 (file)
@@ -2814,7 +2814,8 @@ static int cma_resolve_ib_route(struct rdma_id_private *id_priv,
 
        cma_init_resolve_route_work(work, id_priv);
 
-       route->path_rec = kmalloc(sizeof *route->path_rec, GFP_KERNEL);
+       if (!route->path_rec)
+               route->path_rec = kmalloc(sizeof *route->path_rec, GFP_KERNEL);
        if (!route->path_rec) {
                ret = -ENOMEM;
                goto err1;