X-Git-Url: https://git.kernel.dk/?a=blobdiff_plain;ds=sidebyside;f=options.h;h=d130fc7faed400732a3d55709b11cb18d8b3f48a;hb=e231bbe64fffda2090b74941efe21d9c0013cd1e;hp=c6c2086e0a76286a87f44bbb469307ccdddc09e4;hpb=f5b6bb85364fcb8b2ac8d922ca65afd9dfabc9bb;p=fio.git diff --git a/options.h b/options.h index c6c2086e..d130fc7f 100644 --- a/options.h +++ b/options.h @@ -15,6 +15,10 @@ extern char *exec_profile; void add_opt_posval(const char *, const char *, const char *); 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) { @@ -38,4 +42,53 @@ 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_G_DESC = 0, + __FIO_OPT_G_FILE, + __FIO_OPT_G_IO, + __FIO_OPT_G_IO_DDIR, + __FIO_OPT_G_IO_BUF, + __FIO_OPT_G_IO_ENG, + __FIO_OPT_G_CACHE, + __FIO_OPT_G_VERIFY, + __FIO_OPT_G_ZONE, + __FIO_OPT_G_MEM, + __FIO_OPT_G_LOG, + __FIO_OPT_G_ERR, + __FIO_OPT_G_STAT, + __FIO_OPT_G_CPU, + __FIO_OPT_G_OS, + __FIO_OPT_G_MISC, + __FIO_OPT_G_RAND, + __FIO_OPT_G_JOB, + __FIO_OPT_G_NR, + + FIO_OPT_G_DESC = (1U << __FIO_OPT_G_DESC), + FIO_OPT_G_FILE = (1U << __FIO_OPT_G_FILE), + FIO_OPT_G_MISC = (1U << __FIO_OPT_G_MISC), + FIO_OPT_G_IO = (1U << __FIO_OPT_G_IO), + FIO_OPT_G_IO_DDIR = (1U << __FIO_OPT_G_IO_DDIR), + FIO_OPT_G_IO_BUF = (1U << __FIO_OPT_G_IO_BUF), + FIO_OPT_G_IO_ENG = (1U << __FIO_OPT_G_IO_ENG), + FIO_OPT_G_RAND = (1U << __FIO_OPT_G_RAND), + FIO_OPT_G_OS = (1U << __FIO_OPT_G_OS), + FIO_OPT_G_MEM = (1U << __FIO_OPT_G_MEM), + FIO_OPT_G_VERIFY = (1U << __FIO_OPT_G_VERIFY), + FIO_OPT_G_CPU = (1U << __FIO_OPT_G_CPU), + FIO_OPT_G_LOG = (1U << __FIO_OPT_G_LOG), + FIO_OPT_G_ZONE = (1U << __FIO_OPT_G_ZONE), + FIO_OPT_G_CACHE = (1U << __FIO_OPT_G_CACHE), + FIO_OPT_G_STAT = (1U << __FIO_OPT_G_STAT), + FIO_OPT_G_ERR = (1U << __FIO_OPT_G_ERR), + FIO_OPT_G_JOB = (1U << __FIO_OPT_G_JOB), + FIO_OPT_G_INVALID = (1U << __FIO_OPT_G_NR), +}; + +extern struct opt_group *opt_group_from_mask(unsigned int *mask); + #endif