===================================== WARNING: bad unlock balance detected! 6.3.0-rc2-next-20230316-syzkaller #0 Not tainted ------------------------------------- syz-executor.1/15077 is trying to release lock (&type->i_mutex_dir_key) at: [] inode_unlock include/linux/fs.h:766 [inline] [] ext4_rename+0x569/0x27c0 fs/ext4/namei.c:4029 but there are no more locks to release! other info that might help us debug this: 3 locks held by syz-executor.1/15077: #0: ffff888073304460 (sb_writers#4){.+.+}-{0:0}, at: do_renameat2+0x37f/0xc90 fs/namei.c:4859 #1: ffff888077168400 (&type->i_mutex_dir_key#3/1){+.+.}-{3:3}, at: inode_lock_nested include/linux/fs.h:796 [inline] #1: ffff888077168400 (&type->i_mutex_dir_key#3/1){+.+.}-{3:3}, at: lock_rename+0x229/0x280 fs/namei.c:2991 #2: ffff888079865440 (&type->i_mutex_dir_key#3){++++}-{3:3}, at: inode_lock include/linux/fs.h:761 [inline] #2: ffff888079865440 (&type->i_mutex_dir_key#3){++++}-{3:3}, at: vfs_rename+0x4f9/0x17a0 fs/namei.c:4744 stack backtrace: CPU: 1 PID: 15077 Comm: syz-executor.1 Not tainted 6.3.0-rc2-next-20230316-syzkaller #0 Hardware name: Google Google Compute Engine/Google Compute Engine, BIOS Google 03/02/2023 Call Trace: __dump_stack lib/dump_stack.c:88 [inline] dump_stack_lvl+0xd9/0x150 lib/dump_stack.c:106 __lock_release kernel/locking/lockdep.c:5368 [inline] lock_release+0x4f1/0x670 kernel/locking/lockdep.c:5711 up_write+0x2a/0x520 kernel/locking/rwsem.c:1625 inode_unlock include/linux/fs.h:766 [inline] ext4_rename+0x569/0x27c0 fs/ext4/namei.c:4029 ext4_rename2+0x1c7/0x270 fs/ext4/namei.c:4202 vfs_rename+0xef6/0x17a0 fs/namei.c:4772 do_renameat2+0xb62/0xc90 fs/namei.c:4923 __do_sys_renameat2 fs/namei.c:4956 [inline] __se_sys_renameat2 fs/namei.c:4953 [inline] __x64_sys_renameat2+0xe8/0x120 fs/namei.c:4953 do_syscall_x64 arch/x86/entry/common.c:50 [inline] do_syscall_64+0x39/0xb0 arch/x86/entry/common.c:80 entry_SYSCALL_64_after_hwframe+0x63/0xcd RIP: 0033:0x7f3c92a8c0f9 Code: 28 00 00 00 75 05 48 83 c4 28 c3 e8 f1 19 00 00 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 73 01 c3 48 c7 c1 b8 ff ff ff f7 d8 64 89 01 48 RSP: 002b:00007f3c938af168 EFLAGS: 00000246 ORIG_RAX: 000000000000013c RAX: ffffffffffffffda RBX: 00007f3c92bac050 RCX: 00007f3c92a8c0f9 RDX: 0000000000000004 RSI: 00000000200001c0 RDI: 0000000000000004 RBP: 00007f3c92ae7b39 R08: 0000000000000000 R09: 0000000000000000 R10: 0000000020000200 R11: 0000000000000246 R12: 0000000000000000 R13: 00007ffc92c6bc1f R14: 00007f3c938af300 R15: 0000000000022000 ------------[ cut here ]------------ DEBUG_RWSEMS_WARN_ON((rwsem_owner(sem) != current) && !rwsem_test_oflags(sem, RWSEM_NONSPINNABLE)): count = 0x0, magic = 0xffff888077193fc0, owner = 0x0, curr 0xffff8880442857c0, list empty WARNING: CPU: 1 PID: 15077 at kernel/locking/rwsem.c:1369 __up_write kernel/locking/rwsem.c:1369 [inline] WARNING: CPU: 1 PID: 15077 at kernel/locking/rwsem.c:1369 up_write+0x425/0x520 kernel/locking/rwsem.c:1626 Modules linked in: CPU: 1 PID: 15077 Comm: syz-executor.1 Not tainted 6.3.0-rc2-next-20230316-syzkaller #0 Hardware name: Google Google Compute Engine/Google Compute Engine, BIOS Google 03/02/2023 RIP: 0010:__up_write kernel/locking/rwsem.c:1369 [inline] RIP: 0010:up_write+0x425/0x520 kernel/locking/rwsem.c:1626 Code: 3c 02 00 0f 85 da 00 00 00 48 8b 55 00 4d 89 f1 53 4d 89 f8 4c 89 e9 48 c7 c6 20 57 4c 8a 48 c7 c7 40 56 4c 8a e8 4b e8 e7 ff <0f> 0b 59 e9 dd fc ff ff 48 89 df e8 fb 04 72 00 e9 1a fc ff ff 48 RSP: 0018:ffffc90006cc79a0 EFLAGS: 00010282 RAX: 0000000000000000 RBX: ffffffff8a4c5580 RCX: ffffc900142b7000 RDX: 0000000000040000 RSI: ffffffff814b45d7 RDI: 0000000000000001 RBP: ffff888077193fc0 R08: 0000000000000001 R09: 0000000000000000 R10: 0000000000000001 R11: 57525f4755424544 R12: ffff888077193fc8 R13: ffff888077193fc0 R14: ffff8880442857c0 R15: 0000000000000000 FS: 00007f3c938af700(0000) GS:ffff8880b9900000(0000) knlGS:0000000000000000 CS: 0010 DS: 0000 ES: 0000 CR0: 0000000080050033 CR2: 0000001b32b35000 CR3: 000000001da6e000 CR4: 00000000003506e0 DR0: 0000000000000000 DR1: 0000000000000000 DR2: 0000000000000000 DR3: 0000000000000000 DR6: 00000000fffe0ff0 DR7: 0000000000000400 Call Trace: inode_unlock include/linux/fs.h:766 [inline] ext4_rename+0x569/0x27c0 fs/ext4/namei.c:4029 ext4_rename2+0x1c7/0x270 fs/ext4/namei.c:4202 vfs_rename+0xef6/0x17a0 fs/namei.c:4772 do_renameat2+0xb62/0xc90 fs/namei.c:4923 __do_sys_renameat2 fs/namei.c:4956 [inline] __se_sys_renameat2 fs/namei.c:4953 [inline] __x64_sys_renameat2+0xe8/0x120 fs/namei.c:4953 do_syscall_x64 arch/x86/entry/common.c:50 [inline] do_syscall_64+0x39/0xb0 arch/x86/entry/common.c:80 entry_SYSCALL_64_after_hwframe+0x63/0xcd RIP: 0033:0x7f3c92a8c0f9 Code: 28 00 00 00 75 05 48 83 c4 28 c3 e8 f1 19 00 00 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 73 01 c3 48 c7 c1 b8 ff ff ff f7 d8 64 89 01 48 RSP: 002b:00007f3c938af168 EFLAGS: 00000246 ORIG_RAX: 000000000000013c RAX: ffffffffffffffda RBX: 00007f3c92bac050 RCX: 00007f3c92a8c0f9 RDX: 0000000000000004 RSI: 00000000200001c0 RDI: 0000000000000004 RBP: 00007f3c92ae7b39 R08: 0000000000000000 R09: 0000000000000000 R10: 0000000020000200 R11: 0000000000000246 R12: 0000000000000000 R13: 00007ffc92c6bc1f R14: 00007f3c938af300 R15: 0000000000022000