Liu Shixin via Jfs-discussion
114ea3cb13
jfs: fix invalid free of JFS_IP(ipimap)->i_imap in diUnmount
...
[ Upstream commit 6e2bda2c192d0244b5a78b787ef20aa10cb319b7 ]
syzbot found an invalid-free in diUnmount:
BUG: KASAN: double-free in slab_free mm/slub.c:3661 [inline]
BUG: KASAN: double-free in __kmem_cache_free+0x71/0x110 mm/slub.c:3674
Free of addr ffff88806f410000 by task syz-executor131/3632
CPU: 0 PID: 3632 Comm: syz-executor131 Not tainted 6.1.0-rc7-syzkaller-00012-gca57f02295f1 #0
Hardware name: Google Google Compute Engine/Google Compute Engine, BIOS Google 10/26/2022
Call Trace:
<TASK>
__dump_stack lib/dump_stack.c:88 [inline]
dump_stack_lvl+0x1b1/0x28e lib/dump_stack.c:106
print_address_description+0x74/0x340 mm/kasan/report.c:284
print_report+0x107/0x1f0 mm/kasan/report.c:395
kasan_report_invalid_free+0xac/0xd0 mm/kasan/report.c:460
____kasan_slab_free+0xfb/0x120
kasan_slab_free include/linux/kasan.h:177 [inline]
slab_free_hook mm/slub.c:1724 [inline]
slab_free_freelist_hook+0x12e/0x1a0 mm/slub.c:1750
slab_free mm/slub.c:3661 [inline]
__kmem_cache_free+0x71/0x110 mm/slub.c:3674
diUnmount+0xef/0x100 fs/jfs/jfs_imap.c:195
jfs_umount+0x108/0x370 fs/jfs/jfs_umount.c:63
jfs_put_super+0x86/0x190 fs/jfs/super.c:194
generic_shutdown_super+0x130/0x310 fs/super.c:492
kill_block_super+0x79/0xd0 fs/super.c:1428
deactivate_locked_super+0xa7/0xf0 fs/super.c:332
cleanup_mnt+0x494/0x520 fs/namespace.c:1186
task_work_run+0x243/0x300 kernel/task_work.c:179
exit_task_work include/linux/task_work.h:38 [inline]
do_exit+0x664/0x2070 kernel/exit.c:820
do_group_exit+0x1fd/0x2b0 kernel/exit.c:950
__do_sys_exit_group kernel/exit.c:961 [inline]
__se_sys_exit_group kernel/exit.c:959 [inline]
__x64_sys_exit_group+0x3b/0x40 kernel/exit.c:959
do_syscall_x64 arch/x86/entry/common.c:50 [inline]
do_syscall_64+0x3d/0xb0 arch/x86/entry/common.c:80
entry_SYSCALL_64_after_hwframe+0x63/0xcd
[...]
JFS_IP(ipimap)->i_imap is not setting to NULL after free in diUnmount.
If jfs_remount() free JFS_IP(ipimap)->i_imap but then failed at diMount().
JFS_IP(ipimap)->i_imap will be freed once again.
Fix this problem by setting JFS_IP(ipimap)->i_imap to NULL after free.
Reported-by: syzbot+90a11e6b1e810785c6ff@syzkaller.appspotmail.com
Signed-off-by: Liu Shixin <liushixin2@huawei.com>
Signed-off-by: Dave Kleikamp <dave.kleikamp@oracle.com>
Signed-off-by: Sasha Levin <sashal@kernel.org>
2023-09-23 10:48:16 +02:00
..
2022-06-25 11:48:57 +02:00
2019-08-06 19:06:49 +02:00
2023-02-06 07:49:38 +01:00
2023-08-11 11:45:01 +02:00
2023-09-23 10:48:15 +02:00
2023-09-23 10:48:15 +02:00
2020-11-05 11:08:54 +01:00
2023-08-11 11:45:22 +02:00
2023-09-23 10:47:59 +02:00
2019-08-06 19:06:51 +02:00
2022-03-02 11:38:13 +01:00
2021-09-22 11:47:56 +02:00
2023-09-23 10:47:59 +02:00
2023-09-23 10:48:11 +02:00
2021-05-26 11:48:34 +02:00
2020-12-02 08:48:12 +01:00
2019-12-05 09:20:32 +01:00
2020-01-27 14:50:02 +01:00
2023-09-23 10:48:16 +02:00
2023-08-11 11:45:30 +02:00
2023-08-11 11:45:13 +02:00
2023-08-11 11:45:01 +02:00
2021-09-22 11:48:02 +02:00
2023-08-11 11:45:24 +02:00
2023-08-30 16:31:43 +02:00
2023-03-11 16:31:49 +01:00
2023-08-11 11:45:01 +02:00
2021-06-03 08:38:12 +02:00
2023-08-11 11:45:01 +02:00
2022-08-25 11:15:19 +02:00
2023-08-11 11:45:15 +02:00
2023-09-23 10:48:16 +02:00
2023-09-23 10:47:59 +02:00
2023-09-23 10:48:06 +02:00
2022-04-15 14:15:03 +02:00
2023-09-23 10:48:12 +02:00
2020-12-30 11:26:02 +01:00
2023-09-23 10:48:06 +02:00
2023-09-23 10:47:57 +02:00
2023-09-23 10:47:58 +02:00
2022-06-14 16:59:20 +02:00
2022-11-25 17:40:30 +01:00
2023-09-23 10:48:01 +02:00
2023-08-11 11:45:01 +02:00
2023-01-18 11:30:37 +01:00
2023-09-23 10:47:59 +02:00
2023-09-23 10:48:11 +02:00
2023-09-23 10:48:11 +02:00
2021-10-06 15:31:20 +02:00
2023-09-23 10:48:02 +02:00
2020-10-30 10:38:21 +01:00
2023-09-23 10:47:59 +02:00
2020-08-26 10:30:59 +02:00
2023-02-22 12:47:20 +01:00
2023-03-22 13:27:08 +01:00
2023-08-11 11:45:39 +02:00
2022-09-20 12:26:48 +02:00
2023-08-11 11:45:01 +02:00
2023-09-23 10:48:12 +02:00
2020-08-21 11:05:38 +02:00
2023-08-11 11:45:01 +02:00
2023-02-22 12:47:19 +01:00
2022-08-25 11:14:53 +02:00
2023-01-18 11:30:42 +01:00
2023-01-18 11:30:42 +01:00
2021-10-06 15:31:24 +02:00
2023-01-18 11:30:42 +01:00
2023-01-18 11:30:33 +01:00
2019-11-06 13:05:37 +01:00
2021-05-22 10:59:49 +02:00
2022-11-25 17:40:29 +01:00
2023-01-18 11:30:27 +01:00
2020-01-09 10:19:07 +01:00
2020-05-14 07:57:21 +02:00
2022-06-14 16:59:24 +02:00
2020-11-05 11:08:35 +01:00
2021-04-14 08:22:32 +02:00
2020-01-12 12:17:20 +01:00
2023-09-23 10:47:59 +02:00
2020-10-07 08:00:09 +02:00
2022-06-06 08:24:21 +02:00
2021-09-22 11:47:50 +02:00
2021-12-08 08:50:13 +01:00
2023-03-17 08:31:41 +01:00
2020-04-17 10:48:51 +02:00
2023-05-17 11:13:23 +02:00
2022-10-26 13:19:16 +02:00
2019-05-31 06:46:05 -07:00
2021-05-22 10:59:50 +02:00
2023-01-18 11:30:06 +01:00
2020-01-09 10:19:00 +01:00
2023-01-18 11:30:51 +01:00
2023-09-23 10:47:59 +02:00
2022-05-15 19:41:59 +02:00
2019-05-25 18:23:26 +02:00
2020-03-18 07:14:21 +01:00
2021-08-12 13:19:43 +02:00
2023-01-18 11:30:40 +01:00
2019-12-01 09:17:04 +01:00
2021-04-28 13:16:50 +02:00
2022-01-29 10:19:18 +01:00
2021-07-20 16:16:16 +02:00
2021-12-14 10:18:07 +01:00
2022-10-26 13:19:21 +02:00
2022-04-27 13:39:44 +02:00
2023-05-30 12:42:11 +01:00
2022-02-23 11:58:38 +01:00
2021-09-22 11:48:02 +02:00
2023-01-18 11:30:04 +01:00