================================================================== BUG: KCSAN: data-race in ext4_ext_try_to_merge_right / ext4_mark_iloc_dirty write to 0xffff888106b36202 of 2 bytes by task 1797 on cpu 1: le16_add_cpu include/linux/byteorder/generic.h:146 [inline] ext4_ext_try_to_merge_right+0x34f/0x4c0 fs/ext4/extents.c:1782 ext4_ext_try_to_merge+0x6b/0x310 fs/ext4/extents.c:1856 ext4_convert_unwritten_extents_endio fs/ext4/extents.c:3728 [inline] ext4_ext_handle_unwritten_extents+0x67a/0xaa0 fs/ext4/extents.c:3856 ext4_ext_map_blocks+0x719/0x1f00 fs/ext4/extents.c:4126 ext4_map_blocks+0x70d/0xef0 fs/ext4/inode.c:638 ext4_convert_unwritten_extents+0x15a/0x2c0 fs/ext4/extents.c:4767 ext4_convert_unwritten_io_end_vec+0xa4/0x130 fs/ext4/extents.c:4806 ext4_end_io_end fs/ext4/page-io.c:184 [inline] ext4_do_flush_completed_IO fs/ext4/page-io.c:257 [inline] ext4_end_io_rsv_work+0x198/0x360 fs/ext4/page-io.c:271 process_one_work+0x3e9/0x8f0 kernel/workqueue.c:2276 worker_thread+0x636/0xae0 kernel/workqueue.c:2422 kthread+0x262/0x280 kernel/kthread.c:319 ret_from_fork+0x1f/0x30 arch/x86/entry/entry_64.S:295 read to 0xffff888106b36200 of 4 bytes by task 29434 on cpu 0: ext4_do_update_inode fs/ext4/inode.c:5109 [inline] ext4_mark_iloc_dirty+0xca6/0x1750 fs/ext4/inode.c:5724 __ext4_mark_inode_dirty+0x4db/0x5b0 fs/ext4/inode.c:5918 ext4_dirty_inode+0x86/0xa0 fs/ext4/inode.c:5947 __mark_inode_dirty+0x77/0x680 fs/fs-writeback.c:2395 mark_inode_dirty include/linux/fs.h:2403 [inline] generic_write_end+0x157/0x180 fs/buffer.c:2198 ext4_da_write_end+0x59b/0x730 fs/ext4/inode.c:3110 generic_perform_write+0x22a/0x3c0 mm/filemap.c:3667 ext4_buffered_write_iter+0x2f2/0x3f0 fs/ext4/file.c:269 ext4_file_write_iter+0x2e7/0x11d0 fs/ext4/file.c:519 call_write_iter include/linux/fs.h:2114 [inline] do_iter_readv_writev+0x2cb/0x360 fs/read_write.c:740 do_iter_write+0x112/0x4c0 fs/read_write.c:866 vfs_iter_write+0x4c/0x70 fs/read_write.c:907 iter_file_splice_write+0x40a/0x750 fs/splice.c:689 do_splice_from fs/splice.c:767 [inline] direct_splice_actor+0x80/0xa0 fs/splice.c:936 splice_direct_to_actor+0x345/0x650 fs/splice.c:891 do_splice_direct+0xf5/0x170 fs/splice.c:979 do_sendfile+0x773/0xda0 fs/read_write.c:1260 __do_sys_sendfile64 fs/read_write.c:1325 [inline] __se_sys_sendfile64 fs/read_write.c:1311 [inline] __x64_sys_sendfile64+0xf2/0x130 fs/read_write.c:1311 do_syscall_x64 arch/x86/entry/common.c:50 [inline] do_syscall_64+0x3d/0x90 arch/x86/entry/common.c:80 entry_SYSCALL_64_after_hwframe+0x44/0xae value changed: 0x0004f30a -> 0x0003f30a Reported by Kernel Concurrency Sanitizer on: CPU: 0 PID: 29434 Comm: syz-executor.2 Not tainted 5.14.0-rc1-syzkaller #0 Hardware name: Google Google Compute Engine/Google Compute Engine, BIOS Google 01/01/2011 ================================================================== ================================================================== BUG: KCSAN: data-race in xas_clear_mark / xas_find_marked write to 0xffff888106b7f468 of 8 bytes by task 29426 on cpu 1: instrument_write include/linux/instrumented.h:42 [inline] __instrument_read_write_bitop include/asm-generic/bitops/instrumented-non-atomic.h:79 [inline] __test_and_clear_bit include/asm-generic/bitops/instrumented-non-atomic.h:109 [inline] node_clear_mark lib/xarray.c:100 [inline] xas_clear_mark+0xa1/0x180 lib/xarray.c:911 __test_set_page_writeback+0x3e9/0x500 mm/page-writeback.c:2809 ext4_bio_write_page+0xee/0xa40 fs/ext4/page-io.c:450 mpage_submit_page fs/ext4/inode.c:2100 [inline] mpage_map_and_submit_buffers fs/ext4/inode.c:2348 [inline] mpage_map_and_submit_extent fs/ext4/inode.c:2487 [inline] ext4_writepages+0x1050/0x1d10 fs/ext4/inode.c:2800 do_writepages+0x7b/0x150 mm/page-writeback.c:2355 __filemap_fdatawrite_range mm/filemap.c:413 [inline] __filemap_fdatawrite mm/filemap.c:421 [inline] filemap_flush+0x132/0x160 mm/filemap.c:448 ext4_alloc_da_blocks+0x47/0xd0 fs/ext4/inode.c:3164 ext4_release_file+0x5b/0x1d0 fs/ext4/file.c:141 __fput+0x25b/0x4e0 fs/file_table.c:280 ____fput+0x11/0x20 fs/file_table.c:313 task_work_run+0xae/0x130 kernel/task_work.c:164 tracehook_notify_resume include/linux/tracehook.h:189 [inline] exit_to_user_mode_loop kernel/entry/common.c:175 [inline] exit_to_user_mode_prepare+0x156/0x190 kernel/entry/common.c:209 __syscall_exit_to_user_mode_work kernel/entry/common.c:291 [inline] syscall_exit_to_user_mode+0x20/0x40 kernel/entry/common.c:302 do_syscall_64+0x49/0x90 arch/x86/entry/common.c:86 entry_SYSCALL_64_after_hwframe+0x44/0xae read to 0xffff888106b7f468 of 8 bytes by task 29434 on cpu 0: xas_find_chunk include/linux/xarray.h:1662 [inline] xas_find_marked+0x195/0x5f0 lib/xarray.c:1349 find_get_entry mm/filemap.c:1925 [inline] find_get_pages_range_tag+0xf2/0x390 mm/filemap.c:2216 pagevec_lookup_range_tag+0x37/0x50 mm/swap.c:1123 mpage_prepare_extent_to_map+0x195/0x640 fs/ext4/inode.c:2577 ext4_writepages+0x9d8/0x1d10 fs/ext4/inode.c:2798 do_writepages+0x7b/0x150 mm/page-writeback.c:2355 __filemap_fdatawrite_range mm/filemap.c:413 [inline] __filemap_fdatawrite mm/filemap.c:421 [inline] filemap_flush+0x132/0x160 mm/filemap.c:448 ext4_alloc_da_blocks+0x47/0xd0 fs/ext4/inode.c:3164 ext4_release_file+0x5b/0x1d0 fs/ext4/file.c:141 __fput+0x25b/0x4e0 fs/file_table.c:280 ____fput+0x11/0x20 fs/file_table.c:313 task_work_run+0xae/0x130 kernel/task_work.c:164 get_signal+0x156c/0x15e0 kernel/signal.c:2581 arch_do_signal_or_restart+0x2a/0x220 arch/x86/kernel/signal.c:865 handle_signal_work kernel/entry/common.c:148 [inline] exit_to_user_mode_loop kernel/entry/common.c:172 [inline] exit_to_user_mode_prepare+0x109/0x190 kernel/entry/common.c:209 __syscall_exit_to_user_mode_work kernel/entry/common.c:291 [inline] syscall_exit_to_user_mode+0x20/0x40 kernel/entry/common.c:302 do_syscall_64+0x49/0x90 arch/x86/entry/common.c:86 entry_SYSCALL_64_after_hwframe+0x44/0xae value changed: 0xffffffffffffff00 -> 0xfffffffffffffc00 Reported by Kernel Concurrency Sanitizer on: CPU: 0 PID: 29434 Comm: syz-executor.2 Not tainted 5.14.0-rc1-syzkaller #0 Hardware name: Google Google Compute Engine/Google Compute Engine, BIOS Google 01/01/2011 ==================================================================