qed: Use after free in qed_rdma_free()
authorDan Carpenter <dan.carpenter@oracle.com>
Tue, 13 Mar 2018 09:09:38 +0000 (12:09 +0300)
committerDavid S. Miller <davem@davemloft.net>
Tue, 13 Mar 2018 14:54:17 +0000 (10:54 -0400)
We're dereferencing "p_hwfn->p_rdma_info" but that is freed on the line
before in qed_rdma_resc_free(p_hwfn).

Fixes: 9de506a547c0 ("qed: Free RoCE ILT Memory on rmmod qedr")
Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com>
Acked-by: Michal Kalderon <Michal.Kalderon@cavium.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/ethernet/qlogic/qed/qed_rdma.c

index f3ee6538b553fa51aef40c8bbcab67f63c8c0560..a411f9c702a16ae6963aa5c7eda112cc5a72404d 100644 (file)
@@ -379,8 +379,8 @@ static void qed_rdma_free(struct qed_hwfn *p_hwfn)
        DP_VERBOSE(p_hwfn, QED_MSG_RDMA, "Freeing RDMA\n");
 
        qed_rdma_free_reserved_lkey(p_hwfn);
-       qed_rdma_resc_free(p_hwfn);
        qed_cxt_free_proto_ilt(p_hwfn, p_hwfn->p_rdma_info->proto);
+       qed_rdma_resc_free(p_hwfn);
 }
 
 static void qed_rdma_get_guid(struct qed_hwfn *p_hwfn, u8 *guid)