options: split out option grouping code
authorJens Axboe <axboe@fb.com>
Wed, 30 Dec 2015 16:03:55 +0000 (09:03 -0700)
committerJens Axboe <axboe@fb.com>
Wed, 30 Dec 2015 16:03:55 +0000 (09:03 -0700)
Signed-off-by: Jens Axboe <axboe@fb.com>
17 files changed:
Makefile
engines/cpu.c
engines/e4defrag.c
engines/glusterfs.c
engines/libaio.c
engines/libhdfs.c
engines/net.c
engines/rbd.c
engines/rdma.c
goptions.c
optgroup.c [new file with mode: 0644]
optgroup.h [new file with mode: 0644]
options.c
options.h
parse.c
profiles/act.c
profiles/tiobench.c

index 1b5c9a6f35892d3e15b259a0dafde6df2a2cfc6c..bd5f1bbe352a77e962f993a8a612d5536c40c5b5 100644 (file)
--- a/Makefile
+++ b/Makefile
@@ -45,7 +45,7 @@ SOURCE :=     $(patsubst $(SRCDIR)/%,%,$(wildcard $(SRCDIR)/crc/*.c)) \
                server.c client.c iolog.c backend.c libfio.c flow.c cconv.c \
                gettime-thread.c helpers.c json.c idletime.c td_error.c \
                profiles/tiobench.c profiles/act.c io_u_queue.c filelock.c \
-               workqueue.c rate-submit.c
+               workqueue.c rate-submit.c optgroup.c
 
 ifdef CONFIG_LIBHDFS
   HDFSFLAGS= -I $(JAVA_HOME)/include -I $(JAVA_HOME)/include/linux -I $(FIO_LIBHDFS_INCLUDE)
index 7e4d7374accd24399a6d780639f5c94f05c5c9a3..7643a8c591c39942b95db763694eac93bef59d98 100644 (file)
@@ -6,6 +6,7 @@
  *
  */
 #include "../fio.h"
+#include "../optgroup.h"
 
 struct cpu_options {
        void *pad;
index d6113a97ee9b6565dbdf8e5dc0381491bf6b61a4..c0667feced3f6609bf6efaf320225c5150662da5 100644 (file)
@@ -17,6 +17,7 @@
 #include <fcntl.h>
 
 #include "../fio.h"
+#include "../optgroup.h"
 
 #ifndef EXT4_IOC_MOVE_EXT
 #define EXT4_IOC_MOVE_EXT               _IOWR('f', 15, struct move_extent)
index 507cd25dc89d0c638193134d0543b0670da0ed50..dec9fb5f6597c0754f8ee97da2193f253ebf8346 100644 (file)
@@ -6,6 +6,7 @@
  */
 
 #include "gfapi.h"
+#include "../optgroup.h"
 
 struct fio_option gfapi_options[] = {
        {
index 60dc49d3352a950fa522931ccdfe52a601628975..9d562bb272e6eef5297bb2a6252b1392915f7e2d 100644 (file)
@@ -13,6 +13,7 @@
 
 #include "../fio.h"
 #include "../lib/pow2.h"
+#include "../optgroup.h"
 
 static int fio_libaio_commit(struct thread_data *td);
 
index f690b009e431a2b6c80bdf7b97a9003d64b5549b..faad3f875ac17504eb1cf634f0fc8f8043426ab1 100644 (file)
@@ -15,7 +15,7 @@
 #include <hdfs.h>
 
 #include "../fio.h"
-
+#include "../optgroup.h"
 
 #define CHUNCK_NAME_LENGTH_MAX 80
 #define CHUNCK_CREATION_BUFFER_SIZE 65536
index cd19535294a083eff56c97036aef75f8c4615541..9301ccf02747268b0a878c963037f59506d3c81a 100644 (file)
@@ -22,6 +22,7 @@
 
 #include "../fio.h"
 #include "../verify.h"
+#include "../optgroup.h"
 
 struct netio_data {
        int listenfd;
index 2be9b556634fe8f39f2c9b86047949fdef80ccd4..8252d270b1bcb44eda6095281a413a3cb0cefdaf 100644 (file)
@@ -8,6 +8,7 @@
 #include <rbd/librbd.h>
 
 #include "../fio.h"
+#include "../optgroup.h"
 
 struct fio_rbd_iou {
        struct io_u *io_u;
index 1006b7e45ad8c54659311b9ae680e3f778ee3c74..87ba4658ceca94f6c6aec683cc4e56fc5d0c4d63 100644 (file)
@@ -41,6 +41,7 @@
 
 #include "../fio.h"
 #include "../hash.h"
+#include "../optgroup.h"
 
 #include <rdma/rdma_cma.h>
 #include <infiniband/arch.h>
index 9279b22f946c434441c899dcc6727f8a588d78e5..b3d3684697707f962ff311c2a578be87ae078f05 100644 (file)
@@ -11,6 +11,7 @@
 #include "ghelpers.h"
 #include "gerror.h"
 #include "parse.h"
+#include "optgroup.h"
 
 struct gopt {
        GtkWidget *box;
@@ -95,7 +96,7 @@ static GtkWidget *gopt_get_group_frame(struct gopt_job_view *gjv,
                                       GtkWidget *box, uint64_t groupmask)
 {
        uint64_t mask, group;
-       struct opt_group *og;
+       const struct opt_group *og;
        GtkWidget *frame, *hbox;
        struct gopt_frame_widget *gfw;
 
@@ -1136,7 +1137,7 @@ static void gopt_add_options(struct gopt_job_view *gjv,
        for (i = 0; fio_options[i].name; i++) {
                struct fio_option *o = &fio_options[i];
                uint64_t mask = o->category;
-               struct opt_group *og;
+               const struct opt_group *og;
 
                while ((og = opt_group_from_mask(&mask)) != NULL) {
                        GtkWidget *vbox = gjv->vboxes[ffz64(~og->mask)];
@@ -1177,14 +1178,15 @@ static GtkWidget *gopt_add_tab(GtkWidget *notebook, const char *name)
        return vbox;
 }
 
-static GtkWidget *gopt_add_group_tab(GtkWidget *notebook, struct opt_group *og)
+static GtkWidget *gopt_add_group_tab(GtkWidget *notebook,
+                                    const struct opt_group *og)
 {
        return gopt_add_tab(notebook, og->name);
 }
 
 static void gopt_add_group_tabs(GtkWidget *notebook, struct gopt_job_view *gjv)
 {
-       struct opt_group *og;
+       const struct opt_group *og;
        unsigned int i;
 
        i = 0;
diff --git a/optgroup.c b/optgroup.c
new file mode 100644 (file)
index 0000000..5f9ca96
--- /dev/null
@@ -0,0 +1,166 @@
+#include <stdio.h>
+#include <inttypes.h>
+#include "optgroup.h"
+
+/*
+ * Option grouping
+ */
+static const struct opt_group fio_opt_groups[] = {
+       {
+               .name   = "General",
+               .mask   = FIO_OPT_C_GENERAL,
+       },
+       {
+               .name   = "I/O",
+               .mask   = FIO_OPT_C_IO,
+       },
+       {
+               .name   = "File",
+               .mask   = FIO_OPT_C_FILE,
+       },
+       {
+               .name   = "Statistics",
+               .mask   = FIO_OPT_C_STAT,
+       },
+       {
+               .name   = "Logging",
+               .mask   = FIO_OPT_C_LOG,
+       },
+       {
+               .name   = "Profiles",
+               .mask   = FIO_OPT_C_PROFILE,
+       },
+       {
+               .name   = NULL,
+       },
+};
+
+static const struct opt_group fio_opt_cat_groups[] = {
+       {
+               .name   = "Latency profiling",
+               .mask   = FIO_OPT_G_LATPROF,
+       },
+       {
+               .name   = "Rate",
+               .mask   = FIO_OPT_G_RATE,
+       },
+       {
+               .name   = "Zone",
+               .mask   = FIO_OPT_G_ZONE,
+       },
+       {
+               .name   = "Read/write mix",
+               .mask   = FIO_OPT_G_RWMIX,
+       },
+       {
+               .name   = "Verify",
+               .mask   = FIO_OPT_G_VERIFY,
+       },
+       {
+               .name   = "Trim",
+               .mask   = FIO_OPT_G_TRIM,
+       },
+       {
+               .name   = "I/O Logging",
+               .mask   = FIO_OPT_G_IOLOG,
+       },
+       {
+               .name   = "I/O Depth",
+               .mask   = FIO_OPT_G_IO_DEPTH,
+       },
+       {
+               .name   = "I/O Flow",
+               .mask   = FIO_OPT_G_IO_FLOW,
+       },
+       {
+               .name   = "Description",
+               .mask   = FIO_OPT_G_DESC,
+       },
+       {
+               .name   = "Filename",
+               .mask   = FIO_OPT_G_FILENAME,
+       },
+       {
+               .name   = "General I/O",
+               .mask   = FIO_OPT_G_IO_BASIC,
+       },
+       {
+               .name   = "Cgroups",
+               .mask   = FIO_OPT_G_CGROUP,
+       },
+       {
+               .name   = "Runtime",
+               .mask   = FIO_OPT_G_RUNTIME,
+       },
+       {
+               .name   = "Process",
+               .mask   = FIO_OPT_G_PROCESS,
+       },
+       {
+               .name   = "Job credentials / priority",
+               .mask   = FIO_OPT_G_CRED,
+       },
+       {
+               .name   = "Clock settings",
+               .mask   = FIO_OPT_G_CLOCK,
+       },
+       {
+               .name   = "I/O Type",
+               .mask   = FIO_OPT_G_IO_TYPE,
+       },
+       {
+               .name   = "I/O Thinktime",
+               .mask   = FIO_OPT_G_THINKTIME,
+       },
+       {
+               .name   = "Randomizations",
+               .mask   = FIO_OPT_G_RANDOM,
+       },
+       {
+               .name   = "I/O buffers",
+               .mask   = FIO_OPT_G_IO_BUF,
+       },
+       {
+               .name   = "Tiobench profile",
+               .mask   = FIO_OPT_G_TIOBENCH,
+       },
+       {
+               .name   = "MTD",
+               .mask   = FIO_OPT_G_MTD,
+       },
+
+       {
+               .name   = NULL,
+       }
+};
+
+static const struct opt_group *group_from_mask(const struct opt_group *ogs,
+                                              uint64_t *mask,
+                                              uint64_t inv_mask)
+{
+       int i;
+
+       if (*mask == inv_mask || !*mask)
+               return NULL;
+
+       for (i = 0; ogs[i].name; i++) {
+               const struct opt_group *og = &ogs[i];
+
+               if (*mask & og->mask) {
+                       *mask &= ~(og->mask);
+                       return og;
+               }
+       }
+
+       return NULL;
+}
+
+const struct opt_group *opt_group_from_mask(uint64_t *mask)
+{
+       return group_from_mask(fio_opt_groups, mask, FIO_OPT_C_INVALID);
+}
+
+const struct opt_group *opt_group_cat_from_mask(uint64_t *mask)
+{
+       return group_from_mask(fio_opt_cat_groups, mask, FIO_OPT_G_INVALID);
+}
diff --git a/optgroup.h b/optgroup.h
new file mode 100644 (file)
index 0000000..815ac16
--- /dev/null
@@ -0,0 +1,102 @@
+#ifndef FIO_OPT_GROUP_H
+#define FIO_OPT_GROUP_H
+
+struct opt_group {
+       const char *name;
+       uint64_t mask;
+};
+
+enum opt_category {
+       __FIO_OPT_C_GENERAL     = 0,
+       __FIO_OPT_C_IO,
+       __FIO_OPT_C_FILE,
+       __FIO_OPT_C_STAT,
+       __FIO_OPT_C_LOG,
+       __FIO_OPT_C_PROFILE,
+       __FIO_OPT_C_ENGINE,
+       __FIO_OPT_C_NR,
+
+       FIO_OPT_C_GENERAL       = (1ULL << __FIO_OPT_C_GENERAL),
+       FIO_OPT_C_IO            = (1ULL << __FIO_OPT_C_IO),
+       FIO_OPT_C_FILE          = (1ULL << __FIO_OPT_C_FILE),
+       FIO_OPT_C_STAT          = (1ULL << __FIO_OPT_C_STAT),
+       FIO_OPT_C_LOG           = (1ULL << __FIO_OPT_C_LOG),
+       FIO_OPT_C_PROFILE       = (1ULL << __FIO_OPT_C_PROFILE),
+       FIO_OPT_C_ENGINE        = (1ULL << __FIO_OPT_C_ENGINE),
+       FIO_OPT_C_INVALID       = (1ULL << __FIO_OPT_C_NR),
+};
+
+enum opt_category_group {
+       __FIO_OPT_G_RATE        = 0,
+       __FIO_OPT_G_ZONE,
+       __FIO_OPT_G_RWMIX,
+       __FIO_OPT_G_VERIFY,
+       __FIO_OPT_G_TRIM,
+       __FIO_OPT_G_IOLOG,
+       __FIO_OPT_G_IO_DEPTH,
+       __FIO_OPT_G_IO_FLOW,
+       __FIO_OPT_G_DESC,
+       __FIO_OPT_G_FILENAME,
+       __FIO_OPT_G_IO_BASIC,
+       __FIO_OPT_G_CGROUP,
+       __FIO_OPT_G_RUNTIME,
+       __FIO_OPT_G_PROCESS,
+       __FIO_OPT_G_CRED,
+       __FIO_OPT_G_CLOCK,
+       __FIO_OPT_G_IO_TYPE,
+       __FIO_OPT_G_THINKTIME,
+       __FIO_OPT_G_RANDOM,
+       __FIO_OPT_G_IO_BUF,
+       __FIO_OPT_G_TIOBENCH,
+       __FIO_OPT_G_ERR,
+       __FIO_OPT_G_E4DEFRAG,
+       __FIO_OPT_G_NETIO,
+       __FIO_OPT_G_RDMA,
+       __FIO_OPT_G_LIBAIO,
+       __FIO_OPT_G_ACT,
+       __FIO_OPT_G_LATPROF,
+        __FIO_OPT_G_RBD,
+        __FIO_OPT_G_GFAPI,
+        __FIO_OPT_G_MTD,
+       __FIO_OPT_G_HDFS,
+       __FIO_OPT_G_NR,
+
+       FIO_OPT_G_RATE          = (1ULL << __FIO_OPT_G_RATE),
+       FIO_OPT_G_ZONE          = (1ULL << __FIO_OPT_G_ZONE),
+       FIO_OPT_G_RWMIX         = (1ULL << __FIO_OPT_G_RWMIX),
+       FIO_OPT_G_VERIFY        = (1ULL << __FIO_OPT_G_VERIFY),
+       FIO_OPT_G_TRIM          = (1ULL << __FIO_OPT_G_TRIM),
+       FIO_OPT_G_IOLOG         = (1ULL << __FIO_OPT_G_IOLOG),
+       FIO_OPT_G_IO_DEPTH      = (1ULL << __FIO_OPT_G_IO_DEPTH),
+       FIO_OPT_G_IO_FLOW       = (1ULL << __FIO_OPT_G_IO_FLOW),
+       FIO_OPT_G_DESC          = (1ULL << __FIO_OPT_G_DESC),
+       FIO_OPT_G_FILENAME      = (1ULL << __FIO_OPT_G_FILENAME),
+       FIO_OPT_G_IO_BASIC      = (1ULL << __FIO_OPT_G_IO_BASIC),
+       FIO_OPT_G_CGROUP        = (1ULL << __FIO_OPT_G_CGROUP),
+       FIO_OPT_G_RUNTIME       = (1ULL << __FIO_OPT_G_RUNTIME),
+       FIO_OPT_G_PROCESS       = (1ULL << __FIO_OPT_G_PROCESS),
+       FIO_OPT_G_CRED          = (1ULL << __FIO_OPT_G_CRED),
+       FIO_OPT_G_CLOCK         = (1ULL << __FIO_OPT_G_CLOCK),
+       FIO_OPT_G_IO_TYPE       = (1ULL << __FIO_OPT_G_IO_TYPE),
+       FIO_OPT_G_THINKTIME     = (1ULL << __FIO_OPT_G_THINKTIME),
+       FIO_OPT_G_RANDOM        = (1ULL << __FIO_OPT_G_RANDOM),
+       FIO_OPT_G_IO_BUF        = (1ULL << __FIO_OPT_G_IO_BUF),
+       FIO_OPT_G_TIOBENCH      = (1ULL << __FIO_OPT_G_TIOBENCH),
+       FIO_OPT_G_ERR           = (1ULL << __FIO_OPT_G_ERR),
+       FIO_OPT_G_E4DEFRAG      = (1ULL << __FIO_OPT_G_E4DEFRAG),
+       FIO_OPT_G_NETIO         = (1ULL << __FIO_OPT_G_NETIO),
+       FIO_OPT_G_RDMA          = (1ULL << __FIO_OPT_G_RDMA),
+       FIO_OPT_G_LIBAIO        = (1ULL << __FIO_OPT_G_LIBAIO),
+       FIO_OPT_G_ACT           = (1ULL << __FIO_OPT_G_ACT),
+       FIO_OPT_G_LATPROF       = (1ULL << __FIO_OPT_G_LATPROF),
+       FIO_OPT_G_RBD           = (1ULL << __FIO_OPT_G_RBD),
+       FIO_OPT_G_GFAPI         = (1ULL << __FIO_OPT_G_GFAPI),
+       FIO_OPT_G_MTD           = (1ULL << __FIO_OPT_G_MTD),
+       FIO_OPT_G_HDFS          = (1ULL << __FIO_OPT_G_HDFS),
+       FIO_OPT_G_INVALID       = (1ULL << __FIO_OPT_G_NR),
+};
+
+extern const struct opt_group *opt_group_from_mask(uint64_t *mask);
+extern const struct opt_group *opt_group_cat_from_mask(uint64_t *mask);
+
+#endif
index f67969eace72c7301b8c872ce16d643d68c5226b..a60b6e195c5506844bd3c06489085a04fb87516e 100644 (file)
--- a/options.c
+++ b/options.c
@@ -16,6 +16,7 @@
 #include "lib/fls.h"
 #include "lib/pattern.h"
 #include "options.h"
+#include "optgroup.h"
 
 #include "crc/crc32c.h"
 
@@ -1042,169 +1043,6 @@ static int gtod_cpu_verify(struct fio_option *o, void *data)
        return 0;
 }
 
-/*
- * Option grouping
- */
-static const struct opt_group fio_opt_groups[] = {
-       {
-               .name   = "General",
-               .mask   = FIO_OPT_C_GENERAL,
-       },
-       {
-               .name   = "I/O",
-               .mask   = FIO_OPT_C_IO,
-       },
-       {
-               .name   = "File",
-               .mask   = FIO_OPT_C_FILE,
-       },
-       {
-               .name   = "Statistics",
-               .mask   = FIO_OPT_C_STAT,
-       },
-       {
-               .name   = "Logging",
-               .mask   = FIO_OPT_C_LOG,
-       },
-       {
-               .name   = "Profiles",
-               .mask   = FIO_OPT_C_PROFILE,
-       },
-       {
-               .name   = NULL,
-       },
-};
-
-static const struct opt_group *group_from_mask(const struct opt_group *ogs,
-                                              uint64_t *mask,
-                                              uint64_t inv_mask)
-{
-       int i;
-
-       if (*mask == inv_mask || !*mask)
-               return NULL;
-
-       for (i = 0; ogs[i].name; i++) {
-               const struct opt_group *og = &ogs[i];
-
-               if (*mask & og->mask) {
-                       *mask &= ~(og->mask);
-                       return og;
-               }
-       }
-
-       return NULL;
-}
-
-const struct opt_group *opt_group_from_mask(uint64_t *mask)
-{
-       return group_from_mask(fio_opt_groups, mask, FIO_OPT_C_INVALID);
-}
-
-static const struct opt_group fio_opt_cat_groups[] = {
-       {
-               .name   = "Latency profiling",
-               .mask   = FIO_OPT_G_LATPROF,
-       },
-       {
-               .name   = "Rate",
-               .mask   = FIO_OPT_G_RATE,
-       },
-       {
-               .name   = "Zone",
-               .mask   = FIO_OPT_G_ZONE,
-       },
-       {
-               .name   = "Read/write mix",
-               .mask   = FIO_OPT_G_RWMIX,
-       },
-       {
-               .name   = "Verify",
-               .mask   = FIO_OPT_G_VERIFY,
-       },
-       {
-               .name   = "Trim",
-               .mask   = FIO_OPT_G_TRIM,
-       },
-       {
-               .name   = "I/O Logging",
-               .mask   = FIO_OPT_G_IOLOG,
-       },
-       {
-               .name   = "I/O Depth",
-               .mask   = FIO_OPT_G_IO_DEPTH,
-       },
-       {
-               .name   = "I/O Flow",
-               .mask   = FIO_OPT_G_IO_FLOW,
-       },
-       {
-               .name   = "Description",
-               .mask   = FIO_OPT_G_DESC,
-       },
-       {
-               .name   = "Filename",
-               .mask   = FIO_OPT_G_FILENAME,
-       },
-       {
-               .name   = "General I/O",
-               .mask   = FIO_OPT_G_IO_BASIC,
-       },
-       {
-               .name   = "Cgroups",
-               .mask   = FIO_OPT_G_CGROUP,
-       },
-       {
-               .name   = "Runtime",
-               .mask   = FIO_OPT_G_RUNTIME,
-       },
-       {
-               .name   = "Process",
-               .mask   = FIO_OPT_G_PROCESS,
-       },
-       {
-               .name   = "Job credentials / priority",
-               .mask   = FIO_OPT_G_CRED,
-       },
-       {
-               .name   = "Clock settings",
-               .mask   = FIO_OPT_G_CLOCK,
-       },
-       {
-               .name   = "I/O Type",
-               .mask   = FIO_OPT_G_IO_TYPE,
-       },
-       {
-               .name   = "I/O Thinktime",
-               .mask   = FIO_OPT_G_THINKTIME,
-       },
-       {
-               .name   = "Randomizations",
-               .mask   = FIO_OPT_G_RANDOM,
-       },
-       {
-               .name   = "I/O buffers",
-               .mask   = FIO_OPT_G_IO_BUF,
-       },
-       {
-               .name   = "Tiobench profile",
-               .mask   = FIO_OPT_G_TIOBENCH,
-       },
-       {
-               .name   = "MTD",
-               .mask   = FIO_OPT_G_MTD,
-       },
-
-       {
-               .name   = NULL,
-       }
-};
-
-const struct opt_group *opt_group_cat_from_mask(uint64_t *mask)
-{
-       return group_from_mask(fio_opt_cat_groups, mask, FIO_OPT_G_INVALID);
-}
-
 /*
  * Map of job/command line options
  */
index 7bf7205e9963d3b297436013d0664bddb13e00c0..6a5db0762183c2818a0b55afa888da768188ae28 100644 (file)
--- a/options.h
+++ b/options.h
@@ -59,103 +59,6 @@ static inline struct fio_option *find_option(struct fio_option *options,
        return NULL;
 }
 
-struct opt_group {
-       const char *name;
-       uint64_t mask;
-};
-
-enum opt_category {
-       __FIO_OPT_C_GENERAL     = 0,
-       __FIO_OPT_C_IO,
-       __FIO_OPT_C_FILE,
-       __FIO_OPT_C_STAT,
-       __FIO_OPT_C_LOG,
-       __FIO_OPT_C_PROFILE,
-       __FIO_OPT_C_ENGINE,
-       __FIO_OPT_C_NR,
-
-       FIO_OPT_C_GENERAL       = (1ULL << __FIO_OPT_C_GENERAL),
-       FIO_OPT_C_IO            = (1ULL << __FIO_OPT_C_IO),
-       FIO_OPT_C_FILE          = (1ULL << __FIO_OPT_C_FILE),
-       FIO_OPT_C_STAT          = (1ULL << __FIO_OPT_C_STAT),
-       FIO_OPT_C_LOG           = (1ULL << __FIO_OPT_C_LOG),
-       FIO_OPT_C_PROFILE       = (1ULL << __FIO_OPT_C_PROFILE),
-       FIO_OPT_C_ENGINE        = (1ULL << __FIO_OPT_C_ENGINE),
-       FIO_OPT_C_INVALID       = (1ULL << __FIO_OPT_C_NR),
-};
-
-enum opt_category_group {
-       __FIO_OPT_G_RATE        = 0,
-       __FIO_OPT_G_ZONE,
-       __FIO_OPT_G_RWMIX,
-       __FIO_OPT_G_VERIFY,
-       __FIO_OPT_G_TRIM,
-       __FIO_OPT_G_IOLOG,
-       __FIO_OPT_G_IO_DEPTH,
-       __FIO_OPT_G_IO_FLOW,
-       __FIO_OPT_G_DESC,
-       __FIO_OPT_G_FILENAME,
-       __FIO_OPT_G_IO_BASIC,
-       __FIO_OPT_G_CGROUP,
-       __FIO_OPT_G_RUNTIME,
-       __FIO_OPT_G_PROCESS,
-       __FIO_OPT_G_CRED,
-       __FIO_OPT_G_CLOCK,
-       __FIO_OPT_G_IO_TYPE,
-       __FIO_OPT_G_THINKTIME,
-       __FIO_OPT_G_RANDOM,
-       __FIO_OPT_G_IO_BUF,
-       __FIO_OPT_G_TIOBENCH,
-       __FIO_OPT_G_ERR,
-       __FIO_OPT_G_E4DEFRAG,
-       __FIO_OPT_G_NETIO,
-       __FIO_OPT_G_RDMA,
-       __FIO_OPT_G_LIBAIO,
-       __FIO_OPT_G_ACT,
-       __FIO_OPT_G_LATPROF,
-        __FIO_OPT_G_RBD,
-        __FIO_OPT_G_GFAPI,
-        __FIO_OPT_G_MTD,
-       __FIO_OPT_G_HDFS,
-       __FIO_OPT_G_NR,
-
-       FIO_OPT_G_RATE          = (1ULL << __FIO_OPT_G_RATE),
-       FIO_OPT_G_ZONE          = (1ULL << __FIO_OPT_G_ZONE),
-       FIO_OPT_G_RWMIX         = (1ULL << __FIO_OPT_G_RWMIX),
-       FIO_OPT_G_VERIFY        = (1ULL << __FIO_OPT_G_VERIFY),
-       FIO_OPT_G_TRIM          = (1ULL << __FIO_OPT_G_TRIM),
-       FIO_OPT_G_IOLOG         = (1ULL << __FIO_OPT_G_IOLOG),
-       FIO_OPT_G_IO_DEPTH      = (1ULL << __FIO_OPT_G_IO_DEPTH),
-       FIO_OPT_G_IO_FLOW       = (1ULL << __FIO_OPT_G_IO_FLOW),
-       FIO_OPT_G_DESC          = (1ULL << __FIO_OPT_G_DESC),
-       FIO_OPT_G_FILENAME      = (1ULL << __FIO_OPT_G_FILENAME),
-       FIO_OPT_G_IO_BASIC      = (1ULL << __FIO_OPT_G_IO_BASIC),
-       FIO_OPT_G_CGROUP        = (1ULL << __FIO_OPT_G_CGROUP),
-       FIO_OPT_G_RUNTIME       = (1ULL << __FIO_OPT_G_RUNTIME),
-       FIO_OPT_G_PROCESS       = (1ULL << __FIO_OPT_G_PROCESS),
-       FIO_OPT_G_CRED          = (1ULL << __FIO_OPT_G_CRED),
-       FIO_OPT_G_CLOCK         = (1ULL << __FIO_OPT_G_CLOCK),
-       FIO_OPT_G_IO_TYPE       = (1ULL << __FIO_OPT_G_IO_TYPE),
-       FIO_OPT_G_THINKTIME     = (1ULL << __FIO_OPT_G_THINKTIME),
-       FIO_OPT_G_RANDOM        = (1ULL << __FIO_OPT_G_RANDOM),
-       FIO_OPT_G_IO_BUF        = (1ULL << __FIO_OPT_G_IO_BUF),
-       FIO_OPT_G_TIOBENCH      = (1ULL << __FIO_OPT_G_TIOBENCH),
-       FIO_OPT_G_ERR           = (1ULL << __FIO_OPT_G_ERR),
-       FIO_OPT_G_E4DEFRAG      = (1ULL << __FIO_OPT_G_E4DEFRAG),
-       FIO_OPT_G_NETIO         = (1ULL << __FIO_OPT_G_NETIO),
-       FIO_OPT_G_RDMA          = (1ULL << __FIO_OPT_G_RDMA),
-       FIO_OPT_G_LIBAIO        = (1ULL << __FIO_OPT_G_LIBAIO),
-       FIO_OPT_G_ACT           = (1ULL << __FIO_OPT_G_ACT),
-       FIO_OPT_G_LATPROF       = (1ULL << __FIO_OPT_G_LATPROF),
-       FIO_OPT_G_RBD           = (1ULL << __FIO_OPT_G_RBD),
-       FIO_OPT_G_GFAPI         = (1ULL << __FIO_OPT_G_GFAPI),
-       FIO_OPT_G_MTD           = (1ULL << __FIO_OPT_G_MTD),
-       FIO_OPT_G_HDFS          = (1ULL << __FIO_OPT_G_HDFS),
-       FIO_OPT_G_INVALID       = (1ULL << __FIO_OPT_G_NR),
-};
-
-extern const struct opt_group *opt_group_from_mask(uint64_t *mask);
-extern const struct opt_group *opt_group_cat_from_mask(uint64_t *mask);
 extern struct fio_option *fio_option_find(const char *name);
 extern unsigned int fio_get_kb_base(void *);
 
diff --git a/parse.c b/parse.c
index ac1bee9c296ece240613d8759725aa2efe2b4233..ec0f8707344191e51d03860f35345456e4717272 100644 (file)
--- a/parse.c
+++ b/parse.c
@@ -15,6 +15,7 @@
 #include "parse.h"
 #include "debug.h"
 #include "options.h"
+#include "optgroup.h"
 #include "minmax.h"
 #include "lib/ieee754.h"
 #include "lib/pow2.h"
index 4d2ec5c33c2a4d9a99b34b686be0e1649b9731da..3e9238b31bf02ea6a14a1ccf70f3ca6f7c97b22f 100644 (file)
@@ -1,6 +1,7 @@
 #include "../fio.h"
 #include "../profile.h"
 #include "../parse.h"
+#include "../optgroup.h"
 
 /*
  * 1x loads
index b4331d75ae52c00437c9183d1ef4e76dc7cdf7ca..8af6f4edb1116984e3192c3c8c059d06d46c2826 100644 (file)
@@ -1,6 +1,7 @@
 #include "../fio.h"
 #include "../profile.h"
 #include "../parse.h"
+#include "../optgroup.h"
 
 static unsigned long long size;
 static unsigned int loops = 1;