ChenXiaoSong
f4b930a160
btrfs: qgroup: fix sleep from invalid context bug in btrfs_qgroup_inherit()
...
[ Upstream commit f7e942b5bb35d8e3af54053d19a6bf04143a3955 ]
Syzkaller reported BUG as follows:
BUG: sleeping function called from invalid context at
include/linux/sched/mm.h:274
Call Trace:
<TASK>
dump_stack_lvl+0xcd/0x134
__might_resched.cold+0x222/0x26b
kmem_cache_alloc+0x2e7/0x3c0
update_qgroup_limit_item+0xe1/0x390
btrfs_qgroup_inherit+0x147b/0x1ee0
create_subvol+0x4eb/0x1710
btrfs_mksubvol+0xfe5/0x13f0
__btrfs_ioctl_snap_create+0x2b0/0x430
btrfs_ioctl_snap_create_v2+0x25a/0x520
btrfs_ioctl+0x2a1c/0x5ce0
__x64_sys_ioctl+0x193/0x200
do_syscall_64+0x35/0x80
Fix this by calling qgroup_dirty() on @dstqgroup, and update limit item in
btrfs_run_qgroups() later outside of the spinlock context.
CC: stable@vger.kernel.org # 4.9+
Reviewed-by: Qu Wenruo <wqu@suse.com>
Signed-off-by: ChenXiaoSong <chenxiaosong2@huawei.com>
Reviewed-by: David Sterba <dsterba@suse.com>
Signed-off-by: David Sterba <dsterba@suse.com>
Signed-off-by: Sasha Levin <sashal@kernel.org>
2022-12-08 11:18:33 +01:00
..
2022-06-25 11:48:57 +02:00
2019-08-06 19:06:49 +02:00
2021-03-04 09:39:55 +01:00
2022-07-02 16:27:33 +02:00
2019-12-13 08:51:01 +01:00
2018-12-01 09:37:27 +01:00
2022-12-08 11:18:33 +01:00
2020-11-05 11:08:54 +01:00
2022-12-08 11:18:31 +01:00
2022-11-25 17:40:25 +01:00
2019-08-06 19:06:51 +02:00
2022-03-02 11:38:13 +01:00
2018-11-13 11:08:55 -08:00
2021-09-22 11:47:56 +02:00
2022-09-15 12:17:05 +02:00
2019-03-23 20:09:59 +01:00
2022-10-26 13:19:21 +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
2022-08-25 11:14:58 +02:00
2022-11-10 17:46:55 +01:00
2022-10-26 13:19:35 +02:00
2022-06-14 16:59:18 +02:00
2021-09-22 11:48:02 +02:00
2022-08-25 11:14:55 +02:00
2022-11-25 17:40:29 +01:00
2021-07-31 08:22:38 +02:00
2021-05-22 10:59:45 +02:00
2021-06-03 08:38:12 +02:00
2021-11-12 14:40:50 +01:00
2022-08-25 11:15:19 +02:00
2022-06-14 16:59:33 +02:00
2022-06-14 16:59:17 +02:00
2022-11-03 23:52:29 +09:00
2020-12-30 11:25:59 +01:00
2022-04-15 14:15:03 +02:00
2022-11-25 17:40:22 +01:00
2020-12-30 11:26:02 +01:00
2022-10-26 13:19:36 +02:00
2022-12-08 11:18:31 +01:00
2022-06-14 16:59:20 +02:00
2022-11-25 17:40:30 +01:00
2022-11-03 23:52:24 +09:00
2022-01-27 09:04:13 +01:00
2022-08-25 11:14:54 +02:00
2022-11-03 23:52:27 +09:00
2021-03-04 09:39:54 +01:00
2021-10-06 15:31:20 +02:00
2022-10-26 13:19:21 +02:00
2020-10-30 10:38:21 +01:00
2021-08-12 13:19:44 +02:00
2020-08-26 10:30:59 +02:00
2021-05-22 10:59:45 +02:00
2022-03-23 09:10:42 +01:00
2018-12-17 09:24:30 +01:00
2022-09-20 12:26:48 +02:00
2022-04-15 14:15:00 +02:00
2022-11-25 17:40:19 +01:00
2020-08-21 11:05:38 +02:00
2022-07-12 16:29:02 +02:00
2021-12-14 10:18:07 +01:00
2022-08-25 11:14:53 +02:00
2021-10-06 15:31:24 +02:00
2022-06-14 16:59:13 +02:00
2021-03-17 16:43:51 +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
2020-01-14 20:06:57 +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
2020-02-11 04:34:08 -08: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
2022-03-02 11:38:15 +01:00
2020-04-17 10:48:51 +02:00
2022-06-14 16:59:27 +02:00
2022-10-26 13:19:16 +02:00
2019-05-31 06:46:05 -07:00
2018-11-21 09:19:14 +01:00
2021-05-22 10:59:50 +02:00
2020-11-24 13:27:23 +01:00
2020-01-09 10:19:00 +01:00
2022-11-25 17:40:29 +01: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
2020-05-02 17:26:01 +02: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
2019-10-11 18:21:39 +02:00
2022-02-23 11:58:38 +01:00
2021-09-22 11:48:02 +02:00
2020-08-11 15:32:34 +02:00