log: disable log, if realloc fails
[fio.git] / profile.c
CommitLineData
79d16311
JA
1#include "fio.h"
2#include "profile.h"
3#include "debug.h"
4#include "flist.h"
e2de69da 5#include "options.h"
79d16311
JA
6
7static FLIST_HEAD(profile_list);
8
15dc1934 9struct profile_ops *find_profile(const char *profile)
79d16311 10{
15dc1934 11 struct profile_ops *ops = NULL;
79d16311
JA
12 struct flist_head *n;
13
79d16311
JA
14 flist_for_each(n, &profile_list) {
15 ops = flist_entry(n, struct profile_ops, list);
16 if (!strcmp(profile, ops->name))
17 break;
18
19 ops = NULL;
20 }
21
15dc1934
JA
22 return ops;
23}
24
25int load_profile(const char *profile)
26{
27 struct profile_ops *ops;
28
29 dprint(FD_PROFILE, "loading profile '%s'\n", profile);
30
31 ops = find_profile(profile);
79d16311 32 if (ops) {
d4afedfd 33 if (ops->prep_cmd()) {
90777558 34 log_err("fio: profile %s prep failed\n", profile);
d4afedfd
JA
35 return 1;
36 }
46bcd498 37 add_job_opts(ops->cmdline, FIO_CLIENT_TYPE_CLI);
79d16311
JA
38 return 0;
39 }
40
41 log_err("fio: profile '%s' not found\n", profile);
42 return 1;
43}
44
07b3232d 45static int add_profile_options(struct profile_ops *ops)
e2de69da 46{
07b3232d 47 struct fio_option *o;
3c3ed070 48
e2de69da 49 if (!ops->options)
07b3232d 50 return 0;
e2de69da 51
07b3232d
JA
52 o = ops->options;
53 while (o->name) {
54 o->prof_name = ops->name;
55 if (add_option(o))
56 return 1;
57 o++;
e2de69da 58 }
07b3232d
JA
59
60 return 0;
e2de69da
JA
61}
62
07b3232d 63int register_profile(struct profile_ops *ops)
79d16311 64{
07b3232d
JA
65 int ret;
66
79d16311 67 dprint(FD_PROFILE, "register profile '%s'\n", ops->name);
f5b6bb85 68
07b3232d 69 ret = add_profile_options(ops);
f5b6bb85
JA
70 if (!ret) {
71 flist_add_tail(&ops->list, &profile_list);
72 add_opt_posval("profile", ops->name, ops->desc);
73 return 0;
74 }
07b3232d 75
f5b6bb85 76 invalidate_profile_options(ops->name);
07b3232d 77 return ret;
79d16311
JA
78}
79
80void unregister_profile(struct profile_ops *ops)
81{
82 dprint(FD_PROFILE, "unregister profile '%s'\n", ops->name);
83 flist_del(&ops->list);
07b3232d 84 invalidate_profile_options(ops->name);
f5b6bb85 85 del_opt_posval("profile", ops->name);
79d16311 86}
15dc1934
JA
87
88void profile_add_hooks(struct thread_data *td)
89{
90 struct profile_ops *ops;
91
92 if (!exec_profile)
93 return;
94
95 ops = find_profile(exec_profile);
96 if (!ops)
97 return;
98
d72be545 99 if (ops->io_ops) {
7eb36574 100 td->prof_io_ops = *ops->io_ops;
d72be545
JA
101 td->flags |= TD_F_PROFILE_OPS;
102 }
15dc1934 103}
58c55ba0
JA
104
105int profile_td_init(struct thread_data *td)
106{
107 struct prof_io_ops *ops = &td->prof_io_ops;
108
109 if (ops->td_init)
110 return ops->td_init(td);
111
112 return 0;
113}
114
115void profile_td_exit(struct thread_data *td)
116{
117 struct prof_io_ops *ops = &td->prof_io_ops;
118
119 if (ops->td_exit)
120 ops->td_exit(td);
121}