blob: 786574f84b498ddc61533fb73305018df38e9730 [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 *);
Jens Axboef5b6bb82010-03-05 10:09:59 +010020
Jens Axboe9af4a242012-03-16 10:13:49 +010021extern struct fio_option fio_options[FIO_MAX_OPTS];
22
Jens Axboef5b6bb82010-03-05 10:09:59 +010023static inline int o_match(struct fio_option *o, const char *opt)
24{
25 if (!strcmp(o->name, opt))
26 return 1;
27 else if (o->alias && !strcmp(o->alias, opt))
28 return 1;
29
30 return 0;
31}
32
33static inline struct fio_option *find_option(struct fio_option *options,
34 const char *opt)
35{
36 struct fio_option *o;
37
38 for (o = &options[0]; o->name; o++)
39 if (o_match(o, opt))
40 return o;
41
42 return NULL;
43}
44
Jens Axboe9af4a242012-03-16 10:13:49 +010045struct opt_group {
46 const char *name;
47 unsigned int mask;
48};
49
50enum opt_category {
Jens Axboee8b0e952012-03-19 14:37:08 +010051 __FIO_OPT_C_GENERAL = 0,
52 __FIO_OPT_C_IO,
53 __FIO_OPT_C_FILE,
54 __FIO_OPT_C_STAT,
55 __FIO_OPT_C_LOG,
Jens Axboe13fca822012-03-31 13:55:54 +020056 __FIO_OPT_C_PROFILE,
Jens Axboee8b0e952012-03-19 14:37:08 +010057 __FIO_OPT_C_NR,
58
59 FIO_OPT_C_GENERAL = (1U << __FIO_OPT_C_GENERAL),
60 FIO_OPT_C_IO = (1U << __FIO_OPT_C_IO),
61 FIO_OPT_C_FILE = (1U << __FIO_OPT_C_FILE),
62 FIO_OPT_C_STAT = (1U << __FIO_OPT_C_STAT),
63 FIO_OPT_C_LOG = (1U << __FIO_OPT_C_LOG),
Jens Axboe13fca822012-03-31 13:55:54 +020064 FIO_OPT_C_PROFILE = (1U << __FIO_OPT_C_PROFILE),
Jens Axboee8b0e952012-03-19 14:37:08 +010065 FIO_OPT_C_INVALID = (1U << __FIO_OPT_C_NR),
66};
67
68enum opt_category_group {
69 __FIO_OPT_G_RATE = 0,
Jens Axboee231bbe2012-03-16 19:16:27 +010070 __FIO_OPT_G_ZONE,
Jens Axboee8b0e952012-03-19 14:37:08 +010071 __FIO_OPT_G_RWMIX,
72 __FIO_OPT_G_VERIFY,
73 __FIO_OPT_G_TRIM,
74 __FIO_OPT_G_IOLOG,
75 __FIO_OPT_G_IO_DEPTH,
76 __FIO_OPT_G_IO_FLOW,
Jens Axboe06260372012-03-19 15:16:08 +010077 __FIO_OPT_G_DESC,
78 __FIO_OPT_G_FILENAME,
79 __FIO_OPT_G_IO_BASIC,
Jens Axboea1f6afe2012-03-19 20:44:33 +010080 __FIO_OPT_G_CGROUP,
81 __FIO_OPT_G_RUNTIME,
Jens Axboe10860052012-03-19 20:56:53 +010082 __FIO_OPT_G_PROCESS,
83 __FIO_OPT_G_CRED,
84 __FIO_OPT_G_CLOCK,
Jens Axboe3ceb4582012-03-19 21:27:02 +010085 __FIO_OPT_G_IO_TYPE,
86 __FIO_OPT_G_THINKTIME,
87 __FIO_OPT_G_RANDOM,
88 __FIO_OPT_G_IO_BUF,
Jens Axboe13fca822012-03-31 13:55:54 +020089 __FIO_OPT_G_TIOBENCH,
Jens Axboee231bbe2012-03-16 19:16:27 +010090 __FIO_OPT_G_NR,
Jens Axboe9af4a242012-03-16 10:13:49 +010091
Jens Axboee8b0e952012-03-19 14:37:08 +010092 FIO_OPT_G_RATE = (1U << __FIO_OPT_G_RATE),
Jens Axboe9af4a242012-03-16 10:13:49 +010093 FIO_OPT_G_ZONE = (1U << __FIO_OPT_G_ZONE),
Jens Axboee8b0e952012-03-19 14:37:08 +010094 FIO_OPT_G_RWMIX = (1U << __FIO_OPT_G_RWMIX),
95 FIO_OPT_G_VERIFY = (1U << __FIO_OPT_G_VERIFY),
96 FIO_OPT_G_TRIM = (1U << __FIO_OPT_G_TRIM),
97 FIO_OPT_G_IOLOG = (1U << __FIO_OPT_G_IOLOG),
98 FIO_OPT_G_IO_DEPTH = (1U << __FIO_OPT_G_IO_DEPTH),
99 FIO_OPT_G_IO_FLOW = (1U << __FIO_OPT_G_IO_FLOW),
Jens Axboe06260372012-03-19 15:16:08 +0100100 FIO_OPT_G_DESC = (1U << __FIO_OPT_G_DESC),
101 FIO_OPT_G_FILENAME = (1U << __FIO_OPT_G_FILENAME),
102 FIO_OPT_G_IO_BASIC = (1U << __FIO_OPT_G_IO_BASIC),
Jens Axboea1f6afe2012-03-19 20:44:33 +0100103 FIO_OPT_G_CGROUP = (1U << __FIO_OPT_G_CGROUP),
104 FIO_OPT_G_RUNTIME = (1U << __FIO_OPT_G_RUNTIME),
Jens Axboe10860052012-03-19 20:56:53 +0100105 FIO_OPT_G_PROCESS = (1U << __FIO_OPT_G_PROCESS),
106 FIO_OPT_G_CRED = (1U << __FIO_OPT_G_CRED),
107 FIO_OPT_G_CLOCK = (1U << __FIO_OPT_G_CLOCK),
Jens Axboe3ceb4582012-03-19 21:27:02 +0100108 FIO_OPT_G_IO_TYPE = (1U << __FIO_OPT_G_IO_TYPE),
109 FIO_OPT_G_THINKTIME = (1U << __FIO_OPT_G_THINKTIME),
110 FIO_OPT_G_RANDOM = (1U << __FIO_OPT_G_RANDOM),
111 FIO_OPT_G_IO_BUF = (1U << __FIO_OPT_G_IO_BUF),
Jens Axboe13fca822012-03-31 13:55:54 +0200112 FIO_OPT_G_TIOBENCH = (1U << __FIO_OPT_G_TIOBENCH),
Jens Axboe9af4a242012-03-16 10:13:49 +0100113 FIO_OPT_G_INVALID = (1U << __FIO_OPT_G_NR),
114};
115
116extern struct opt_group *opt_group_from_mask(unsigned int *mask);
Jens Axboee8b0e952012-03-19 14:37:08 +0100117extern struct opt_group *opt_group_cat_from_mask(unsigned int *mask);
Jens Axboec504ee52012-03-20 11:29:09 +0100118extern struct fio_option *fio_option_find(const char *name);
Jens Axboe3c3ed072012-03-27 09:12:39 +0200119extern unsigned int fio_get_kb_base(void *);
Jens Axboe9af4a242012-03-16 10:13:49 +0100120
Jens Axboe9f988e22010-03-04 10:42:38 +0100121#endif