can: j1939: j1939_sk_init(): set SOCK_RCU_FREE to call sk_destruct() after RCU is...
authorOleksij Rempel <o.rempel@pengutronix.de>
Thu, 17 Jun 2021 13:06:23 +0000 (15:06 +0200)
committerMarc Kleine-Budde <mkl@pengutronix.de>
Sat, 19 Jun 2021 21:54:00 +0000 (23:54 +0200)
commit22c696fed25c63c7f67508309820358b94a96b6d
tree73f5fa7199d0721932570c9700ab952166869763
parent14a4696bc3118ba49da28f79280e1d55603aa737
can: j1939: j1939_sk_init(): set SOCK_RCU_FREE to call sk_destruct() after RCU is done

Set SOCK_RCU_FREE to let RCU to call sk_destruct() on completion.
Without this patch, we will run in to j1939_can_recv() after priv was
freed by j1939_sk_release()->j1939_sk_sock_destruct()

Fixes: 25fe97cb7620 ("can: j1939: move j1939_priv_put() into sk_destruct callback")
Link: https://lore.kernel.org/r/20210617130623.12705-1-o.rempel@pengutronix.de
Cc: linux-stable <stable@vger.kernel.org>
Reported-by: Thadeu Lima de Souza Cascardo <cascardo@canonical.com>
Reported-by: syzbot+bdf710cfc41c186fdff3@syzkaller.appspotmail.com
Signed-off-by: Oleksij Rempel <o.rempel@pengutronix.de>
Signed-off-by: Marc Kleine-Budde <mkl@pengutronix.de>
net/can/j1939/main.c
net/can/j1939/socket.c