blob: 36fd35d2f6e72ed67f316b8fe4c317f89b751eff [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
Jens Axboe3c0f5262014-12-18 21:51:21 -070027#define fio_option_is_set(__td, name) \
28({ \
Jens Axboe0703ea02014-12-19 08:04:48 -070029 const unsigned int off = td_var_offset(name); \
30 int __r = __fio_option_is_set((__td), off); \
Jens Axboe3c0f5262014-12-18 21:51:21 -070031 if (__r == -1) { \
Jens Axboe0703ea02014-12-19 08:04:48 -070032 dprint(FD_PARSE, "option %s/%u not found in map\n", \
33 __fio_stringify(name), off); \
Jens Axboe3c0f5262014-12-18 21:51:21 -070034 __r = 0; \
35 } \
36 __r; \
37})
Jens Axboe9c62acd2014-12-09 12:58:15 -070038
39extern void fio_option_mark_set(struct thread_options *, struct fio_option *);
40
Jens Axboef5b6bb82010-03-05 10:09:59 +010041static inline int o_match(struct fio_option *o, const char *opt)
42{
43 if (!strcmp(o->name, opt))
44 return 1;
45 else if (o->alias && !strcmp(o->alias, opt))
46 return 1;
47
48 return 0;
49}
50
51static inline struct fio_option *find_option(struct fio_option *options,
52 const char *opt)
53{
54 struct fio_option *o;
55
56 for (o = &options[0]; o->name; o++)
57 if (o_match(o, opt))
58 return o;
59
60 return NULL;
61}
62
Jens Axboe9af4a242012-03-16 10:13:49 +010063struct opt_group {
64 const char *name;
65 unsigned int mask;
66};
67
68enum opt_category {
Jens Axboee8b0e952012-03-19 14:37:08 +010069 __FIO_OPT_C_GENERAL = 0,
70 __FIO_OPT_C_IO,
71 __FIO_OPT_C_FILE,
72 __FIO_OPT_C_STAT,
73 __FIO_OPT_C_LOG,
Jens Axboe13fca822012-03-31 13:55:54 +020074 __FIO_OPT_C_PROFILE,
Jens Axboee90a0ad2013-04-10 19:43:59 +020075 __FIO_OPT_C_ENGINE,
Jens Axboee8b0e952012-03-19 14:37:08 +010076 __FIO_OPT_C_NR,
77
78 FIO_OPT_C_GENERAL = (1U << __FIO_OPT_C_GENERAL),
79 FIO_OPT_C_IO = (1U << __FIO_OPT_C_IO),
80 FIO_OPT_C_FILE = (1U << __FIO_OPT_C_FILE),
81 FIO_OPT_C_STAT = (1U << __FIO_OPT_C_STAT),
82 FIO_OPT_C_LOG = (1U << __FIO_OPT_C_LOG),
Jens Axboe13fca822012-03-31 13:55:54 +020083 FIO_OPT_C_PROFILE = (1U << __FIO_OPT_C_PROFILE),
Jens Axboee90a0ad2013-04-10 19:43:59 +020084 FIO_OPT_C_ENGINE = (1U << __FIO_OPT_C_ENGINE),
Jens Axboee8b0e952012-03-19 14:37:08 +010085 FIO_OPT_C_INVALID = (1U << __FIO_OPT_C_NR),
86};
87
88enum opt_category_group {
89 __FIO_OPT_G_RATE = 0,
Jens Axboee231bbe2012-03-16 19:16:27 +010090 __FIO_OPT_G_ZONE,
Jens Axboee8b0e952012-03-19 14:37:08 +010091 __FIO_OPT_G_RWMIX,
92 __FIO_OPT_G_VERIFY,
93 __FIO_OPT_G_TRIM,
94 __FIO_OPT_G_IOLOG,
95 __FIO_OPT_G_IO_DEPTH,
96 __FIO_OPT_G_IO_FLOW,
Jens Axboe06260372012-03-19 15:16:08 +010097 __FIO_OPT_G_DESC,
98 __FIO_OPT_G_FILENAME,
99 __FIO_OPT_G_IO_BASIC,
Jens Axboea1f6afe2012-03-19 20:44:33 +0100100 __FIO_OPT_G_CGROUP,
101 __FIO_OPT_G_RUNTIME,
Jens Axboe10860052012-03-19 20:56:53 +0100102 __FIO_OPT_G_PROCESS,
103 __FIO_OPT_G_CRED,
104 __FIO_OPT_G_CLOCK,
Jens Axboe3ceb4582012-03-19 21:27:02 +0100105 __FIO_OPT_G_IO_TYPE,
106 __FIO_OPT_G_THINKTIME,
107 __FIO_OPT_G_RANDOM,
108 __FIO_OPT_G_IO_BUF,
Jens Axboe13fca822012-03-31 13:55:54 +0200109 __FIO_OPT_G_TIOBENCH,
Jens Axboebc3f5522012-09-27 19:28:11 +0200110 __FIO_OPT_G_ERR,
Jens Axboee90a0ad2013-04-10 19:43:59 +0200111 __FIO_OPT_G_E4DEFRAG,
112 __FIO_OPT_G_NETIO,
113 __FIO_OPT_G_LIBAIO,
Jens Axboed4afedf2013-05-22 22:21:29 +0200114 __FIO_OPT_G_ACT,
Jens Axboe3e260a42013-12-09 12:38:53 -0700115 __FIO_OPT_G_LATPROF,
Daniel Gollubfc5c0342014-02-17 14:35:28 +0100116 __FIO_OPT_G_RBD,
chenh0e55d6b2014-03-27 15:19:43 -0400117 __FIO_OPT_G_GFAPI,
Jens Axboee231bbe2012-03-16 19:16:27 +0100118 __FIO_OPT_G_NR,
Jens Axboe9af4a242012-03-16 10:13:49 +0100119
Jens Axboee8b0e952012-03-19 14:37:08 +0100120 FIO_OPT_G_RATE = (1U << __FIO_OPT_G_RATE),
Jens Axboe9af4a242012-03-16 10:13:49 +0100121 FIO_OPT_G_ZONE = (1U << __FIO_OPT_G_ZONE),
Jens Axboee8b0e952012-03-19 14:37:08 +0100122 FIO_OPT_G_RWMIX = (1U << __FIO_OPT_G_RWMIX),
123 FIO_OPT_G_VERIFY = (1U << __FIO_OPT_G_VERIFY),
124 FIO_OPT_G_TRIM = (1U << __FIO_OPT_G_TRIM),
125 FIO_OPT_G_IOLOG = (1U << __FIO_OPT_G_IOLOG),
126 FIO_OPT_G_IO_DEPTH = (1U << __FIO_OPT_G_IO_DEPTH),
127 FIO_OPT_G_IO_FLOW = (1U << __FIO_OPT_G_IO_FLOW),
Jens Axboe06260372012-03-19 15:16:08 +0100128 FIO_OPT_G_DESC = (1U << __FIO_OPT_G_DESC),
129 FIO_OPT_G_FILENAME = (1U << __FIO_OPT_G_FILENAME),
130 FIO_OPT_G_IO_BASIC = (1U << __FIO_OPT_G_IO_BASIC),
Jens Axboea1f6afe2012-03-19 20:44:33 +0100131 FIO_OPT_G_CGROUP = (1U << __FIO_OPT_G_CGROUP),
132 FIO_OPT_G_RUNTIME = (1U << __FIO_OPT_G_RUNTIME),
Jens Axboe10860052012-03-19 20:56:53 +0100133 FIO_OPT_G_PROCESS = (1U << __FIO_OPT_G_PROCESS),
134 FIO_OPT_G_CRED = (1U << __FIO_OPT_G_CRED),
135 FIO_OPT_G_CLOCK = (1U << __FIO_OPT_G_CLOCK),
Jens Axboe3ceb4582012-03-19 21:27:02 +0100136 FIO_OPT_G_IO_TYPE = (1U << __FIO_OPT_G_IO_TYPE),
137 FIO_OPT_G_THINKTIME = (1U << __FIO_OPT_G_THINKTIME),
138 FIO_OPT_G_RANDOM = (1U << __FIO_OPT_G_RANDOM),
139 FIO_OPT_G_IO_BUF = (1U << __FIO_OPT_G_IO_BUF),
Jens Axboe13fca822012-03-31 13:55:54 +0200140 FIO_OPT_G_TIOBENCH = (1U << __FIO_OPT_G_TIOBENCH),
Jens Axboebc3f5522012-09-27 19:28:11 +0200141 FIO_OPT_G_ERR = (1U << __FIO_OPT_G_ERR),
Jens Axboee90a0ad2013-04-10 19:43:59 +0200142 FIO_OPT_G_E4DEFRAG = (1U << __FIO_OPT_G_E4DEFRAG),
143 FIO_OPT_G_NETIO = (1U << __FIO_OPT_G_NETIO),
144 FIO_OPT_G_LIBAIO = (1U << __FIO_OPT_G_LIBAIO),
Jens Axboed4afedf2013-05-22 22:21:29 +0200145 FIO_OPT_G_ACT = (1U << __FIO_OPT_G_ACT),
Jens Axboe3e260a42013-12-09 12:38:53 -0700146 FIO_OPT_G_LATPROF = (1U << __FIO_OPT_G_LATPROF),
Daniel Gollubfc5c0342014-02-17 14:35:28 +0100147 FIO_OPT_G_RBD = (1U << __FIO_OPT_G_RBD),
chenh0e55d6b2014-03-27 15:19:43 -0400148 FIO_OPT_G_GFAPI = (1U << __FIO_OPT_G_GFAPI),
Jens Axboe9af4a242012-03-16 10:13:49 +0100149 FIO_OPT_G_INVALID = (1U << __FIO_OPT_G_NR),
150};
151
152extern struct opt_group *opt_group_from_mask(unsigned int *mask);
Jens Axboee8b0e952012-03-19 14:37:08 +0100153extern struct opt_group *opt_group_cat_from_mask(unsigned int *mask);
Jens Axboec504ee52012-03-20 11:29:09 +0100154extern struct fio_option *fio_option_find(const char *name);
Jens Axboe3c3ed072012-03-27 09:12:39 +0200155extern unsigned int fio_get_kb_base(void *);
Jens Axboe9af4a242012-03-16 10:13:49 +0100156
Jens Axboe9f988e22010-03-04 10:42:38 +0100157#endif