Shijie Luo
af133ade9a
ext4: add cond_resched() to ext4_protect_reserved_inode
...
When journal size is set too big by "mkfs.ext4 -J size=", or when
we mount a crafted image to make journal inode->i_size too big,
the loop, "while (i < num)", holds cpu too long. This could cause
soft lockup.
[ 529.357541] Call trace:
[ 529.357551] dump_backtrace+0x0/0x198
[ 529.357555] show_stack+0x24/0x30
[ 529.357562] dump_stack+0xa4/0xcc
[ 529.357568] watchdog_timer_fn+0x300/0x3e8
[ 529.357574] __hrtimer_run_queues+0x114/0x358
[ 529.357576] hrtimer_interrupt+0x104/0x2d8
[ 529.357580] arch_timer_handler_virt+0x38/0x58
[ 529.357584] handle_percpu_devid_irq+0x90/0x248
[ 529.357588] generic_handle_irq+0x34/0x50
[ 529.357590] __handle_domain_irq+0x68/0xc0
[ 529.357593] gic_handle_irq+0x6c/0x150
[ 529.357595] el1_irq+0xb8/0x140
[ 529.357599] __ll_sc_atomic_add_return_acquire+0x14/0x20
[ 529.357668] ext4_map_blocks+0x64/0x5c0 [ext4]
[ 529.357693] ext4_setup_system_zone+0x330/0x458 [ext4]
[ 529.357717] ext4_fill_super+0x2170/0x2ba8 [ext4]
[ 529.357722] mount_bdev+0x1a8/0x1e8
[ 529.357746] ext4_mount+0x44/0x58 [ext4]
[ 529.357748] mount_fs+0x50/0x170
[ 529.357752] vfs_kern_mount.part.9+0x54/0x188
[ 529.357755] do_mount+0x5ac/0xd78
[ 529.357758] ksys_mount+0x9c/0x118
[ 529.357760] __arm64_sys_mount+0x28/0x38
[ 529.357764] el0_svc_common+0x78/0x130
[ 529.357766] el0_svc_handler+0x38/0x78
[ 529.357769] el0_svc+0x8/0xc
[ 541.356516] watchdog: BUG: soft lockup - CPU#0 stuck for 23s! [mount:18674]
Link: https://lore.kernel.org/r/20200211011752.29242-1-luoshijie1@huawei.com
Reviewed-by: Jan Kara <jack@suse.cz>
Signed-off-by: Shijie Luo <luoshijie1@huawei.com>
Signed-off-by: Theodore Ts'o <tytso@mit.edu>
Cc: stable@kernel.org
2020-02-13 11:56:26 -05:00
..
2018-12-10 00:22:38 -05:00
2017-12-17 22:00:59 -05:00
2019-12-26 11:28:31 -05:00
2017-11-02 11:10:55 +01:00
2020-02-13 11:56:26 -05:00
2020-02-13 11:56:19 -05:00
2020-01-17 16:24:54 -05:00
2020-01-17 16:24:52 -05:00
2020-01-17 16:24:52 -05:00
2020-02-13 11:56:19 -05:00
2019-08-28 11:19:23 -04:00
2020-01-25 02:03:03 -05:00
2020-01-23 12:02:15 -05:00
2019-12-26 11:57:18 -05:00
2019-05-12 04:49:47 -04:00
2017-12-17 22:00:59 -05:00
2019-11-05 11:31:40 -05:00
2019-09-03 01:43:17 -04:00
2019-12-26 11:28:31 -05:00
2020-01-17 16:24:54 -05:00
2020-01-25 02:24:53 -05:00
2020-01-09 16:42:29 -07:00
2020-02-13 11:56:19 -05:00
2020-01-17 16:24:55 -05:00
2020-01-30 15:17:05 -08:00
2020-01-09 16:42:29 -07:00
2019-12-26 11:28:23 -05:00
2017-12-17 22:00:59 -05:00
2019-11-05 16:00:49 -05:00
2020-02-13 11:53:10 -05:00
2019-06-20 17:26:26 -04:00
2020-02-13 11:56:19 -05:00
2020-01-17 16:24:54 -05:00
2020-01-17 16:24:54 -05:00
2020-01-17 16:24:55 -05:00
2020-02-13 11:54:08 -05:00
2018-01-11 22:10:40 -05:00
2019-12-26 11:29:10 -05:00
2018-07-29 17:00:22 -04:00
2020-01-14 13:27:32 -08:00
2018-05-10 11:52:14 -04:00
2017-11-02 11:10:55 +01:00
2017-11-02 11:10:55 +01:00
2020-01-17 16:24:55 -05:00
2018-03-30 20:04:11 -04:00