blob: fa015c393ea24bb9ff2be3361b7ba91ac50d16a3 [file] [log] [blame]
Jens Axboe9f988e22010-03-04 10:42:38 +01001#ifndef FIO_OPTION_H
2#define FIO_OPTION_H
3
Jens Axboe07b32322010-03-05 09:48:44 +01004#define FIO_MAX_OPTS 512
5
Jens Axboef5b6bb82010-03-05 10:09:59 +01006#include <string.h>
Jens Axboe9f988e22010-03-04 10:42:38 +01007#include "parse.h"
8#include "flist.h"
9
10#define td_var_offset(var) ((size_t) &((struct thread_options *)0)->var)
11
Jens Axboe07b32322010-03-05 09:48:44 +010012int add_option(struct fio_option *);
13void invalidate_profile_options(const char *);
14extern char *exec_profile;
Jens Axboe9f988e22010-03-04 10:42:38 +010015
Jens Axboef5b6bb82010-03-05 10:09:59 +010016void add_opt_posval(const char *, const char *, const char *);
17void del_opt_posval(const char *, const char *);
Jens Axboe7e356b22011-10-14 10:55:16 +020018struct thread_data;
19void fio_options_free(struct thread_data *);
Christian Ehrhardtbcbfeef2014-02-20 09:13:06 -080020char *get_name_idx(char *, int);
21int set_name_idx(char *, char *, int);
Jens Axboef5b6bb82010-03-05 10:09:59 +010022
Jens Axboe9af4a242012-03-16 10:13:49 +010023extern struct fio_option fio_options[FIO_MAX_OPTS];
24
Jens Axboe9c62acd2014-12-09 12:58:15 -070025extern int __fio_option_is_set(struct thread_options *, unsigned int off);
26
27#define fio_option_is_set(__td, name) \
28 __fio_option_is_set((__td), td_var_offset(name))
29
30extern void fio_option_mark_set(struct thread_options *, struct fio_option *);
31
Jens Axboef5b6bb82010-03-05 10:09:59 +010032static inline int o_match(struct fio_option *o, const char *opt)
33{
34 if (!strcmp(o->name, opt))
35 return 1;
36 else if (o->alias && !strcmp(o->alias, opt))
37 return 1;
38
39 return 0;
40}
41
42static inline struct fio_option *find_option(struct fio_option *options,
43 const char *opt)
44{
45 struct fio_option *o;
46
47 for (o = &options[0]; o->name; o++)
48 if (o_match(o, opt))
49 return o;
50
51 return NULL;
52}
53
Jens Axboe9af4a242012-03-16 10:13:49 +010054struct opt_group {
55 const char *name;
56 unsigned int mask;
57};
58
59enum opt_category {
Jens Axboee8b0e952012-03-19 14:37:08 +010060 __FIO_OPT_C_GENERAL = 0,
61 __FIO_OPT_C_IO,
62 __FIO_OPT_C_FILE,
63 __FIO_OPT_C_STAT,
64 __FIO_OPT_C_LOG,
Jens Axboe13fca822012-03-31 13:55:54 +020065 __FIO_OPT_C_PROFILE,
Jens Axboee90a0ad2013-04-10 19:43:59 +020066 __FIO_OPT_C_ENGINE,
Jens Axboee8b0e952012-03-19 14:37:08 +010067 __FIO_OPT_C_NR,
68
69 FIO_OPT_C_GENERAL = (1U << __FIO_OPT_C_GENERAL),
70 FIO_OPT_C_IO = (1U << __FIO_OPT_C_IO),
71 FIO_OPT_C_FILE = (1U << __FIO_OPT_C_FILE),
72 FIO_OPT_C_STAT = (1U << __FIO_OPT_C_STAT),
73 FIO_OPT_C_LOG = (1U << __FIO_OPT_C_LOG),
Jens Axboe13fca822012-03-31 13:55:54 +020074 FIO_OPT_C_PROFILE = (1U << __FIO_OPT_C_PROFILE),
Jens Axboee90a0ad2013-04-10 19:43:59 +020075 FIO_OPT_C_ENGINE = (1U << __FIO_OPT_C_ENGINE),
Jens Axboee8b0e952012-03-19 14:37:08 +010076 FIO_OPT_C_INVALID = (1U << __FIO_OPT_C_NR),
77};
78
79enum opt_category_group {
80 __FIO_OPT_G_RATE = 0,
Jens Axboee231bbe2012-03-16 19:16:27 +010081 __FIO_OPT_G_ZONE,
Jens Axboee8b0e952012-03-19 14:37:08 +010082 __FIO_OPT_G_RWMIX,
83 __FIO_OPT_G_VERIFY,
84 __FIO_OPT_G_TRIM,
85 __FIO_OPT_G_IOLOG,
86 __FIO_OPT_G_IO_DEPTH,
87 __FIO_OPT_G_IO_FLOW,
Jens Axboe06260372012-03-19 15:16:08 +010088 __FIO_OPT_G_DESC,
89 __FIO_OPT_G_FILENAME,
90 __FIO_OPT_G_IO_BASIC,
Jens Axboea1f6afe2012-03-19 20:44:33 +010091 __FIO_OPT_G_CGROUP,
92 __FIO_OPT_G_RUNTIME,
Jens Axboe10860052012-03-19 20:56:53 +010093 __FIO_OPT_G_PROCESS,
94 __FIO_OPT_G_CRED,
95 __FIO_OPT_G_CLOCK,
Jens Axboe3ceb4582012-03-19 21:27:02 +010096 __FIO_OPT_G_IO_TYPE,
97 __FIO_OPT_G_THINKTIME,
98 __FIO_OPT_G_RANDOM,
99 __FIO_OPT_G_IO_BUF,
Jens Axboe13fca822012-03-31 13:55:54 +0200100 __FIO_OPT_G_TIOBENCH,
Jens Axboebc3f5522012-09-27 19:28:11 +0200101 __FIO_OPT_G_ERR,
Jens Axboee90a0ad2013-04-10 19:43:59 +0200102 __FIO_OPT_G_E4DEFRAG,
103 __FIO_OPT_G_NETIO,
104 __FIO_OPT_G_LIBAIO,
Jens Axboed4afedf2013-05-22 22:21:29 +0200105 __FIO_OPT_G_ACT,
Jens Axboe3e260a42013-12-09 12:38:53 -0700106 __FIO_OPT_G_LATPROF,
Daniel Gollubfc5c0342014-02-17 14:35:28 +0100107 __FIO_OPT_G_RBD,
chenh0e55d6b2014-03-27 15:19:43 -0400108 __FIO_OPT_G_GFAPI,
Jens Axboee231bbe2012-03-16 19:16:27 +0100109 __FIO_OPT_G_NR,
Jens Axboe9af4a242012-03-16 10:13:49 +0100110
Jens Axboee8b0e952012-03-19 14:37:08 +0100111 FIO_OPT_G_RATE = (1U << __FIO_OPT_G_RATE),
Jens Axboe9af4a242012-03-16 10:13:49 +0100112 FIO_OPT_G_ZONE = (1U << __FIO_OPT_G_ZONE),
Jens Axboee8b0e952012-03-19 14:37:08 +0100113 FIO_OPT_G_RWMIX = (1U << __FIO_OPT_G_RWMIX),
114 FIO_OPT_G_VERIFY = (1U << __FIO_OPT_G_VERIFY),
115 FIO_OPT_G_TRIM = (1U << __FIO_OPT_G_TRIM),
116 FIO_OPT_G_IOLOG = (1U << __FIO_OPT_G_IOLOG),
117 FIO_OPT_G_IO_DEPTH = (1U << __FIO_OPT_G_IO_DEPTH),
118 FIO_OPT_G_IO_FLOW = (1U << __FIO_OPT_G_IO_FLOW),
Jens Axboe06260372012-03-19 15:16:08 +0100119 FIO_OPT_G_DESC = (1U << __FIO_OPT_G_DESC),
120 FIO_OPT_G_FILENAME = (1U << __FIO_OPT_G_FILENAME),
121 FIO_OPT_G_IO_BASIC = (1U << __FIO_OPT_G_IO_BASIC),
Jens Axboea1f6afe2012-03-19 20:44:33 +0100122 FIO_OPT_G_CGROUP = (1U << __FIO_OPT_G_CGROUP),
123 FIO_OPT_G_RUNTIME = (1U << __FIO_OPT_G_RUNTIME),
Jens Axboe10860052012-03-19 20:56:53 +0100124 FIO_OPT_G_PROCESS = (1U << __FIO_OPT_G_PROCESS),
125 FIO_OPT_G_CRED = (1U << __FIO_OPT_G_CRED),
126 FIO_OPT_G_CLOCK = (1U << __FIO_OPT_G_CLOCK),
Jens Axboe3ceb4582012-03-19 21:27:02 +0100127 FIO_OPT_G_IO_TYPE = (1U << __FIO_OPT_G_IO_TYPE),
128 FIO_OPT_G_THINKTIME = (1U << __FIO_OPT_G_THINKTIME),
129 FIO_OPT_G_RANDOM = (1U << __FIO_OPT_G_RANDOM),
130 FIO_OPT_G_IO_BUF = (1U << __FIO_OPT_G_IO_BUF),
Jens Axboe13fca822012-03-31 13:55:54 +0200131 FIO_OPT_G_TIOBENCH = (1U << __FIO_OPT_G_TIOBENCH),
Jens Axboebc3f5522012-09-27 19:28:11 +0200132 FIO_OPT_G_ERR = (1U << __FIO_OPT_G_ERR),
Jens Axboee90a0ad2013-04-10 19:43:59 +0200133 FIO_OPT_G_E4DEFRAG = (1U << __FIO_OPT_G_E4DEFRAG),
134 FIO_OPT_G_NETIO = (1U << __FIO_OPT_G_NETIO),
135 FIO_OPT_G_LIBAIO = (1U << __FIO_OPT_G_LIBAIO),
Jens Axboed4afedf2013-05-22 22:21:29 +0200136 FIO_OPT_G_ACT = (1U << __FIO_OPT_G_ACT),
Jens Axboe3e260a42013-12-09 12:38:53 -0700137 FIO_OPT_G_LATPROF = (1U << __FIO_OPT_G_LATPROF),
Daniel Gollubfc5c0342014-02-17 14:35:28 +0100138 FIO_OPT_G_RBD = (1U << __FIO_OPT_G_RBD),
chenh0e55d6b2014-03-27 15:19:43 -0400139 FIO_OPT_G_GFAPI = (1U << __FIO_OPT_G_GFAPI),
Jens Axboe9af4a242012-03-16 10:13:49 +0100140 FIO_OPT_G_INVALID = (1U << __FIO_OPT_G_NR),
141};
142
143extern struct opt_group *opt_group_from_mask(unsigned int *mask);
Jens Axboee8b0e952012-03-19 14:37:08 +0100144extern struct opt_group *opt_group_cat_from_mask(unsigned int *mask);
Jens Axboec504ee52012-03-20 11:29:09 +0100145extern struct fio_option *fio_option_find(const char *name);
Jens Axboe3c3ed072012-03-27 09:12:39 +0200146extern unsigned int fio_get_kb_base(void *);
Jens Axboe9af4a242012-03-16 10:13:49 +0100147
Jens Axboe9f988e22010-03-04 10:42:38 +0100148#endif