possible deadlock in flush_workqueue (2)

46 views
Skip to first unread message

syzbot

unread,
Oct 20, 2018, 12:57:03 PM10/20/18
to adilger...@dilger.ca, linux...@vger.kernel.org, linux-...@vger.kernel.org, syzkall...@googlegroups.com, ty...@mit.edu
Hello,

syzbot found the following crash on:

HEAD commit: 91b15613ce7f Merge git://git.kernel.org/pub/scm/linux/kern..
git tree: upstream
console output: https://syzkaller.appspot.com/x/log.txt?x=10114109400000
kernel config: https://syzkaller.appspot.com/x/.config?x=b3f55cb3dfcc6c33
dashboard link: https://syzkaller.appspot.com/bug?extid=a50c7541a4a55cd49b02
compiler: gcc (GCC) 8.0.1 20180413 (experimental)
syz repro: https://syzkaller.appspot.com/x/repro.syz?x=159c1de9400000

IMPORTANT: if you fix the bug, please add the following tag to the commit:
Reported-by: syzbot+a50c75...@syzkaller.appspotmail.com

8021q: adding VLAN 0 to HW filter on device team0
8021q: adding VLAN 0 to HW filter on device team0
8021q: adding VLAN 0 to HW filter on device team0

======================================================
WARNING: possible circular locking dependency detected
4.19.0-rc8+ #291 Not tainted
------------------------------------------------------
syz-executor1/6832 is trying to acquire lock:
000000007d4a82f2 ((wq_completion)"dio/%s"sb->s_id){+.+.}, at:
flush_workqueue+0x2db/0x1e10 kernel/workqueue.c:2652

but task is already holding lock:
00000000e2da6d71 (&sb->s_type->i_mutex_key#10){+.+.}, at: inode_trylock
include/linux/fs.h:758 [inline]
00000000e2da6d71 (&sb->s_type->i_mutex_key#10){+.+.}, at:
ext4_file_write_iter+0x2a1/0x1420 fs/ext4/file.c:232

which lock already depends on the new lock.


the existing dependency chain (in reverse order) is:
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env

-> #2 (&sb->s_type->i_mutex_key#10){+.+.}:
down_write+0x8a/0x130 kernel/locking/rwsem.c:70
inode_lock include/linux/fs.h:738 [inline]
__generic_file_fsync+0xb5/0x200 fs/libfs.c:981
ext4_sync_file+0xa4f/0x1510 fs/ext4/fsync.c:120
vfs_fsync_range+0x140/0x220 fs/sync.c:197
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
generic_write_sync include/linux/fs.h:2732 [inline]
dio_complete+0x75c/0x9e0 fs/direct-io.c:329
dio_aio_complete_work+0x20/0x30 fs/direct-io.c:341
process_one_work+0xc90/0x1b90 kernel/workqueue.c:2153
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
worker_thread+0x17f/0x1390 kernel/workqueue.c:2296
kthread+0x35a/0x420 kernel/kthread.c:246
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
ret_from_fork+0x3a/0x50 arch/x86/entry/entry_64.S:413

-> #1 ((work_completion)(&dio->complete_work)){+.+.}:
process_one_work+0xc0a/0x1b90 kernel/workqueue.c:2129
worker_thread+0x17f/0x1390 kernel/workqueue.c:2296
kthread+0x35a/0x420 kernel/kthread.c:246
ret_from_fork+0x3a/0x50 arch/x86/entry/entry_64.S:413

-> #0 ((wq_completion)"dio/%s"sb->s_id){+.+.}:
lock_acquire+0x1ed/0x520 kernel/locking/lockdep.c:3900
flush_workqueue+0x30a/0x1e10 kernel/workqueue.c:2655
drain_workqueue+0x2a9/0x640 kernel/workqueue.c:2820
destroy_workqueue+0xc6/0x9c0 kernel/workqueue.c:4155
sb_init_dio_done_wq+0x74/0x90 fs/direct-io.c:634
do_blockdev_direct_IO+0x12ea/0x9d70 fs/direct-io.c:1283
__blockdev_direct_IO+0x9d/0xc6 fs/direct-io.c:1417
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
ext4_direct_IO_write fs/ext4/inode.c:3743 [inline]
ext4_direct_IO+0xae8/0x2230 fs/ext4/inode.c:3870
generic_file_direct_write+0x275/0x4b0 mm/filemap.c:3042
__generic_file_write_iter+0x2ff/0x630 mm/filemap.c:3221
ext4_file_write_iter+0x390/0x1420 fs/ext4/file.c:266
call_write_iter include/linux/fs.h:1808 [inline]
aio_write+0x3b1/0x610 fs/aio.c:1561
io_submit_one+0xaa1/0xf80 fs/aio.c:1835
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
__do_sys_io_submit fs/aio.c:1916 [inline]
__se_sys_io_submit fs/aio.c:1887 [inline]
__x64_sys_io_submit+0x1b7/0x580 fs/aio.c:1887
do_syscall_64+0x1b9/0x820 arch/x86/entry/common.c:290
entry_SYSCALL_64_after_hwframe+0x49/0xbe

other info that might help us debug this:

Chain exists of:
(wq_completion)"dio/%s"sb->s_id -->
(work_completion)(&dio->complete_work) --> &sb->s_type->i_mutex_key#10

Possible unsafe locking scenario:

CPU0 CPU1
---- ----
lock(&sb->s_type->i_mutex_key#10);
lock((work_completion)(&dio->complete_work));
lock(&sb->s_type->i_mutex_key#10);
lock((wq_completion)"dio/%s"sb->s_id);

*** DEADLOCK ***

1 lock held by syz-executor1/6832:
#0: 00000000e2da6d71 (&sb->s_type->i_mutex_key#10){+.+.}, at:
inode_trylock include/linux/fs.h:758 [inline]
#0: 00000000e2da6d71 (&sb->s_type->i_mutex_key#10){+.+.}, at:
ext4_file_write_iter+0x2a1/0x1420 fs/ext4/file.c:232

stack backtrace:
CPU: 1 PID: 6832 Comm: syz-executor1 Not tainted 4.19.0-rc8+ #291
Hardware name: Google Google Compute Engine/Google Compute Engine, BIOS
Google 01/01/2011
Call Trace:
__dump_stack lib/dump_stack.c:77 [inline]
dump_stack+0x1c4/0x2b4 lib/dump_stack.c:113
print_circular_bug.isra.33.cold.54+0x1bd/0x27d
kernel/locking/lockdep.c:1221
check_prev_add kernel/locking/lockdep.c:1861 [inline]
check_prevs_add kernel/locking/lockdep.c:1974 [inline]
validate_chain kernel/locking/lockdep.c:2415 [inline]
__lock_acquire+0x33e4/0x4ec0 kernel/locking/lockdep.c:3411
lock_acquire+0x1ed/0x520 kernel/locking/lockdep.c:3900
flush_workqueue+0x30a/0x1e10 kernel/workqueue.c:2655
drain_workqueue+0x2a9/0x640 kernel/workqueue.c:2820
destroy_workqueue+0xc6/0x9c0 kernel/workqueue.c:4155
sb_init_dio_done_wq+0x74/0x90 fs/direct-io.c:634
do_blockdev_direct_IO+0x12ea/0x9d70 fs/direct-io.c:1283
__blockdev_direct_IO+0x9d/0xc6 fs/direct-io.c:1417
ext4_direct_IO_write fs/ext4/inode.c:3743 [inline]
ext4_direct_IO+0xae8/0x2230 fs/ext4/inode.c:3870
generic_file_direct_write+0x275/0x4b0 mm/filemap.c:3042
__generic_file_write_iter+0x2ff/0x630 mm/filemap.c:3221
ext4_file_write_iter+0x390/0x1420 fs/ext4/file.c:266
call_write_iter include/linux/fs.h:1808 [inline]
aio_write+0x3b1/0x610 fs/aio.c:1561
io_submit_one+0xaa1/0xf80 fs/aio.c:1835
__do_sys_io_submit fs/aio.c:1916 [inline]
__se_sys_io_submit fs/aio.c:1887 [inline]
__x64_sys_io_submit+0x1b7/0x580 fs/aio.c:1887
do_syscall_64+0x1b9/0x820 arch/x86/entry/common.c:290
entry_SYSCALL_64_after_hwframe+0x49/0xbe
RIP: 0033:0x457569
Code: fd b3 fb ff c3 66 2e 0f 1f 84 00 00 00 00 00 66 90 48 89 f8 48 89 f7
48 89 d6 48 89 ca 4d 89 c2 4d 89 c8 4c 8b 4c 24 08 0f 05 <48> 3d 01 f0 ff
ff 0f 83 cb b3 fb ff c3 66 2e 0f 1f 84 00 00 00 00
RSP: 002b:00007f7d19a51c78 EFLAGS: 00000246 ORIG_RAX: 00000000000000d1
RAX: ffffffffffffffda RBX: 0000000000000003 RCX: 0000000000457569
RDX: 0000000020000540 RSI: 0000000000000008 RDI: 00007f7d19a31000
RBP: 000000000072bf00 R08: 0000000000000000 R09: 0000000000000000
R10: 0000000000000000 R11: 0000000000000246 R12: 00007f7d19a526d4
R13: 00000000004be72d R14: 00000000004ce380 R15: 00000000ffffffff
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
syz-executor3 (6993) used greatest stack depth: 14648 bytes left
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
Page cache invalidation failure on direct I/O. Possible data corruption
due to collision with buffered I/O!
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
File: /root/syzkaller-testdir701396558/syzkaller.CThVT5/11/bus PID: 14
Comm: kworker/0:1
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
Page cache invalidation failure on direct I/O. Possible data corruption
due to collision with buffered I/O!
File: /root/syzkaller-testdir446226321/syzkaller.6kf3D2/23/bus PID: 14
Comm: kworker/0:1
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
syz-executor5 (7484) used greatest stack depth: 12280 bytes left
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
Page cache invalidation failure on direct I/O. Possible data corruption
due to collision with buffered I/O!
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
File: /root/syzkaller-testdir749472085/syzkaller.cOi3p9/41/bus PID: 5692
Comm: kworker/0:4
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
Page cache invalidation failure on direct I/O. Possible data corruption
due to collision with buffered I/O!
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
File: /root/syzkaller-testdir625100220/syzkaller.kNEfa4/64/bus PID: 7011
Comm: kworker/0:5
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env
kobject: 'loop5' (00000000373a5938): fill_kobj_path: path
= '/devices/virtual/block/loop5'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop4' (00000000d7ab4dab): kobject_uevent_env
kobject: 'loop4' (00000000d7ab4dab): fill_kobj_path: path
= '/devices/virtual/block/loop4'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop1' (0000000020356063): kobject_uevent_env
kobject: 'loop1' (0000000020356063): fill_kobj_path: path
= '/devices/virtual/block/loop1'
kobject: 'loop2' (00000000a99f8b0a): kobject_uevent_env
kobject: 'loop2' (00000000a99f8b0a): fill_kobj_path: path
= '/devices/virtual/block/loop2'
kobject: 'loop0' (0000000088c9da71): kobject_uevent_env
kobject: 'loop0' (0000000088c9da71): fill_kobj_path: path
= '/devices/virtual/block/loop0'
kobject: 'loop3' (00000000037f642c): kobject_uevent_env
kobject: 'loop3' (00000000037f642c): fill_kobj_path: path
= '/devices/virtual/block/loop3'
kobject: 'loop5' (00000000373a5938): kobject_uevent_env


---
This bug is generated by a bot. It may contain errors.
See https://goo.gl/tpsmEJ for more information about syzbot.
syzbot engineers can be reached at syzk...@googlegroups.com.

syzbot will keep track of this bug report. See:
https://goo.gl/tpsmEJ#bug-status-tracking for how to communicate with
syzbot.
syzbot can test patches for this bug, for details see:
https://goo.gl/tpsmEJ#testing-patches

syzbot

unread,
Oct 23, 2018, 5:42:04 AM10/23/18
to adilger...@dilger.ca, linux...@vger.kernel.org, linux-...@vger.kernel.org, syzkall...@googlegroups.com, ty...@mit.edu
syzbot has found a reproducer for the following crash on:

HEAD commit: ca9eb48fe01f Merge tag 'regulator-v5.0' of git://git.kerne..
git tree: upstream
console output: https://syzkaller.appspot.com/x/log.txt?x=11a60939400000
kernel config: https://syzkaller.appspot.com/x/.config?x=963b24abf3f7c2d8
dashboard link: https://syzkaller.appspot.com/bug?extid=a50c7541a4a55cd49b02
compiler: gcc (GCC) 8.0.1 20180413 (experimental)
syz repro: https://syzkaller.appspot.com/x/repro.syz?x=12097f03400000
C reproducer: https://syzkaller.appspot.com/x/repro.c?x=10b55ac5400000

IMPORTANT: if you fix the bug, please add the following tag to the commit:
Reported-by: syzbot+a50c75...@syzkaller.appspotmail.com


======================================================
WARNING: possible circular locking dependency detected
syz-executor460 (5381) used greatest stack depth: 13176 bytes left
4.19.0+ #298 Not tainted
------------------------------------------------------
syz-executor460/5379 is trying to acquire lock:
00000000cba2efd5 ((wq_completion)"dio/%s"sb->s_id){+.+.}, at:
flush_workqueue+0x2db/0x1e10 kernel/workqueue.c:2652

but task is already holding lock:
00000000a7636398 (&sb->s_type->i_mutex_key#10){+.+.}, at: inode_trylock
include/linux/fs.h:758 [inline]
00000000a7636398 (&sb->s_type->i_mutex_key#10){+.+.}, at:
ext4_file_write_iter+0x2a1/0x1420 fs/ext4/file.c:232

which lock already depends on the new lock.


the existing dependency chain (in reverse order) is:

-> #2 (&sb->s_type->i_mutex_key#10){+.+.}:
down_write+0x8a/0x130 kernel/locking/rwsem.c:70
inode_lock include/linux/fs.h:738 [inline]
__generic_file_fsync+0xb5/0x200 fs/libfs.c:981
ext4_sync_file+0xa4f/0x1510 fs/ext4/fsync.c:120
vfs_fsync_range+0x140/0x220 fs/sync.c:197
generic_write_sync include/linux/fs.h:2732 [inline]
dio_complete+0x75c/0x9e0 fs/direct-io.c:329
dio_aio_complete_work+0x20/0x30 fs/direct-io.c:341
process_one_work+0xc90/0x1c40 kernel/workqueue.c:2153
worker_thread+0x17f/0x1390 kernel/workqueue.c:2296
kthread+0x35a/0x420 kernel/kthread.c:246
ret_from_fork+0x3a/0x50 arch/x86/entry/entry_64.S:413

-> #1 ((work_completion)(&dio->complete_work)){+.+.}:
process_one_work+0xc0a/0x1c40 kernel/workqueue.c:2129
worker_thread+0x17f/0x1390 kernel/workqueue.c:2296
kthread+0x35a/0x420 kernel/kthread.c:246
ret_from_fork+0x3a/0x50 arch/x86/entry/entry_64.S:413

-> #0 ((wq_completion)"dio/%s"sb->s_id){+.+.}:
lock_acquire+0x1ed/0x520 kernel/locking/lockdep.c:3900
flush_workqueue+0x30a/0x1e10 kernel/workqueue.c:2655
drain_workqueue+0x2a9/0x640 kernel/workqueue.c:2820
destroy_workqueue+0xc6/0x9c0 kernel/workqueue.c:4155
sb_init_dio_done_wq+0x74/0x90 fs/direct-io.c:634
do_blockdev_direct_IO+0x12ea/0x9d70 fs/direct-io.c:1283
__blockdev_direct_IO+0x9d/0xc6 fs/direct-io.c:1417
ext4_direct_IO_write fs/ext4/inode.c:3743 [inline]
ext4_direct_IO+0xae8/0x2230 fs/ext4/inode.c:3870
generic_file_direct_write+0x275/0x4b0 mm/filemap.c:3042
__generic_file_write_iter+0x2ff/0x630 mm/filemap.c:3221
ext4_file_write_iter+0x390/0x1420 fs/ext4/file.c:266
call_write_iter include/linux/fs.h:1808 [inline]
aio_write+0x3b1/0x610 fs/aio.c:1561
io_submit_one+0xaa1/0xf80 fs/aio.c:1835
__do_sys_io_submit fs/aio.c:1916 [inline]
__se_sys_io_submit fs/aio.c:1887 [inline]
__x64_sys_io_submit+0x1b7/0x580 fs/aio.c:1887
do_syscall_64+0x1b9/0x820 arch/x86/entry/common.c:290
entry_SYSCALL_64_after_hwframe+0x49/0xbe

other info that might help us debug this:

Chain exists of:
(wq_completion)"dio/%s"sb->s_id -->
(work_completion)(&dio->complete_work) --> &sb->s_type->i_mutex_key#10

Possible unsafe locking scenario:

CPU0 CPU1
---- ----
lock(&sb->s_type->i_mutex_key#10);
lock((work_completion)(&dio->complete_work));
lock(&sb->s_type->i_mutex_key#10);
lock((wq_completion)"dio/%s"sb->s_id);

*** DEADLOCK ***

1 lock held by syz-executor460/5379:
#0: 00000000a7636398 (&sb->s_type->i_mutex_key#10){+.+.}, at:
inode_trylock include/linux/fs.h:758 [inline]
#0: 00000000a7636398 (&sb->s_type->i_mutex_key#10){+.+.}, at:
ext4_file_write_iter+0x2a1/0x1420 fs/ext4/file.c:232

stack backtrace:
CPU: 1 PID: 5379 Comm: syz-executor460 Not tainted 4.19.0+ #298
Hardware name: Google Google Compute Engine/Google Compute Engine, BIOS
Google 01/01/2011
Call Trace:
__dump_stack lib/dump_stack.c:77 [inline]
dump_stack+0x1c4/0x2b6 lib/dump_stack.c:113
RIP: 0033:0x4469b9
Code: e8 dc e6 ff ff 48 83 c4 18 c3 0f 1f 80 00 00 00 00 48 89 f8 48 89 f7
48 89 d6 48 89 ca 4d 89 c2 4d 89 c8 4c 8b 4c 24 08 0f 05 <48> 3d 01 f0 ff
ff 0f 83 4b 07 fc ff c3 66 2e 0f 1f 84 00 00 00 00
RSP: 002b:00007fbd534a7da8 EFLAGS: 00000246 ORIG_RAX: 00000000000000d1
RAX: ffffffffffffffda RBX: 00000000006dcc48 RCX: 00000000004469b9
RDX: 0000000020000540 RSI: 0000000000000008 RDI: 00007fbd53487000
RBP: 00000000006dcc40 R08: 0000000000000000 R09: 0000000000000000
R10: 0000000000000000 R11: 0000000000000246 R12: 00000000006dcc4c
R13: 8000000000044000 R14: 00007fbd534a89c0 R15: 00000000006dcd4c
Page cache invalidation failure on direct I/O. Possible data corruption
due to collision with buffered I/O!
File: /root/syzkaller.jTMKK3/1/bus PID: 14 Comm: kworker/0:1
Page cache invalidation failure on direct I/O. Possible data corruption
due to collision with buffered I/O!
File: /root/syzkaller.jTMKK3/3/bus PID: 14 Comm: kworker/0:1
Page cache invalidation failure on direct I/O. Possible data corruption
due to collision with buffered I/O!
File: /root/syzkaller.itrSF4/4/bus PID: 5 Comm: kworker/0:0
Page cache invalidation failure on direct I/O. Possible data corruption
due to collision with buffered I/O!
File: /root/syzkaller.itrSF4/5/bus PID: 5 Comm: kworker/0:0
Page cache invalidation failure on direct I/O. Possible data corruption
due to collision with buffered I/O!
File: /root/syzkaller.qGPxI4/5/bus PID: 14 Comm: kworker/0:1
Page cache invalidation failure on direct I/O. Possible data corruption
due to collision with buffered I/O!
File: /root/syzkaller.qGPxI4/6/bus PID: 5 Comm: kworker/0:0
Page cache invalidation failure on direct I/O. Possible data corruption
due to collision with buffered I/O!
File: /root/syzkaller.FhXGz4/9/bus PID: 14 Comm: kworker/0:1
Page cache invalidation failure on direct I/O. Possible data corruption
due to collision with buffered I/O!
File: /root/syzkaller.itrSF4/9/bus PID: 5394 Comm: kworker/0:4
Page cache invalidation failure on direct I/O. Possible data corruption
due to collision with buffered I/O!
File: /root/syzkaller.FhXGz4/10/bus PID: 5394 Comm: kworker/0:4
Page cache invalidation failure on direct I/O. Possible data corruption
due to collision with buffered I/O!
File: /root/syzkaller.qGPxI4/9/bus PID: 5394 Comm: kworker/0:4

Theodore Y. Ts'o

unread,
Oct 23, 2018, 10:28:18 AM10/23/18
to syzbot, adilger...@dilger.ca, linux...@vger.kernel.org, linux-...@vger.kernel.org, syzkall...@googlegroups.com, linux-...@vger.kernel.org, t...@kernel.org, jiangs...@gmail.com
On Tue, Oct 23, 2018 at 02:42:03AM -0700, syzbot wrote:
> syzbot has found a reproducer for the following crash on:
>
> HEAD commit: ca9eb48fe01f Merge tag 'regulator-v5.0' of git://git.kerne..
> git tree: upstream
> console output: https://syzkaller.appspot.com/x/log.txt?x=11a60939400000
> kernel config: https://syzkaller.appspot.com/x/.config?x=963b24abf3f7c2d8
> dashboard link: https://syzkaller.appspot.com/bug?extid=a50c7541a4a55cd49b02
> compiler: gcc (GCC) 8.0.1 20180413 (experimental)
> syz repro: https://syzkaller.appspot.com/x/repro.syz?x=12097f03400000
> C reproducer: https://syzkaller.appspot.com/x/repro.c?x=10b55ac5400000
>
> IMPORTANT: if you fix the bug, please add the following tag to the commit:
> Reported-by: syzbot+a50c75...@syzkaller.appspotmail.com

This is a false positive in lockdep, but it's not clear to me what's
the best way to fix it. It's not ext4-specific, so I've added
linux-fsdevel, Tejun, and Lai to the cc.

The problem is that when we first start doing direct I/O in a
particular file system, we use a lockless technique to allocate the
dio workqueue. From fs/direct-io.c:

int sb_init_dio_done_wq(struct super_block *sb)
{
struct workqueue_struct *old;
struct workqueue_struct *wq = alloc_workqueue("dio/%s",
WQ_MEM_RECLAIM, 0,
sb->s_id);
if (!wq)
return -ENOMEM;
/*
* This has to be atomic as more DIOs can race to create the workqueue
*/
old = cmpxchg(&sb->s_dio_done_wq, NULL, wq);
/* Someone created workqueue before us? Free ours... */
if (old)
destroy_workqueue(wq);
return 0;
}

If we have multiple DIO writers racing to initialize
sb->s_dio_done_wq, the losers of the race will destroy the fresly
created workqueue. Because it's freshly created, there's nothing to
drain --- but lockdep doesn't know that.

One way I suppose we could solve this is to call sb_init_dio_done_wq
on open if the O_DIRECT flag is set. But now if we have multiple
threads racing to open files with O_DIRECT we'll still hit this
particular race.

The other, and I think better way, we could fix this is to have an
alternate destroy_never_used_workqueue() function which skips the
drain_workqueue().

What do people think?

The annotated lockdep is attached below.

- Ted

[ 263.210408] EXT4-fs (vdc): mounted filesystem without journal. Opts: acl,user_xattr,d
[ 263.227896]
[ 263.229118] ======================================================
[ 263.231370] WARNING: possible circular locking dependency detected
[ 263.232950] 4.19.0-rc6-xfstests-00021-g33458eaba4df #706 Not tainted
[ 263.234762] ------------------------------------------------------
[ 263.236915] kworker/1:3/1371 is trying to acquire lock:
[ 263.238630] 00000000f97c1367 (&sb->s_type->i_mutex_key#11){+.+.}, at: __generic_file0
[ 263.241115]
[ 263.241115] but task is already holding lock:
[ 263.243121] 000000008f473d52 ((work_completion)(&dio->complete_work)){+.+.}, at: pro0
[ 263.246910]
[ 263.246910] which lock already depends on the new lock.
[ 263.246910]
[ 263.249597]
[ 263.249597] the existing dependency chain (in reverse order) is:
[ 263.252024]
[ 263.252024] -> #2 ((work_completion)(&dio->complete_work)){+.+.}:
[ 263.254384] process_one_work (/arch/x86/include/asm/jump_label.h:36 /include/linux/jump_label.h:142 /include/trace/events/workqueue.h:89 /kernel/workqueue.c:2152)
[ 263.255835] worker_thread (/include/linux/compiler.h:188 /include/linux/list.h:203 /kernel/workqueue.c:2297)
[ 263.257180] kthread (/kernel/kthread.c:246)
[ 263.258310] ret_from_fork (/arch/x86/entry/entry_64.S:419)
[ 263.259449]
[ 263.259449] -> #1 ((wq_completion)"dio/%s"sb->s_id){+.+.}:
[ 263.260991] flush_workqueue (/kernel/workqueue.c:2655)
[ 263.262024] drain_workqueue (/kernel/workqueue.c:2822)
[ 263.263076] destroy_workqueue (/kernel/workqueue.c:4158)
[ 263.264177] sb_init_dio_done_wq (/fs/direct-io.c:636)
[ 263.265131] __blockdev_direct_IO (/fs/direct-io.c:1283 /fs/direct-io.c:1417)
[ 263.266248] ext4_direct_IO (/fs/ext4/inode.c:3778 /fs/ext4/inode.c:3901)
[ 263.267184] generic_file_direct_write (/mm/filemap.c:3057)
[ 263.268164] __generic_file_write_iter (/mm/filemap.c:3229)
[ 263.269173] ext4_file_write_iter (/include/linux/fs.h:743 /fs/ext4/file.c:267)
[ 263.270052] aio_write (/fs/aio.c:1473 /fs/aio.c:1561)
[ 263.270821] io_submit_one (/fs/aio.c:1836)
[ 263.272136] __se_sys_io_submit (/fs/aio.c:1916 /fs/aio.c:1887)
[ 263.273565] do_syscall_64 (/arch/x86/entry/common.c:290)
[ 263.274831] entry_SYSCALL_64_after_hwframe (/arch/x86/entry/entry_64.S:240)
[ 263.276514]
[ 263.276514] -> #0 (&sb->s_type->i_mutex_key#11){+.+.}:
[ 263.278492] lock_acquire (/arch/x86/include/asm/paravirt.h:788 /kernel/locking/lockdep.c:3903)
[ 263.279690] down_write (/arch/x86/include/asm/rwsem.h:160 /kernel/locking/rwsem.c:72)
[ 263.280812] __generic_file_fsync (/fs/libfs.c:982)
[ 263.282156] ext4_sync_file (/fs/ext4/fsync.c:121)
[ 263.283400] dio_complete (/include/linux/fs.h:2733 /fs/direct-io.c:329)
[ 263.284629] process_one_work (/arch/x86/include/asm/jump_label.h:36 /include/linux/jump_label.h:142 /include/trace/events/workqueue.h:114 /kernel/workqueue.c:2158)
[ 263.285916] worker_thread (/include/linux/compiler.h:188 /include/linux/list.h:203 /kernel/workqueue.c:2297)
[ 263.287114] kthread (/kernel/kthread.c:246)
[ 263.288198] ret_from_fork (/arch/x86/entry/entry_64.S:419)
[ 263.289394]
[ 263.289394] other info that might help us debug this:
[ 263.289394]
[ 263.291805] Chain exists of:
[ 263.291805] &sb->s_type->i_mutex_key#11 --> (wq_completion)"dio/%s"sb->s_id --> (w)
[ 263.291805]
[ 263.294392] Possible unsafe locking scenario:
[ 263.294392]
[ 263.295398] CPU0 CPU1
[ 263.296171] ---- ----
[ 263.296949] lock((work_completion)(&dio->complete_work));
[ 263.298481] lock((wq_completion)"dio/%s"sb->s_id);
[ 263.300579] lock((work_completion)(&dio->complete_wor;
[ 263.302856] lock(&sb->s_type->i_mutex_key#11);
[ 263.304175]
[ 263.304175] *** DEADLOCK ***
[ 263.304175]
[ 263.305861] 2 locks held by kworker/1:3/1371:
[ 263.307097] #0: 000000004a793a56 ((wq_completion)"dio/%s"sb->s_id){+.+.}, at: proce0
[ 263.309761] #1: 000000008f473d52 ((work_completion)(&dio->complete_work)){+.+.}, at0
[ 263.312663]
[ 263.312663] stack backtrace:
[ 263.313881] CPU: 1 PID: 1371 Comm: kworker/1:3 Not tainted 4.19.0-rc6-xfstests-000216
[ 263.316541] Hardware name: QEMU Standard PC (i440FX + PIIX, 1996), BIOS 1.11.1-1 04/4
[ 263.318894] Workqueue: dio/vdc dio_aio_complete_work
[ 263.320303] Call Trace:
[ 263.321038] dump_stack (/lib/dump_stack.c:115)
[ 263.322010] print_circular_bug.isra.19.cold.39 (/kernel/locking/lockdep.c:1221)
[ 263.323581] check_prev_add.constprop.27 (/kernel/locking/lockdep.c:1861)
[ 263.324991] __lock_acquire (/kernel/locking/lockdep.c:1975 /kernel/locking/lockdep.c:2415 /kernel/locking/lockdep.c:3411)
[ 263.326054] lock_acquire (/arch/x86/include/asm/paravirt.h:788 /kernel/locking/lockdep.c:3903)
[ 263.327086] ? __generic_file_fsync (/fs/libfs.c:982)
[ 263.328349] down_write (/arch/x86/include/asm/rwsem.h:160 /kernel/locking/rwsem.c:72)
[ 263.329300] ? __generic_file_fsync (/fs/libfs.c:982)
[ 263.330504] __generic_file_fsync (/fs/libfs.c:982)
[ 263.331663] ext4_sync_file (/fs/ext4/fsync.c:121)
[ 263.332722] dio_complete (/include/linux/fs.h:2733 /fs/direct-io.c:329)
[ 263.333772] process_one_work (/arch/x86/include/asm/jump_label.h:36 /include/linux/jump_label.h:142 /include/trace/events/workqueue.h:114 /kernel/workqueue.c:2158)
[ 263.334719] worker_thread (/include/linux/compiler.h:188 /include/linux/list.h:203 /kernel/workqueue.c:2297)
[ 263.335482] ? process_one_work (/kernel/workqueue.c:2239)
[ 263.336241] kthread (/kernel/kthread.c:246)
[ 263.336826] ? kthread_park (/kernel/kthread.c:206)
[ 263.337548] ret_from_fork (/arch/x86/entry/entry_64.S:419)

Tejun Heo

unread,
Oct 23, 2018, 3:40:27 PM10/23/18
to Theodore Y. Ts'o, syzbot, adilger...@dilger.ca, linux...@vger.kernel.org, linux-...@vger.kernel.org, syzkall...@googlegroups.com, linux-...@vger.kernel.org, jiangs...@gmail.com
Hello,

On Tue, Oct 23, 2018 at 10:28:04AM -0400, Theodore Y. Ts'o wrote:
> The other, and I think better way, we could fix this is to have an
> alternate destroy_never_used_workqueue() function which skips the
> drain_workqueue().

Yeah, I'm okay with this approach. Maybe name it
destroy_workqueue_skip_drain()?

Thanks.

--
tejun

syzbot

unread,
Mar 22, 2019, 7:12:01 AM3/22/19
to adilger...@dilger.ca, da...@davemloft.net, jiangs...@gmail.com, kuz...@ms2.inr.ac.ru, linux...@vger.kernel.org, linux-...@vger.kernel.org, linux-...@vger.kernel.org, net...@vger.kernel.org, sbr...@redhat.com, s...@queasysnail.net, syzkall...@googlegroups.com, t...@kernel.org, ty...@mit.edu, vi...@zeniv.linux.org.uk, yosh...@linux-ipv6.org
syzbot has bisected this bug to:

commit f547fac624be53ad8b07e9ebca7654a7827ba61b
Author: Sabrina Dubroca <s...@queasysnail.net>
Date: Fri Oct 12 14:22:47 2018 +0000

ipv6: rate-limit probes for neighbourless routes

bisection log: https://syzkaller.appspot.com/x/bisect.txt?x=17affd1b200000
start commit: f547fac6 ipv6: rate-limit probes for neighbourless routes
git tree: upstream
final crash: https://syzkaller.appspot.com/x/report.txt?x=146ffd1b200000
console output: https://syzkaller.appspot.com/x/log.txt?x=106ffd1b200000
Reported-by: syzbot+a50c75...@syzkaller.appspotmail.com
Fixes: f547fac624be ("ipv6: rate-limit probes for neighbourless routes")

For information about bisection process see: https://goo.gl/tpsmEJ#bisection

syzbot

unread,
Nov 7, 2019, 8:42:08 AM11/7/19
to aarc...@redhat.com, adilger...@dilger.ca, ak...@linux-foundation.org, aneesh...@linux.vnet.ibm.com, da...@stgolabs.net, da...@davemloft.net, hu...@google.com, jiangs...@gmail.com, kirill....@linux.intel.com, kuz...@ms2.inr.ac.ru, linux...@vger.kernel.org, linux-...@vger.kernel.org, linux-...@vger.kernel.org, mho...@kernel.org, mike.k...@oracle.com, n-hor...@ah.jp.nec.com, net...@vger.kernel.org, prakash....@oracle.com, sbr...@redhat.com, s...@queasysnail.net, syzkall...@googlegroups.com, t...@kernel.org, torv...@linux-foundation.org, ty...@mit.edu, vi...@zeniv.linux.org.uk, yosh...@linux-ipv6.org
syzbot suspects this bug was fixed by commit:

commit e7c58097793ef15d58fadf190ee58738fbf447cd
Author: Mike Kravetz <mike.k...@oracle.com>
Date: Tue Jan 8 23:23:32 2019 +0000

hugetlbfs: revert "Use i_mmap_rwsem to fix page fault/truncate race"

bisection log: https://syzkaller.appspot.com/x/bisect.txt?x=14ec0d2c600000
start commit: ca9eb48f Merge tag 'regulator-v5.0' of git://git.kernel.or..
git tree: upstream
If the result looks correct, please mark the bug fixed by replying with:

#syz fix: hugetlbfs: revert "Use i_mmap_rwsem to fix page fault/truncate
race"

Dmitry Vyukov

unread,
Jan 31, 2020, 12:46:45 PM1/31/20
to syzbot, syzkaller-bugs
#syz fix:
hugetlbfs: revert "Use i_mmap_rwsem to fix page fault/truncate race"

> --
> You received this message because you are subscribed to the Google Groups "syzkaller-bugs" group.
> To unsubscribe from this group and stop receiving emails from it, send an email to syzkaller-bug...@googlegroups.com.
> To view this discussion on the web visit https://groups.google.com/d/msgid/syzkaller-bugs/000000000000d8b0630596c1d4a0%40google.com.
Reply all
Reply to author
Forward
0 new messages