kernel_samsung_a53x/fs/nilfs2
Ryusuke Konishi 7d7e891e2f nilfs2: fix potential hang in nilfs_detach_log_writer()
commit eb85dace897c5986bc2f36b3c783c6abb8a4292e upstream.

Syzbot has reported a potential hang in nilfs_detach_log_writer() called
during nilfs2 unmount.

Analysis revealed that this is because nilfs_segctor_sync(), which
synchronizes with the log writer thread, can be called after
nilfs_segctor_destroy() terminates that thread, as shown in the call trace
below:

nilfs_detach_log_writer
  nilfs_segctor_destroy
    nilfs_segctor_kill_thread  --> Shut down log writer thread
    flush_work
      nilfs_iput_work_func
        nilfs_dispose_list
          iput
            nilfs_evict_inode
              nilfs_transaction_commit
                nilfs_construct_segment (if inode needs sync)
                  nilfs_segctor_sync  --> Attempt to synchronize with
                                          log writer thread
                           *** DEADLOCK ***

Fix this issue by changing nilfs_segctor_sync() so that the log writer
thread returns normally without synchronizing after it terminates, and by
forcing tasks that are already waiting to complete once after the thread
terminates.

The skipped inode metadata flushout will then be processed together in the
subsequent cleanup work in nilfs_segctor_destroy().

Link: https://lkml.kernel.org/r/20240520132621.4054-4-konishi.ryusuke@gmail.com
Signed-off-by: Ryusuke Konishi <konishi.ryusuke@gmail.com>
Reported-by: syzbot+e3973c409251e136fdd0@syzkaller.appspotmail.com
Closes: https://syzkaller.appspot.com/bug?extid=e3973c409251e136fdd0
Tested-by: Ryusuke Konishi <konishi.ryusuke@gmail.com>
Cc: <stable@vger.kernel.org>
Cc: "Bai, Shuangpeng" <sjb7183@psu.edu>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
2024-11-19 12:26:51 +01:00
..
alloc.c Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
alloc.h Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
bmap.c Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
bmap.h Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
btnode.c Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
btnode.h Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
btree.c nilfs2: fix failure to detect DAT corruption in btree and direct mappings 2024-11-19 09:22:36 +01:00
btree.h Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
cpfile.c Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
cpfile.h Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
dat.c nilfs2: replace WARN_ONs for invalid DAT metadata block requests 2024-11-18 12:13:40 +01:00
dat.h Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
dir.c nilfs2: fix OOB in nilfs_set_de_type 2024-11-19 11:32:23 +01:00
direct.c nilfs2: fix failure to detect DAT corruption in btree and direct mappings 2024-11-19 09:22:36 +01:00
direct.h Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
export.h Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
file.c nilfs2: fix hang in nilfs_lookup_dirty_data_buffers() 2024-11-18 12:13:32 +01:00
gcinode.c Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
ifile.c Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
ifile.h Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
inode.c nilfs2: prevent kernel bug at submit_bh_wbc() 2024-11-19 09:22:36 +01:00
ioctl.c Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
Kconfig Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
Makefile Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
mdt.c Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
mdt.h Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
namei.c Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
nilfs.h Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
page.c Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
page.h Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
recovery.c nilfs2: fix data corruption in dsync block recovery for small block sizes 2024-11-18 12:13:32 +01:00
segbuf.c Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
segbuf.h Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
segment.c nilfs2: fix potential hang in nilfs_detach_log_writer() 2024-11-19 12:26:51 +01:00
segment.h Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
sufile.c nilfs2: prevent WARNING in nilfs_sufile_set_segment_usage() 2024-11-18 12:11:41 +01:00
sufile.h Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
super.c Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
sysfs.c Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
sysfs.h Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00
the_nilfs.c nilfs2: fix missing error check for sb_set_blocksize call 2024-11-18 12:11:41 +01:00
the_nilfs.h Import A536BXXU9EXDC 2024-06-15 16:02:09 -03:00