1 // SPDX-License-Identifier: GPL-2.0
4 * Copyright (c) 2003, 2010, Oracle and/or its affiliates. All rights reserved.
5 * Use is subject to license terms.
7 * Copyright (c) 2011, Intel Corporation.
11 * This file is part of Lustre, http://www.lustre.org/
21 #include <sys/types.h>
25 #include <libcfs/util/param.h>
27 static double timenow(void)
31 gettimeofday (&tv, NULL);
32 return (tv.tv_sec + tv.tv_usec / 1000000.0);
36 unsigned long msgs_alloc;
37 unsigned long msgs_max;
39 unsigned long send_count;
40 unsigned long recv_count;
41 unsigned long route_count;
42 unsigned long drop_count;
43 unsigned long long send_length;
44 unsigned long long recv_length;
45 unsigned long long route_length;
46 unsigned long long drop_length;
49 static unsigned long long subull(unsigned long long a, unsigned long long b)
52 return -1ULL - b + a + 1;
57 static unsigned long long subul(unsigned long a, unsigned long b)
60 return -1UL - b + a + 1;
65 static double rul(unsigned long a, double secs)
67 return (double)a/secs;
70 static double rull(unsigned long long a, double secs)
72 return (double)a/secs;
75 static void do_stat(int fd)
77 static char buffer[1024];
78 static double last = 0.0;
79 static counters_t old_counter;
82 counters_t new_counter;
86 lseek (fd, 0, SEEK_SET);
88 n = read(fd, buffer, sizeof(buffer) - 1);
91 fprintf (stderr, "Can't read statfile\n");
96 n = sscanf(buffer, "%lu %lu %lu %lu %lu %lu %lu %llu %llu %llu %llu",
97 &new_counter.msgs_alloc, &new_counter.msgs_max,
99 &new_counter.send_count, &new_counter.recv_count,
100 &new_counter.route_count, &new_counter.drop_count,
101 &new_counter.send_length, &new_counter.recv_length,
102 &new_counter.route_length, &new_counter.drop_length);
105 fprintf (stderr, "Can't parse statfile\n");
110 printf("M %lu(%lu) E %lu S %llu/%lu R %llu/%lu F %llu/%lu "
112 new_counter.msgs_alloc, new_counter.msgs_max,
114 new_counter.send_length, new_counter.send_count,
115 new_counter.recv_length, new_counter.recv_count,
116 new_counter.route_length, new_counter.route_count,
117 new_counter.drop_length, new_counter.drop_count);
121 counter.msgs_alloc = new_counter.msgs_alloc;
122 counter.msgs_max = new_counter.msgs_max;
124 counter.errors = subul(new_counter.errors, old_counter.errors);
125 counter.send_count = subul(new_counter.send_count, old_counter.send_count);
126 counter.recv_count = subul(new_counter.recv_count, old_counter.recv_count);
127 counter.route_count = subul(new_counter.route_count, old_counter.route_count);
128 counter.drop_count = subul(new_counter.drop_count, old_counter.drop_count);
129 counter.send_length = subull(new_counter.send_length, old_counter.send_length);
130 counter.recv_length = subull(new_counter.recv_length, old_counter.recv_length);
131 counter.route_length = subull(new_counter.route_length, old_counter.route_length);
132 counter.drop_length = subull(new_counter.drop_length, old_counter.drop_length);
134 printf ("M %3lu(%3lu) E %0.0f S %7.2f/%6.0f R %7.2f/%6.0f F %7.2f/%6.0f D %4.2f/%0.0f\n",
135 counter.msgs_alloc, counter.msgs_max,
136 rul(counter.errors,t),
137 rull(counter.send_length,t*1024.0*1024.0), rul(counter.send_count, t),
138 rull(counter.recv_length,t*1024.0*1024.0), rul(counter.recv_count, t),
139 rull(counter.route_length,t*1024.0*1024.0), rul(counter.route_count, t),
140 rull(counter.drop_length,t*1024.0*1024.0), rul(counter.drop_count, t));
143 old_counter = new_counter;
146 lseek (fd, 0, SEEK_SET);
150 int main(int argc, char **argv)
157 interval = atoi(argv[1]);
159 if (cfs_get_param_paths(&path, "stats") != 0) {
160 fprintf(stderr, "LNet stats not available\n");
164 fd = open(path.gl_pathv[0], O_RDONLY);
166 fprintf(stderr, "failed to open '%s': %s\n", path.gl_pathv[0],
168 cfs_free_param_data(&path);
171 cfs_free_param_data(&path);