possible deadlock in ocfs2_reserve_suballoc_bits
From: Liebes Wang
Date: Tue Dec 31 2024 - 01:02:59 EST
Dear Linux maintainers and reviewers:
We are reporting a Linux kernel bug titled **possible deadlock in ocfs2_reserve_suballoc_bits**, discovered using a modified version of Syzkaller.
Linux version: v6.12-rc6:59b723cd2adbac2a34fc8e12c74ae26ae45bf230 (crash is also reproduced in the latest kernel version)
The test case and kernel config is in attach.
The report is (The full report is attached):
WARNING: possible circular locking dependency detected
6.12.0-rc6 #1 Not tainted
------------------------------------------------------
syz.3.114/4759 is trying to acquire lock:
ff1100015293b480 (&ocfs2_sysfile_lock_key[args->fi_sysfile_type]#5){+.+.}-{3:3}, at: inode_lock include/linux/fs.h:815 [inline]
ff1100015293b480 (&ocfs2_sysfile_lock_key[args->fi_sysfile_type]#5){+.+.}-{3:3}, at: ocfs2_xattr_set+0xe5a/0x27b0 fs/ocfs2/xattr.c:3623
but task is already holding lock:
ff1100015e045c78 (&oi->ip_xattr_sem){++++}-{3:3}, at: ocfs2_xattr_set+0x3e2/0x27b0 fs/ocfs2/xattr.c:3584
which lock already depends on the new lock.
the existing dependency chain (in reverse order) is:
-> #2 (&oi->ip_xattr_sem){++++}-{3:3}:
down_read+0x9a/0x320 kernel/locking/rwsem.c:1524
ocfs2_init_acl+0x2f7/0x7d0 fs/ocfs2/acl.c:366
ocfs2_mknod+0xdac/0x24c0 fs/ocfs2/namei.c:408
ocfs2_create+0x167/0x420 fs/ocfs2/namei.c:672
lookup_open.isra.0+0x106e/0x1450 fs/namei.c:3595
open_last_lookups fs/namei.c:3694 [inline]
path_openat+0xcb9/0x2940 fs/namei.c:3930
do_filp_open+0x1c7/0x410 fs/namei.c:3960
do_sys_openat2+0x164/0x1d0 fs/open.c:1415
do_sys_open fs/open.c:1430 [inline]
__do_sys_openat fs/open.c:1446 [inline]
__se_sys_openat fs/open.c:1441 [inline]
__x64_sys_openat+0x140/0x1f0 fs/open.c:1441
do_syscall_x64 arch/x86/entry/common.c:52 [inline]
do_syscall_64+0xc1/0x1d0 arch/x86/entry/common.c:83
entry_SYSCALL_64_after_hwframe+0x77/0x7f
-> #1 (jbd2_handle){++++}-{0:0}:
jbd2_journal_lock_updates+0xa5/0x310 fs/jbd2/transaction.c:865
__ocfs2_flush_truncate_log+0x27d/0x11d0 fs/ocfs2/alloc.c:6029
ocfs2_flush_truncate_log+0x4d/0x70 fs/ocfs2/alloc.c:6076
ocfs2_sync_fs+0x1ca/0x3d0 fs/ocfs2/super.c:402
sync_filesystem+0x1d3/0x2a0 fs/sync.c:66
ocfs2_remount+0xb0/0xcb0 fs/ocfs2/super.c:611
legacy_reconfigure+0x11d/0x190 fs/fs_context.c:685
reconfigure_super+0x372/0xba0 fs/super.c:1083
do_remount fs/namespace.c:3047 [inline]
path_mount+0x189d/0x1eb0 fs/namespace.c:3826
do_mount fs/namespace.c:3847 [inline]
__do_sys_mount fs/namespace.c:4057 [inline]
__se_sys_mount fs/namespace.c:4034 [inline]
__x64_sys_mount+0x283/0x300 fs/namespace.c:4034
do_syscall_x64 arch/x86/entry/common.c:52 [inline]
do_syscall_64+0xc1/0x1d0 arch/x86/entry/common.c:83
entry_SYSCALL_64_after_hwframe+0x77/0x7f
-> #0 (&ocfs2_sysfile_lock_key[args->fi_sysfile_type]#5){+.+.}-{3:3}:
check_prev_add kernel/locking/lockdep.c:3161 [inline]
check_prevs_add kernel/locking/lockdep.c:3280 [inline]
validate_chain kernel/locking/lockdep.c:3904 [inline]
__lock_acquire+0x2381/0x3a20 kernel/locking/lockdep.c:5202
lock_acquire kernel/locking/lockdep.c:5825 [inline]
lock_acquire+0x19d/0x530 kernel/locking/lockdep.c:5790
down_write+0x92/0x1f0 kernel/locking/rwsem.c:1577
inode_lock include/linux/fs.h:815 [inline]
ocfs2_xattr_set+0xe5a/0x27b0 fs/ocfs2/xattr.c:3623
ocfs2_set_acl+0x46f/0x530 fs/ocfs2/acl.c:254
ocfs2_iop_set_acl+0x1d2/0x270 fs/ocfs2/acl.c:286
set_posix_acl+0x25e/0x330 fs/posix_acl.c:955
vfs_set_acl+0x5b7/0x920 fs/posix_acl.c:1134
do_set_acl+0xd9/0x1a0 fs/posix_acl.c:1279
do_setxattr+0xdf/0x1e0 fs/xattr.c:626
path_setxattr+0x209/0x260 fs/xattr.c:658
__do_sys_setxattr fs/xattr.c:676 [inline]
__se_sys_setxattr fs/xattr.c:672 [inline]
__x64_sys_setxattr+0xc4/0x160 fs/xattr.c:672
loop0: detected capacity change from 0 to 32768
do_syscall_x64 arch/x86/entry/common.c:52 [inline]
do_syscall_64+0xc1/0x1d0 arch/x86/entry/common.c:83
entry_SYSCALL_64_after_hwframe+0x77/0x7f
other info that might help us debug this:
Chain exists of:
&ocfs2_sysfile_lock_key[args->fi_sysfile_type]#5 --> jbd2_handle --> &oi->ip_xattr_sem
Possible unsafe locking scenario:
CPU0 CPU1
---- ----
lock(&oi->ip_xattr_sem);
lock(jbd2_handle);
lock(&oi->ip_xattr_sem);
lock(&ocfs2_sysfile_lock_key[args->fi_sysfile_type]#5);
*** DEADLOCK ***
3 locks held by syz.3.114/4759:
#0: ff1100012f4763f8 (sb_writers#28){.+.+}-{0:0}, at: path_setxattr+0x12d/0x260 fs/xattr.c:656
#1: ff1100015e045f40 (&sb->s_type->i_mutex_key#30){+.+.}-{3:3}, at: inode_lock include/linux/fs.h:815 [inline]
#1: ff1100015e045f40 (&sb->s_type->i_mutex_key#30){+.+.}-{3:3}, at: vfs_set_acl+0x351/0x920 fs/posix_acl.c:1115
#2: ff1100015e045c78 (&oi->ip_xattr_sem){++++}-{3:3}, at: ocfs2_xattr_set+0x3e2/0x27b0 fs/ocfs2/xattr.c:3584
stack backtrace:
CPU: 1 UID: 0 PID: 4759 Comm: syz.3.114 Not tainted 6.12.0-rc6 #1
Hardware name: QEMU Standard PC (i440FX + PIIX, 1996), BIOS 1.13.0-1ubuntu1.1 04/01/2014
Call Trace:
<TASK>
__dump_stack lib/dump_stack.c:94 [inline]
dump_stack_lvl+0xca/0x120 lib/dump_stack.c:120
print_circular_bug+0x53f/0x820 kernel/locking/lockdep.c:2074
check_noncircular+0x2f9/0x3e0 kernel/locking/lockdep.c:2206
check_prev_add kernel/locking/lockdep.c:3161 [inline]
check_prevs_add kernel/locking/lockdep.c:3280 [inline]
validate_chain kernel/locking/lockdep.c:3904 [inline]
__lock_acquire+0x2381/0x3a20 kernel/locking/lockdep.c:5202
lock_acquire kernel/locking/lockdep.c:5825 [inline]
lock_acquire+0x19d/0x530 kernel/locking/lockdep.c:5790
down_write+0x92/0x1f0 kernel/locking/rwsem.c:1577
inode_lock include/linux/fs.h:815 [inline]
ocfs2_xattr_set+0xe5a/0x27b0 fs/ocfs2/xattr.c:3623
ocfs2_set_acl+0x46f/0x530 fs/ocfs2/acl.c:254
ocfs2_iop_set_acl+0x1d2/0x270 fs/ocfs2/acl.c:286
set_posix_acl+0x25e/0x330 fs/posix_acl.c:955
vfs_set_acl+0x5b7/0x920 fs/posix_acl.c:1134
do_set_acl+0xd9/0x1a0 fs/posix_acl.c:1279
do_setxattr+0xdf/0x1e0 fs/xattr.c:626
path_setxattr+0x209/0x260 fs/xattr.c:658
__do_sys_setxattr fs/xattr.c:676 [inline]
__se_sys_setxattr fs/xattr.c:672 [inline]
__x64_sys_setxattr+0xc4/0x160 fs/xattr.c:672
do_syscall_x64 arch/x86/entry/common.c:52 [inline]
do_syscall_64+0xc1/0x1d0 arch/x86/entry/common.c:83
entry_SYSCALL_64_after_hwframe+0x77/0x7f
Attachment:
repro.c
Description: Binary data
Attachment:
report0
Description: Binary data
Attachment:
config
Description: Binary data