X-Git-Url: https://git.kernel.dk/?p=fio.git;a=blobdiff_plain;f=options.h;h=256bf60e6fe6f50129551faa1c6cdcc0017e41a8;hp=ed6b9c2da47a5699cb9b4d3f1808eba4b8ede019;hb=e8b0e958cd219cabb1154e2b06036863a7d6dbd7;hpb=7e356b2dee2e86f3684424fc6e903f1ef9f00ef4 diff --git a/options.h b/options.h index ed6b9c2d..256bf60e 100644 --- a/options.h +++ b/options.h @@ -18,6 +18,8 @@ void del_opt_posval(const char *, const char *); struct thread_data; void fio_options_free(struct thread_data *); +extern struct fio_option fio_options[FIO_MAX_OPTS]; + static inline int o_match(struct fio_option *o, const char *opt) { if (!strcmp(o->name, opt)) @@ -40,4 +42,50 @@ static inline struct fio_option *find_option(struct fio_option *options, return NULL; } +struct opt_group { + const char *name; + unsigned int 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_NR, + + FIO_OPT_C_GENERAL = (1U << __FIO_OPT_C_GENERAL), + FIO_OPT_C_IO = (1U << __FIO_OPT_C_IO), + FIO_OPT_C_FILE = (1U << __FIO_OPT_C_FILE), + FIO_OPT_C_STAT = (1U << __FIO_OPT_C_STAT), + FIO_OPT_C_LOG = (1U << __FIO_OPT_C_LOG), + FIO_OPT_C_INVALID = (1U << __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_NR, + + FIO_OPT_G_RATE = (1U << __FIO_OPT_G_RATE), + FIO_OPT_G_ZONE = (1U << __FIO_OPT_G_ZONE), + FIO_OPT_G_RWMIX = (1U << __FIO_OPT_G_RWMIX), + FIO_OPT_G_VERIFY = (1U << __FIO_OPT_G_VERIFY), + FIO_OPT_G_TRIM = (1U << __FIO_OPT_G_TRIM), + FIO_OPT_G_IOLOG = (1U << __FIO_OPT_G_IOLOG), + FIO_OPT_G_IO_DEPTH = (1U << __FIO_OPT_G_IO_DEPTH), + FIO_OPT_G_IO_FLOW = (1U << __FIO_OPT_G_IO_FLOW), + FIO_OPT_G_INVALID = (1U << __FIO_OPT_G_NR), +}; + +extern struct opt_group *opt_group_from_mask(unsigned int *mask); +extern struct opt_group *opt_group_cat_from_mask(unsigned int *mask); + #endif