Revision 0ace17d56824165c7f4c68785d6b58971db954dd authored by Richard Palethorpe on 21 January 2020, 13:42:58 UTC, committed by David S. Miller on 22 January 2020, 19:32:03 UTC
write_wakeup can happen in parallel with close/hangup where tty->disc_data
is set to NULL and the netdevice is freed thus also freeing
disc_data. write_wakeup accesses disc_data so we must prevent close from
freeing the netdev while write_wakeup has a non-NULL view of
tty->disc_data.

We also need to make sure that accesses to disc_data are atomic. Which can
all be done with RCU.

This problem was found by Syzkaller on SLCAN, but the same issue is
reproducible with the SLIP line discipline using an LTP test based on the
Syzkaller reproducer.

A fix which didn't use RCU was posted by Hillf Danton.

Fixes: 661f7fda21b1 ("slip: Fix deadlock in write_wakeup")
Fixes: a8e83b17536a ("slcan: Port write_wakeup deadlock fix from slip")
Reported-by: syzbot+017e491ae13c0068598a@syzkaller.appspotmail.com
Signed-off-by: Richard Palethorpe <rpalethorpe@suse.com>
Cc: Wolfgang Grandegger <wg@grandegger.com>
Cc: Marc Kleine-Budde <mkl@pengutronix.de>
Cc: "David S. Miller" <davem@davemloft.net>
Cc: Tyler Hall <tylerwhall@gmail.com>
Cc: linux-can@vger.kernel.org
Cc: netdev@vger.kernel.org
Cc: linux-kernel@vger.kernel.org
Cc: syzkaller@googlegroups.com
Signed-off-by: David S. Miller <davem@davemloft.net>
1 parent 58c8db9
History
File Mode Size
cluster
dlm
dlmfs
Kconfig -rw-r--r-- 2.5 KB
Makefile -rw-r--r-- 1.0 KB
acl.c -rw-r--r-- 9.1 KB
acl.h -rw-r--r-- 776 bytes
alloc.c -rw-r--r-- 196.2 KB
alloc.h -rw-r--r-- 11.2 KB
aops.c -rw-r--r-- 62.2 KB
aops.h -rw-r--r-- 2.4 KB
blockcheck.c -rw-r--r-- 15.2 KB
blockcheck.h -rw-r--r-- 3.3 KB
buffer_head_io.c -rw-r--r-- 11.1 KB
buffer_head_io.h -rw-r--r-- 1.6 KB
dcache.c -rw-r--r-- 12.5 KB
dcache.h -rw-r--r-- 1.2 KB
dir.c -rw-r--r-- 113.4 KB
dir.h -rw-r--r-- 3.2 KB
dlmglue.c -rw-r--r-- 124.8 KB
dlmglue.h -rw-r--r-- 6.7 KB
export.c -rw-r--r-- 6.2 KB
export.h -rw-r--r-- 392 bytes
extent_map.c -rw-r--r-- 23.6 KB
extent_map.h -rw-r--r-- 2.3 KB
file.c -rw-r--r-- 66.5 KB
file.h -rw-r--r-- 2.3 KB
filecheck.c -rw-r--r-- 12.0 KB
filecheck.h -rw-r--r-- 1.9 KB
heartbeat.c -rw-r--r-- 2.8 KB
heartbeat.h -rw-r--r-- 828 bytes
inode.c -rw-r--r-- 45.4 KB
inode.h -rw-r--r-- 5.3 KB
ioctl.c -rw-r--r-- 22.4 KB
ioctl.h -rw-r--r-- 369 bytes
journal.c -rw-r--r-- 61.6 KB
journal.h -rw-r--r-- 21.5 KB
localalloc.c -rw-r--r-- 33.3 KB
localalloc.h -rw-r--r-- 1.5 KB
locks.c -rw-r--r-- 2.8 KB
locks.h -rw-r--r-- 471 bytes
mmap.c -rw-r--r-- 4.3 KB
mmap.h -rw-r--r-- 173 bytes
move_extents.c -rw-r--r-- 25.2 KB
move_extents.h -rw-r--r-- 363 bytes
namei.c -rw-r--r-- 69.2 KB
namei.h -rw-r--r-- 1.1 KB
ocfs1_fs_compat.h -rw-r--r-- 2.3 KB
ocfs2.h -rw-r--r-- 24.5 KB
ocfs2_fs.h -rw-r--r-- 49.6 KB
ocfs2_ioctl.h -rw-r--r-- 6.5 KB
ocfs2_lockid.h -rw-r--r-- 2.7 KB
ocfs2_lockingver.h -rw-r--r-- 562 bytes
ocfs2_trace.h -rw-r--r-- 75.8 KB
quota.h -rw-r--r-- 4.6 KB
quota_global.c -rw-r--r-- 29.8 KB
quota_local.c -rw-r--r-- 35.5 KB
refcounttree.c -rw-r--r-- 120.2 KB
refcounttree.h -rw-r--r-- 4.4 KB
reservations.c -rw-r--r-- 20.0 KB
reservations.h -rw-r--r-- 4.9 KB
resize.c -rw-r--r-- 15.5 KB
resize.h -rw-r--r-- 444 bytes
slot_map.c -rw-r--r-- 11.6 KB
slot_map.h -rw-r--r-- 769 bytes
stack_o2cb.c -rw-r--r-- 11.2 KB
stack_user.c -rw-r--r-- 28.9 KB
stackglue.c -rw-r--r-- 17.0 KB
stackglue.h -rw-r--r-- 8.8 KB
suballoc.c -rw-r--r-- 74.7 KB
suballoc.h -rw-r--r-- 6.9 KB
super.c -rw-r--r-- 68.3 KB
super.h -rw-r--r-- 911 bytes
symlink.c -rw-r--r-- 2.5 KB
symlink.h -rw-r--r-- 634 bytes
sysfile.c -rw-r--r-- 4.1 KB
sysfile.h -rw-r--r-- 416 bytes
uptodate.c -rw-r--r-- 17.0 KB
uptodate.h -rw-r--r-- 2.3 KB
xattr.c -rw-r--r-- 192.9 KB
xattr.h -rw-r--r-- 3.1 KB

back to top