btrfs-progs: qgroup: move btrfs_show_qgroups's error handler to __qgroup_search
authorLu Fengqi <lufq.fnst@cn.fujitsu.com>
Mon, 13 Nov 2017 05:33:15 +0000 (13:33 +0800)
committerDavid Sterba <dsterba@suse.com>
Mon, 8 Jan 2018 18:22:43 +0000 (19:22 +0100)
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 <lufq.fnst@cn.fujitsu.com>
Signed-off-by: David Sterba <dsterba@suse.com>
cmds-qgroup.c
qgroup.c

index 38382ea..d07bb0c 100644 (file)
@@ -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:
index 156825f..23463d8 100644 (file)
--- 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)