blob: de9f6109fa1b474e72a1b60df667f99f7455735d [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 Axboef5b6bb82010-03-05 10:09:59 +010025static inline int o_match(struct fio_option *o, const char *opt)
26{
27 if (!strcmp(o->name, opt))
28 return 1;
29 else if (o->alias && !strcmp(o->alias, opt))
30 return 1;
31
32 return 0;
33}
34
35static inline struct fio_option *find_option(struct fio_option *options,
36 const char *opt)
37{
38 struct fio_option *o;
39
40 for (o = &options[0]; o->name; o++)
41 if (o_match(o, opt))
42 return o;
43
44 return NULL;
45}
46
Jens Axboe9af4a242012-03-16 10:13:49 +010047struct opt_group {
48 const char *name;
49 unsigned int mask;
50};
51
52enum opt_category {
Jens Axboee8b0e952012-03-19 14:37:08 +010053 __FIO_OPT_C_GENERAL = 0,
54 __FIO_OPT_C_IO,
55 __FIO_OPT_C_FILE,
56 __FIO_OPT_C_STAT,
57 __FIO_OPT_C_LOG,
Jens Axboe13fca822012-03-31 13:55:54 +020058 __FIO_OPT_C_PROFILE,
Jens Axboee90a0ad2013-04-10 19:43:59 +020059 __FIO_OPT_C_ENGINE,
Jens Axboee8b0e952012-03-19 14:37:08 +010060 __FIO_OPT_C_NR,
61
62 FIO_OPT_C_GENERAL = (1U << __FIO_OPT_C_GENERAL),
63 FIO_OPT_C_IO = (1U << __FIO_OPT_C_IO),
64 FIO_OPT_C_FILE = (1U << __FIO_OPT_C_FILE),
65 FIO_OPT_C_STAT = (1U << __FIO_OPT_C_STAT),
66 FIO_OPT_C_LOG = (1U << __FIO_OPT_C_LOG),
Jens Axboe13fca822012-03-31 13:55:54 +020067 FIO_OPT_C_PROFILE = (1U << __FIO_OPT_C_PROFILE),
Jens Axboee90a0ad2013-04-10 19:43:59 +020068 FIO_OPT_C_ENGINE = (1U << __FIO_OPT_C_ENGINE),
Jens Axboee8b0e952012-03-19 14:37:08 +010069 FIO_OPT_C_INVALID = (1U << __FIO_OPT_C_NR),
70};
71
72enum opt_category_group {
73 __FIO_OPT_G_RATE = 0,
Jens Axboee231bbe2012-03-16 19:16:27 +010074 __FIO_OPT_G_ZONE,
Jens Axboee8b0e952012-03-19 14:37:08 +010075 __FIO_OPT_G_RWMIX,
76 __FIO_OPT_G_VERIFY,
77 __FIO_OPT_G_TRIM,
78 __FIO_OPT_G_IOLOG,
79 __FIO_OPT_G_IO_DEPTH,
80 __FIO_OPT_G_IO_FLOW,
Jens Axboe06260372012-03-19 15:16:08 +010081 __FIO_OPT_G_DESC,
82 __FIO_OPT_G_FILENAME,
83 __FIO_OPT_G_IO_BASIC,
Jens Axboea1f6afe2012-03-19 20:44:33 +010084 __FIO_OPT_G_CGROUP,
85 __FIO_OPT_G_RUNTIME,
Jens Axboe10860052012-03-19 20:56:53 +010086 __FIO_OPT_G_PROCESS,
87 __FIO_OPT_G_CRED,
88 __FIO_OPT_G_CLOCK,
Jens Axboe3ceb4582012-03-19 21:27:02 +010089 __FIO_OPT_G_IO_TYPE,
90 __FIO_OPT_G_THINKTIME,
91 __FIO_OPT_G_RANDOM,
92 __FIO_OPT_G_IO_BUF,
Jens Axboe13fca822012-03-31 13:55:54 +020093 __FIO_OPT_G_TIOBENCH,
Jens Axboebc3f5522012-09-27 19:28:11 +020094 __FIO_OPT_G_ERR,
Jens Axboee90a0ad2013-04-10 19:43:59 +020095 __FIO_OPT_G_E4DEFRAG,
96 __FIO_OPT_G_NETIO,
97 __FIO_OPT_G_LIBAIO,
Jens Axboed4afedf2013-05-22 22:21:29 +020098 __FIO_OPT_G_ACT,
Jens Axboe3e260a42013-12-09 12:38:53 -070099 __FIO_OPT_G_LATPROF,
Daniel Gollubfc5c0342014-02-17 14:35:28 +0100100 __FIO_OPT_G_RBD,
Jens Axboee231bbe2012-03-16 19:16:27 +0100101 __FIO_OPT_G_NR,
Jens Axboe9af4a242012-03-16 10:13:49 +0100102
Jens Axboee8b0e952012-03-19 14:37:08 +0100103 FIO_OPT_G_RATE = (1U << __FIO_OPT_G_RATE),
Jens Axboe9af4a242012-03-16 10:13:49 +0100104 FIO_OPT_G_ZONE = (1U << __FIO_OPT_G_ZONE),
Jens Axboee8b0e952012-03-19 14:37:08 +0100105 FIO_OPT_G_RWMIX = (1U << __FIO_OPT_G_RWMIX),
106 FIO_OPT_G_VERIFY = (1U << __FIO_OPT_G_VERIFY),
107 FIO_OPT_G_TRIM = (1U << __FIO_OPT_G_TRIM),
108 FIO_OPT_G_IOLOG = (1U << __FIO_OPT_G_IOLOG),
109 FIO_OPT_G_IO_DEPTH = (1U << __FIO_OPT_G_IO_DEPTH),
110 FIO_OPT_G_IO_FLOW = (1U << __FIO_OPT_G_IO_FLOW),
Jens Axboe06260372012-03-19 15:16:08 +0100111 FIO_OPT_G_DESC = (1U << __FIO_OPT_G_DESC),
112 FIO_OPT_G_FILENAME = (1U << __FIO_OPT_G_FILENAME),
113 FIO_OPT_G_IO_BASIC = (1U << __FIO_OPT_G_IO_BASIC),
Jens Axboea1f6afe2012-03-19 20:44:33 +0100114 FIO_OPT_G_CGROUP = (1U << __FIO_OPT_G_CGROUP),
115 FIO_OPT_G_RUNTIME = (1U << __FIO_OPT_G_RUNTIME),
Jens Axboe10860052012-03-19 20:56:53 +0100116 FIO_OPT_G_PROCESS = (1U << __FIO_OPT_G_PROCESS),
117 FIO_OPT_G_CRED = (1U << __FIO_OPT_G_CRED),
118 FIO_OPT_G_CLOCK = (1U << __FIO_OPT_G_CLOCK),
Jens Axboe3ceb4582012-03-19 21:27:02 +0100119 FIO_OPT_G_IO_TYPE = (1U << __FIO_OPT_G_IO_TYPE),
120 FIO_OPT_G_THINKTIME = (1U << __FIO_OPT_G_THINKTIME),
121 FIO_OPT_G_RANDOM = (1U << __FIO_OPT_G_RANDOM),
122 FIO_OPT_G_IO_BUF = (1U << __FIO_OPT_G_IO_BUF),
Jens Axboe13fca822012-03-31 13:55:54 +0200123 FIO_OPT_G_TIOBENCH = (1U << __FIO_OPT_G_TIOBENCH),
Jens Axboebc3f5522012-09-27 19:28:11 +0200124 FIO_OPT_G_ERR = (1U << __FIO_OPT_G_ERR),
Jens Axboee90a0ad2013-04-10 19:43:59 +0200125 FIO_OPT_G_E4DEFRAG = (1U << __FIO_OPT_G_E4DEFRAG),
126 FIO_OPT_G_NETIO = (1U << __FIO_OPT_G_NETIO),
127 FIO_OPT_G_LIBAIO = (1U << __FIO_OPT_G_LIBAIO),
Jens Axboed4afedf2013-05-22 22:21:29 +0200128 FIO_OPT_G_ACT = (1U << __FIO_OPT_G_ACT),
Jens Axboe3e260a42013-12-09 12:38:53 -0700129 FIO_OPT_G_LATPROF = (1U << __FIO_OPT_G_LATPROF),
Daniel Gollubfc5c0342014-02-17 14:35:28 +0100130 FIO_OPT_G_RBD = (1U << __FIO_OPT_G_RBD),
Jens Axboe9af4a242012-03-16 10:13:49 +0100131 FIO_OPT_G_INVALID = (1U << __FIO_OPT_G_NR),
132};
133
134extern struct opt_group *opt_group_from_mask(unsigned int *mask);
Jens Axboee8b0e952012-03-19 14:37:08 +0100135extern struct opt_group *opt_group_cat_from_mask(unsigned int *mask);
Jens Axboec504ee52012-03-20 11:29:09 +0100136extern struct fio_option *fio_option_find(const char *name);
Jens Axboe3c3ed072012-03-27 09:12:39 +0200137extern unsigned int fio_get_kb_base(void *);
Jens Axboe9af4a242012-03-16 10:13:49 +0100138
Jens Axboe9f988e22010-03-04 10:42:38 +0100139#endif