net/smc: remove freed buffer from list
authorKarsten Graul <kgraul@linux.ibm.com>
Sat, 18 Jul 2020 13:06:17 +0000 (15:06 +0200)
committerDavid S. Miller <davem@davemloft.net>
Sun, 19 Jul 2020 22:30:23 +0000 (15:30 -0700)
Two buffers are allocated for each SMC connection. Each buffer is
added to a buffer list after creation. When the second buffer
allocation fails, the first buffer is freed but not deleted from
the list. This might result in crashes when another connection picks
up the freed buffer later and starts to work with it.

Reviewed-by: Ursula Braun <ubraun@linux.ibm.com>
Fixes: 6511aad3f039 ("net/smc: change smc_buf_free function parameters")
Signed-off-by: Karsten Graul <kgraul@linux.ibm.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/smc/smc_core.c

index 42ba227f3e97b956c2f1853e23cdce5b0ce01a6d..ca3dc6af73af0a17a602e7391877314b7c6d2ef6 100644 (file)
@@ -1772,8 +1772,12 @@ int smc_buf_create(struct smc_sock *smc, bool is_smcd)
                return rc;
        /* create rmb */
        rc = __smc_buf_create(smc, is_smcd, true);
-       if (rc)
+       if (rc) {
+               mutex_lock(&smc->conn.lgr->sndbufs_lock);
+               list_del(&smc->conn.sndbuf_desc->list);
+               mutex_unlock(&smc->conn.lgr->sndbufs_lock);
                smc_buf_free(smc->conn.lgr, false, smc->conn.sndbuf_desc);
+       }
        return rc;
 }