From: Lu Fengqi Date: Mon, 13 Nov 2017 05:33:15 +0000 (+0800) Subject: btrfs-progs: qgroup: move btrfs_show_qgroups's error handler to __qgroup_search X-Git-Tag: upstream/4.16.1~214 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=f0445b8a344b496e6c070c733e445bf79a8fad58;p=platform%2Fupstream%2Fbtrfs-progs.git btrfs-progs: qgroup: move btrfs_show_qgroups's error handler to __qgroup_search We have to process the return value of BTRFS_IOC_TREE_SEARCH ioctl in advance, so that we can distinguish between the two case where quota is not enabled (ioctl return -ENOENT) and either parent qgroup or child qgroup does not exist (update_qgroup_relation return -ENOENT). Besides this, any error in this routine has been reported, so we don't need to report again in cmd_qgroup_show. Signed-off-by: Lu Fengqi Signed-off-by: David Sterba --- diff --git a/cmds-qgroup.c b/cmds-qgroup.c index 38382ea..d07bb0c 100644 --- a/cmds-qgroup.c +++ b/cmds-qgroup.c @@ -399,10 +399,6 @@ static int cmd_qgroup_show(int argc, char **argv) qgroupid); } ret = btrfs_show_qgroups(fd, filter_set, comparer_set); - if (ret == -ENOENT) - error("can't list qgroups: quotas not enabled"); - else if (ret < 0) - error("can't list qgroups: %s", strerror(-ret)); close_file_or_dir(fd, dirstream); out: diff --git a/qgroup.c b/qgroup.c index 156825f..23463d8 100644 --- a/qgroup.c +++ b/qgroup.c @@ -1065,8 +1065,18 @@ static int __qgroups_search(int fd, struct qgroup_lookup *qgroup_lookup) while (1) { ret = ioctl(fd, BTRFS_IOC_TREE_SEARCH, &args); - if (ret < 0) - return -errno; + if (ret < 0) { + if (errno == ENOENT) { + error("can't list qgroups: quotas not enabled"); + ret = -ENOTTY; + } else { + error("can't list qgroups: %s", + strerror(errno)); + ret = -errno; + } + + break; + } /* the ioctl returns the number of item it found in nr_items */ if (sk->nr_items == 0)