RDMA/hns: Fix memory leak in free_mr_init()
authorChengchang Tang <tangchengchang@huawei.com>
Thu, 7 Dec 2023 11:42:31 +0000 (19:42 +0800)
committerLeon Romanovsky <leon@kernel.org>
Thu, 7 Dec 2023 13:09:16 +0000 (15:09 +0200)
When a reserved QP fails to be created, the memory of the remaining
created reserved QPs is leaked.

Fixes: 70f92521584f ("RDMA/hns: Use the reserved loopback QPs to free MR before destroying MPT")
Signed-off-by: Chengchang Tang <tangchengchang@huawei.com>
Signed-off-by: Junxian Huang <huangjunxian6@hisilicon.com>
Link: https://lore.kernel.org/r/20231207114231.2872104-6-huangjunxian6@hisilicon.com
Signed-off-by: Leon Romanovsky <leon@kernel.org>
drivers/infiniband/hw/hns/hns_roce_hw_v2.c

index 93a71db527d865860215d3e9f97cbc8c3ae614bb..b8dde04bd57397ab791b19c6ee5169481c029197 100644 (file)
@@ -2710,6 +2710,10 @@ static int free_mr_alloc_res(struct hns_roce_dev *hr_dev)
        return 0;
 
 create_failed_qp:
+       for (i--; i >= 0; i--) {
+               hns_roce_v2_destroy_qp(&free_mr->rsv_qp[i]->ibqp, NULL);
+               kfree(free_mr->rsv_qp[i]);
+       }
        hns_roce_destroy_cq(cq, NULL);
        kfree(cq);