projects
/
fio.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Makefile: missing conversion, and oslib/ dep cleanup
[fio.git]
/
client.c
diff --git
a/client.c
b/client.c
index 760ec85087b73bba197c95b033154f08c245bc7f..db472c4cb0b4cb1d87368358b8bb34d65f78d94c 100644
(file)
--- a/
client.c
+++ b/
client.c
@@
-117,7
+117,7
@@
static int read_data(int fd, void *data, size_t size)
static void fio_client_json_init(void)
{
static void fio_client_json_init(void)
{
- if (
output_format != FIO_OUTPUT_JSON
)
+ if (
!(output_format & FIO_OUTPUT_JSON)
)
return;
root = json_create_object();
json_object_add_value_string(root, "fio version", fio_version_string);
return;
root = json_create_object();
json_object_add_value_string(root, "fio version", fio_version_string);
@@
-129,9
+129,9
@@
static void fio_client_json_init(void)
static void fio_client_json_fini(void)
{
static void fio_client_json_fini(void)
{
- if (
output_format != FIO_OUTPUT_JSON
)
+ if (
!(output_format & FIO_OUTPUT_JSON)
)
return;
return;
- json_print_object(root);
+ json_print_object(root
, NULL
);
log_info("\n");
json_free_object(root);
root = NULL;
log_info("\n");
json_free_object(root);
root = NULL;
@@
-184,6
+184,17
@@
void fio_put_client(struct fio_client *client)
free(client);
}
free(client);
}
+static int fio_client_dec_jobs_eta(struct client_eta *eta, client_eta_op eta_fn)
+{
+ if (!--eta->pending) {
+ eta_fn(&eta->eta);
+ free(eta);
+ return 0;
+ }
+
+ return 1;
+}
+
static void remove_client(struct fio_client *client)
{
assert(client->refs);
static void remove_client(struct fio_client *client)
{
assert(client->refs);
@@
-523,11
+534,6
@@
static void sig_int(int sig)
fio_clients_terminate();
}
fio_clients_terminate();
}
-static void sig_show_status(int sig)
-{
- show_running_run_stats();
-}
-
static void client_signal_handler(void)
{
struct sigaction act;
static void client_signal_handler(void)
{
struct sigaction act;
@@
-891,6
+897,10
@@
static void convert_ts(struct thread_stat *dst, struct thread_stat *src)
dst->latency_target = le64_to_cpu(src->latency_target);
dst->latency_window = le64_to_cpu(src->latency_window);
dst->latency_percentile.u.f = fio_uint64_to_double(le64_to_cpu(src->latency_percentile.u.i));
dst->latency_target = le64_to_cpu(src->latency_target);
dst->latency_window = le64_to_cpu(src->latency_window);
dst->latency_percentile.u.f = fio_uint64_to_double(le64_to_cpu(src->latency_percentile.u.i));
+
+ dst->nr_block_infos = le64_to_cpu(src->nr_block_infos);
+ for (i = 0; i < dst->nr_block_infos; i++)
+ dst->block_infos[i] = le32_to_cpu(src->block_infos[i]);
}
static void convert_gs(struct group_run_stats *dst, struct group_run_stats *src)
}
static void convert_gs(struct group_run_stats *dst, struct group_run_stats *src)
@@
-926,7
+936,7
@@
static void handle_ts(struct fio_client *client, struct fio_net_cmd *cmd)
struct cmd_ts_pdu *p = (struct cmd_ts_pdu *) cmd->payload;
struct json_object *tsobj;
struct cmd_ts_pdu *p = (struct cmd_ts_pdu *) cmd->payload;
struct json_object *tsobj;
- tsobj = show_thread_status(&p->ts, &p->rs);
+ tsobj = show_thread_status(&p->ts, &p->rs
, NULL
);
client->did_stat = 1;
if (tsobj) {
json_object_add_client_info(tsobj, client);
client->did_stat = 1;
if (tsobj) {
json_object_add_client_info(tsobj, client);
@@
-946,7
+956,7
@@
static void handle_ts(struct fio_client *client, struct fio_net_cmd *cmd)
if (++sum_stat_nr == sum_stat_clients) {
strcpy(client_ts.name, "All clients");
if (++sum_stat_nr == sum_stat_clients) {
strcpy(client_ts.name, "All clients");
- tsobj = show_thread_status(&client_ts, &client_gs);
+ tsobj = show_thread_status(&client_ts, &client_gs
, NULL
);
if (tsobj) {
json_object_add_client_info(tsobj, client);
json_array_add_value_object(clients_array, tsobj);
if (tsobj) {
json_object_add_client_info(tsobj, client);
json_array_add_value_object(clients_array, tsobj);
@@
-958,7
+968,7
@@
static void handle_gs(struct fio_client *client, struct fio_net_cmd *cmd)
{
struct group_run_stats *gs = (struct group_run_stats *) cmd->payload;
{
struct group_run_stats *gs = (struct group_run_stats *) cmd->payload;
- show_group_stats(gs);
+ show_group_stats(gs
, NULL
);
}
static void handle_text(struct fio_client *client, struct fio_net_cmd *cmd)
}
static void handle_text(struct fio_client *client, struct fio_net_cmd *cmd)
@@
-1019,13
+1029,16
@@
static void handle_du(struct fio_client *client, struct fio_net_cmd *cmd)
log_info("\nDisk stats (read/write):\n");
}
log_info("\nDisk stats (read/write):\n");
}
- if (output_format
==
FIO_OUTPUT_JSON) {
+ if (output_format
&
FIO_OUTPUT_JSON) {
struct json_object *duobj;
json_array_add_disk_util(&du->dus, &du->agg, du_array);
duobj = json_array_last_value_object(du_array);
json_object_add_client_info(duobj, client);
struct json_object *duobj;
json_array_add_disk_util(&du->dus, &du->agg, du_array);
duobj = json_array_last_value_object(du_array);
json_object_add_client_info(duobj, client);
- } else
- print_disk_util(&du->dus, &du->agg, output_format == FIO_OUTPUT_TERSE);
+ }
+ if (output_format & FIO_OUTPUT_TERSE)
+ print_disk_util(&du->dus, &du->agg, 1, NULL);
+ if (output_format & FIO_OUTPUT_NORMAL)
+ print_disk_util(&du->dus, &du->agg, 0, NULL);
}
static void convert_jobs_eta(struct jobs_eta *je)
}
static void convert_jobs_eta(struct jobs_eta *je)
@@
-1087,14
+1100,6
@@
void fio_client_sum_jobs_eta(struct jobs_eta *dst, struct jobs_eta *je)
strcpy((char *) dst->run_str, (char *) je->run_str);
}
strcpy((char *) dst->run_str, (char *) je->run_str);
}
-void fio_client_dec_jobs_eta(struct client_eta *eta, client_eta_op eta_fn)
-{
- if (!--eta->pending) {
- eta_fn(&eta->eta);
- free(eta);
- }
-}
-
static void remove_reply_cmd(struct fio_client *client, struct fio_net_cmd *cmd)
{
struct fio_net_cmd_reply *reply = NULL;
static void remove_reply_cmd(struct fio_client *client, struct fio_net_cmd *cmd)
{
struct fio_net_cmd_reply *reply = NULL;
@@
-1490,9
+1495,15
@@
int fio_handle_client(struct fio_client *client)
break;
case FIO_NET_CMD_VTRIGGER: {
struct all_io_list *pdu = (struct all_io_list *) cmd->payload;
break;
case FIO_NET_CMD_VTRIGGER: {
struct all_io_list *pdu = (struct all_io_list *) cmd->payload;
- char buf[64];
+ char buf[128];
+ int off = 0;
+
+ if (aux_path) {
+ strcpy(buf, aux_path);
+ off = strlen(buf);
+ }
- __verify_save_state(pdu, server_name(client,
buf, sizeof(buf)
));
+ __verify_save_state(pdu, server_name(client,
&buf[off], sizeof(buf) - off
));
exec_trigger(trigger_cmd);
break;
}
exec_trigger(trigger_cmd);
break;
}
@@
-1569,8
+1580,10
@@
static void request_client_etas(struct client_ops *ops)
(uintptr_t) eta, &client->cmd_list);
}
(uintptr_t) eta, &client->cmd_list);
}
- while (skipped--)
- fio_client_dec_jobs_eta(eta, ops->eta);
+ while (skipped--) {
+ if (!fio_client_dec_jobs_eta(eta, ops->eta))
+ break;
+ }
dprint(FD_NET, "client: requested eta tag %p\n", eta);
}
dprint(FD_NET, "client: requested eta tag %p\n", eta);
}