]> git.ipfire.org Git - people/arne_f/kernel.git/commitdiff
chelsio/chtls: fix a double free in chtls_setkey()
authorDan Carpenter <dan.carpenter@oracle.com>
Thu, 3 Dec 2020 08:44:31 +0000 (11:44 +0300)
committerJakub Kicinski <kuba@kernel.org>
Thu, 3 Dec 2020 18:53:35 +0000 (10:53 -0800)
The "skb" is freed by the transmit code in cxgb4_ofld_send() and we
shouldn't use it again.  But in the current code, if we hit an error
later on in the function then the clean up code will call kfree_skb(skb)
and so it causes a double free.

Set the "skb" to NULL and that makes the kfree_skb() a no-op.

Fixes: d25f2f71f653 ("crypto: chtls - Program the TLS session Key")
Signed-off-by: Dan Carpenter <dan.carpenter@oracle.com>
Link: https://lore.kernel.org/r/X8ilb6PtBRLWiSHp@mwanda
Signed-off-by: Jakub Kicinski <kuba@kernel.org>
drivers/net/ethernet/chelsio/inline_crypto/chtls/chtls_hw.c

index 62c829023da564f46be598d7bc6fec13aebe3896..a4fb463af22ac335c425532787f4b8a7bb91e11d 100644 (file)
@@ -391,6 +391,7 @@ int chtls_setkey(struct chtls_sock *csk, u32 keylen,
        csk->wr_unacked += DIV_ROUND_UP(len, 16);
        enqueue_wr(csk, skb);
        cxgb4_ofld_send(csk->egress_dev, skb);
+       skb = NULL;
 
        chtls_set_scmd(csk);
        /* Clear quiesce for Rx key */