X-Git-Url: https://git.kernel.dk/?p=fio.git;a=blobdiff_plain;f=options.h;h=36fd35d2f6e72ed67f316b8fe4c317f89b751eff;hp=a13afd142d7345118e2627a6ae3e577e3c252f56;hb=d47d7cb371fd24419ea5b4d83469ab66f31aa42e;hpb=108600560ae2368369e7b75255539b3286341929 diff --git a/options.h b/options.h index a13afd14..36fd35d2 100644 --- a/options.h +++ b/options.h @@ -17,9 +17,27 @@ 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 *); +char *get_name_idx(char *, int); +int set_name_idx(char *, char *, int); extern struct fio_option fio_options[FIO_MAX_OPTS]; +extern int __fio_option_is_set(struct thread_options *, unsigned int off); + +#define fio_option_is_set(__td, name) \ +({ \ + const unsigned int off = td_var_offset(name); \ + int __r = __fio_option_is_set((__td), off); \ + if (__r == -1) { \ + dprint(FD_PARSE, "option %s/%u not found in map\n", \ + __fio_stringify(name), off); \ + __r = 0; \ + } \ + __r; \ +}) + +extern void fio_option_mark_set(struct thread_options *, struct fio_option *); + static inline int o_match(struct fio_option *o, const char *opt) { if (!strcmp(o->name, opt)) @@ -53,6 +71,8 @@ enum opt_category { __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 = (1U << __FIO_OPT_C_GENERAL), @@ -60,6 +80,8 @@ enum opt_category { 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_PROFILE = (1U << __FIO_OPT_C_PROFILE), + FIO_OPT_C_ENGINE = (1U << __FIO_OPT_C_ENGINE), FIO_OPT_C_INVALID = (1U << __FIO_OPT_C_NR), }; @@ -80,6 +102,19 @@ enum opt_category_group { __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_LIBAIO, + __FIO_OPT_G_ACT, + __FIO_OPT_G_LATPROF, + __FIO_OPT_G_RBD, + __FIO_OPT_G_GFAPI, __FIO_OPT_G_NR, FIO_OPT_G_RATE = (1U << __FIO_OPT_G_RATE), @@ -98,10 +133,25 @@ enum opt_category_group { FIO_OPT_G_PROCESS = (1U << __FIO_OPT_G_PROCESS), FIO_OPT_G_CRED = (1U << __FIO_OPT_G_CRED), FIO_OPT_G_CLOCK = (1U << __FIO_OPT_G_CLOCK), + FIO_OPT_G_IO_TYPE = (1U << __FIO_OPT_G_IO_TYPE), + FIO_OPT_G_THINKTIME = (1U << __FIO_OPT_G_THINKTIME), + FIO_OPT_G_RANDOM = (1U << __FIO_OPT_G_RANDOM), + FIO_OPT_G_IO_BUF = (1U << __FIO_OPT_G_IO_BUF), + FIO_OPT_G_TIOBENCH = (1U << __FIO_OPT_G_TIOBENCH), + FIO_OPT_G_ERR = (1U << __FIO_OPT_G_ERR), + FIO_OPT_G_E4DEFRAG = (1U << __FIO_OPT_G_E4DEFRAG), + FIO_OPT_G_NETIO = (1U << __FIO_OPT_G_NETIO), + FIO_OPT_G_LIBAIO = (1U << __FIO_OPT_G_LIBAIO), + FIO_OPT_G_ACT = (1U << __FIO_OPT_G_ACT), + FIO_OPT_G_LATPROF = (1U << __FIO_OPT_G_LATPROF), + FIO_OPT_G_RBD = (1U << __FIO_OPT_G_RBD), + FIO_OPT_G_GFAPI = (1U << __FIO_OPT_G_GFAPI), 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); +extern struct fio_option *fio_option_find(const char *name); +extern unsigned int fio_get_kb_base(void *); #endif