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