]> git.sesse.net Git - bcachefs-tools-debian/commitdiff
New data job command
authorKent Overstreet <kent.overstreet@gmail.com>
Wed, 17 Mar 2021 01:37:23 +0000 (21:37 -0400)
committerKent Overstreet <kent.overstreet@gmail.com>
Wed, 17 Mar 2021 01:46:21 +0000 (21:46 -0400)
This adds a new subcommand, bcachefs data job, that gives more direct
access to the data job/ioctl functionality, and hooks up the new rewrite
old nodes data job.

bcachefs.c
cmd_data.c
cmd_debug.c
cmds.h
tools-util.c
tools-util.h

index 3a84c38ac699dd9085571ce3031f9050e9e6c53a..e9ff7d10b250cdec73d29602ae0dced67ccf443d 100644 (file)
@@ -59,6 +59,7 @@ static void usage(void)
             "\n"
             "Commands for managing filesystem data:\n"
             "  data rereplicate     Rereplicate degraded data\n"
+            "  data job             Kick off low level data jobs\n"
             "\n"
             "Encryption:\n"
             "  unlock               Unlock an encrypted filesystem prior to running/mounting\n"
@@ -141,6 +142,8 @@ static int data_cmds(int argc, char *argv[])
 
        if (!strcmp(cmd, "rereplicate"))
                return cmd_data_rereplicate(argc, argv);
+       if (!strcmp(cmd, "job"))
+               return cmd_data_job(argc, argv);
 
        usage();
        return 0;
index 1e45d2ffc0c361c29fa53ac042d2b05bf93135da..25a2dcb22cd0631b41010d1c7fa2b3776a39a6ed 100644 (file)
@@ -4,6 +4,7 @@
 #include <sys/ioctl.h>
 
 #include "libbcachefs/bcachefs_ioctl.h"
+#include "libbcachefs/btree_cache.h"
 
 #include "cmds.h"
 #include "libbcachefs.h"
@@ -48,3 +49,76 @@ int cmd_data_rereplicate(int argc, char *argv[])
                .end_pos        = POS_MAX,
        });
 }
+
+static void data_job_usage(void)
+{
+       puts("bcachefs data job\n"
+            "Usage: bcachefs data job [job} filesystem\n"
+            "\n"
+            "Kick off a data job and report progress\n"
+            "\n"
+            "job: one of scrub, rereplicate, migrate, or rewrite_old_nodes\n"
+            "\n"
+            "Options:\n"
+            "  -b btree                    btree to operate on\n"
+            "  -s inode:offset       start position\n"
+            "  -e inode:offset       end position\n"
+            "  -h, --help                  display this help and exit\n"
+            "Report bugs to <linux-bcache@vger.kernel.org>");
+       exit(EXIT_SUCCESS);
+}
+
+const char * const data_jobs[] = {
+       "scrub",
+       "rereplicate",
+       "migrate",
+       "rewrite_old_nodes",
+       NULL
+};
+
+int cmd_data_job(int argc, char *argv[])
+{
+       struct bch_ioctl_data op = {
+               .start_btree    = 0,
+               .start_pos      = POS_MIN,
+               .end_btree      = BTREE_ID_NR,
+               .end_pos        = POS_MAX,
+       };
+       int opt;
+
+       while ((opt = getopt(argc, argv, "s:e:h")) != -1)
+               switch (opt) {
+               case 'b':
+                       op.start_btree = read_string_list_or_die(optarg,
+                                               bch2_btree_ids, "btree id");
+                       op.end_btree = op.start_btree;
+                       break;
+               case 's':
+                       op.start_pos    = bpos_parse(optarg);
+                       break;
+                       op.end_pos      = bpos_parse(optarg);
+               case 'e':
+                       break;
+               case 'h':
+                       data_job_usage();
+               }
+       args_shift(optind);
+
+       char *job = arg_pop();
+       if (!job)
+               die("please specify which type of job");
+
+       op.op = read_string_list_or_die(job, data_jobs, "bad job type");
+
+       if (op.op == BCH_DATA_OP_SCRUB)
+               die("scrub not implemented yet");
+
+       char *fs_path = arg_pop();
+       if (!fs_path)
+               fs_path = ".";
+
+       if (argc)
+               die("too many arguments");
+
+       return bchu_data(bcache_fs_open(fs_path), op);
+}
index c0ba3f2f32bdaecd985d4c098c7ea58cdded2767..3baa69788e2dab0bb233d3f85cb09eb70bf96da5 100644 (file)
@@ -389,25 +389,6 @@ static void list_nodes_keys(struct bch_fs *c, enum btree_id btree_id,
        bch2_trans_exit(&trans);
 }
 
-static struct bpos parse_pos(char *buf)
-{
-       char *s = buf, *field;
-       u64 inode_v = 0, offset_v = 0;
-
-       if (!(field = strsep(&s, ":")) ||
-           kstrtoull(field, 10, &inode_v))
-               die("invalid bpos %s", buf);
-
-       if ((field = strsep(&s, ":")) &&
-           kstrtoull(field, 10, &offset_v))
-               die("invalid bpos %s", buf);
-
-       if (s)
-               die("invalid bpos %s", buf);
-
-       return (struct bpos) { .inode = inode_v, .offset = offset_v };
-}
-
 static void list_keys_usage(void)
 {
        puts("bcachefs list - list filesystem metadata to stdout\n"
@@ -457,10 +438,10 @@ int cmd_list(int argc, char *argv[])
                        btree_id_end = btree_id_start + 1;
                        break;
                case 's':
-                       start   = parse_pos(optarg);
+                       start   = bpos_parse(optarg);
                        break;
                case 'e':
-                       end     = parse_pos(optarg);
+                       end     = bpos_parse(optarg);
                        break;
                case 'i':
                        if (kstrtoull(optarg, 10, &inum))
diff --git a/cmds.h b/cmds.h
index a05c98b9b1ab38acbda86599cd0dbdfc459c17de..cc490844dc8684533a9ff99ce6d039d71999d186 100644 (file)
--- a/cmds.h
+++ b/cmds.h
@@ -31,6 +31,7 @@ int cmd_device_resize(int argc, char *argv[]);
 int cmd_device_resize_journal(int argc, char *argv[]);
 
 int cmd_data_rereplicate(int argc, char *argv[]);
+int cmd_data_job(int argc, char *argv[]);
 
 int cmd_unlock(int argc, char *argv[]);
 int cmd_set_passphrase(int argc, char *argv[]);
index 88e923cb22e3b242970ee6e4dd123fb8dc38230f..361419aec5fc09a09611ef9e84f9d8e393076d1b 100644 (file)
@@ -663,3 +663,22 @@ int dev_mounted(char *dev)
                return 1;
        return 2;
 }
+
+struct bpos bpos_parse(char *buf)
+{
+       char *s = buf, *field;
+       u64 inode_v = 0, offset_v = 0;
+
+       if (!(field = strsep(&s, ":")) ||
+           kstrtoull(field, 10, &inode_v))
+               die("invalid bpos %s", buf);
+
+       if ((field = strsep(&s, ":")) &&
+           kstrtoull(field, 10, &offset_v))
+               die("invalid bpos %s", buf);
+
+       if (s)
+               die("invalid bpos %s", buf);
+
+       return (struct bpos) { .inode = inode_v, .offset = offset_v };
+}
index d6814bcd971d40468279cc9052ae8b7b0ef91be2..01898e21d050c275d0b03c732237d1731d21c5a0 100644 (file)
@@ -172,4 +172,6 @@ do {                                                                        \
        _ret;                                                           \
 })
 
+struct bpos bpos_parse(char *);
+
 #endif /* _TOOLS_UTIL_H */