iw_cxgb4: Fix potential NULL dereference in c4iw_fill_res_cm_id_entry()
authorDan Carpenter <error27@gmail.com>
Tue, 14 Feb 2023 15:43:38 +0000 (18:43 +0300)
committerLeon Romanovsky <leon@kernel.org>
Wed, 15 Feb 2023 11:37:37 +0000 (13:37 +0200)
This condition needs to match the previous "if (epcp->state == LISTEN) {"
exactly to avoid a NULL dereference of either "listen_ep" or "ep". The
problem is that "epcp" has been re-assigned so just testing
"if (epcp->state == LISTEN) {" a second time is not sufficient.

Fixes: 116aeb887371 ("iw_cxgb4: provide detailed provider-specific CM_ID information")
Signed-off-by: Dan Carpenter <error27@gmail.com>
Link: https://lore.kernel.org/r/Y+usKuWIKr4dimZh@kili
Signed-off-by: Leon Romanovsky <leon@kernel.org>
drivers/infiniband/hw/cxgb4/restrack.c

index ff645b9..fd22c85 100644 (file)
@@ -238,7 +238,7 @@ int c4iw_fill_res_cm_id_entry(struct sk_buff *msg,
        if (rdma_nl_put_driver_u64_hex(msg, "history", epcp->history))
                goto err_cancel_table;
 
-       if (epcp->state == LISTEN) {
+       if (listen_ep) {
                if (rdma_nl_put_driver_u32(msg, "stid", listen_ep->stid))
                        goto err_cancel_table;
                if (rdma_nl_put_driver_u32(msg, "backlog", listen_ep->backlog))