Merge branch 'ci' of https://github.com/sitsofe/fio
[fio.git] / client.h
... / ...
CommitLineData
1#ifndef CLIENT_H
2#define CLIENT_H
3
4#include <sys/socket.h>
5#include <sys/un.h>
6#include <netinet/in.h>
7#include <arpa/inet.h>
8
9#include "lib/types.h"
10#include "stat.h"
11
12struct fio_net_cmd;
13struct client_ops;
14
15enum {
16 Client_created = 0,
17 Client_connected = 1,
18 Client_started = 2,
19 Client_running = 3,
20 Client_stopped = 4,
21 Client_exited = 5,
22};
23
24struct client_file {
25 char *file;
26 bool remote;
27};
28
29struct fio_client {
30 struct flist_head list;
31 struct flist_head hash_list;
32 struct flist_head arg_list;
33 union {
34 struct sockaddr_in addr;
35 struct sockaddr_in6 addr6;
36 struct sockaddr_un addr_un;
37 };
38 char *hostname;
39 int port;
40 int fd;
41 unsigned int refs;
42
43 char *name;
44
45 struct flist_head *opt_lists;
46
47 int state;
48
49 bool skip_newline;
50 bool is_sock;
51 bool disk_stats_shown;
52 unsigned int jobs;
53 unsigned int nr_stat;
54 int error;
55 int signal;
56 int ipv6;
57 bool sent_job;
58 bool did_stat;
59 uint32_t type;
60
61 uint32_t thread_number;
62 uint32_t groupid;
63
64 struct flist_head eta_list;
65 struct client_eta *eta_in_flight;
66 unsigned int eta_timeouts;
67
68 struct flist_head cmd_list;
69
70 uint16_t argc;
71 char **argv;
72
73 struct client_ops *ops;
74 void *client_data;
75
76 struct client_file *files;
77 unsigned int nr_files;
78};
79
80typedef void (client_cmd_op)(struct fio_client *, struct fio_net_cmd *);
81typedef void (client_eta_op)(struct jobs_eta *je);
82typedef void (client_timed_out_op)(struct fio_client *);
83typedef void (client_jobs_eta_op)(struct fio_client *client, struct jobs_eta *je);
84
85struct client_ops {
86 client_cmd_op *text;
87 client_cmd_op *disk_util;
88 client_cmd_op *thread_status;
89 client_cmd_op *group_stats;
90 client_jobs_eta_op *jobs_eta;
91 client_eta_op *eta;
92 client_cmd_op *probe;
93 client_cmd_op *quit;
94 client_cmd_op *add_job;
95 client_cmd_op *update_job;
96 client_timed_out_op *timed_out;
97 client_cmd_op *stop;
98 client_cmd_op *start;
99 client_cmd_op *job_start;
100 client_timed_out_op *removed;
101
102 unsigned int eta_msec;
103 int stay_connected;
104 uint32_t client_type;
105};
106
107extern struct client_ops fio_client_ops;
108
109struct client_eta {
110 unsigned int pending;
111 struct jobs_eta eta;
112};
113
114extern int fio_handle_client(struct fio_client *);
115extern void fio_client_sum_jobs_eta(struct jobs_eta *dst, struct jobs_eta *je);
116
117enum {
118 Fio_client_ipv4 = 1,
119 Fio_client_ipv6,
120 Fio_client_socket,
121};
122
123extern int fio_client_connect(struct fio_client *);
124extern int fio_clients_connect(void);
125extern int fio_start_client(struct fio_client *);
126extern int fio_start_all_clients(void);
127extern int fio_clients_send_ini(const char *);
128extern int fio_client_send_ini(struct fio_client *, const char *, bool);
129extern int fio_handle_clients(struct client_ops *);
130extern int fio_client_add(struct client_ops *, const char *, void **);
131extern struct fio_client *fio_client_add_explicit(struct client_ops *, const char *, int, int);
132extern void fio_client_add_cmd_option(void *, const char *);
133extern int fio_client_add_ini_file(void *, const char *, bool);
134extern int fio_client_terminate(struct fio_client *);
135extern struct fio_client *fio_get_client(struct fio_client *);
136extern void fio_put_client(struct fio_client *);
137extern int fio_client_update_options(struct fio_client *, struct thread_options *, uint64_t *);
138extern int fio_client_wait_for_reply(struct fio_client *, uint64_t);
139extern int fio_clients_send_trigger(const char *);
140
141#define FIO_CLIENT_DEF_ETA_MSEC 900
142
143enum {
144 FIO_CLIENT_TYPE_CLI = 1,
145 FIO_CLIENT_TYPE_GUI = 2,
146};
147
148extern int sum_stat_clients;
149extern struct thread_stat client_ts;
150extern struct group_run_stats client_gs;
151
152#endif
153