On 2021/3/16 下午9:27, Sidong Yang wrote:
When user assign qgroup with qgroup id that is too big to exceeds range and invade level value, and it works without any error. but this action would be make undefined error. this code make sure that qgroup id doesn't exceed range(0 ~ 2^48-1). Signed-off-by: Sidong Yang <realwa...@gmail.com>
Reviewed-by: Qu Wenruo <w...@suse.com> Thanks, Qu
--- v2: Use btrfs_qgroup_level() for checking --- common/utils.c | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/common/utils.c b/common/utils.c index 57e41432..ba0bcb24 100644 --- a/common/utils.c +++ b/common/utils.c @@ -727,6 +727,8 @@ u64 parse_qgroupid(const char *p) id = strtoull(p, &ptr_parse_end, 10); if (ptr_parse_end != ptr_src_end) goto path; + if (btrfs_qgroup_level(id)) + goto err; return id; } level = strtoull(p, &ptr_parse_end, 10); @@ -734,6 +736,9 @@ u64 parse_qgroupid(const char *p) goto path; id = strtoull(s + 1, &ptr_parse_end, 10); + if (btrfs_qgroup_level(id)) + goto err; + if (ptr_parse_end != ptr_src_end) goto path;