1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23#define FOR_time
24#include "toys.h"
25
26
27void time_main(void)
28{
29 struct timespec ts, ts2;
30 struct rusage ru;
31 long long sec[3];
32 int stat, ii, idx, nano[3];
33 pid_t pid;
34 char *labels[] = {"\nreal"+!!FLAG(p), "user", "sys"}, **label = labels,
35 *vlabels[] ={"Real", "User", "System"}, tab = toys.optflags ? ' ' : '\t';
36
37 if (FLAG(v)) label = vlabels;
38 clock_gettime(CLOCK_MONOTONIC, &ts);
39 if (!(pid = XVFORK())) xexec(toys.optargs);
40 wait4(pid, &stat, 0, &ru);
41 clock_gettime(CLOCK_MONOTONIC, &ts2);
42 sec[0] = nanodiff(&ts, &ts2);
43 nano[0] = (sec[0] % 1000000000)/(toys.optflags ? 1000 : 1000000);
44 sec[0] /= 1000000000;
45 sec[1] = ru.ru_utime.tv_sec, nano[1] = ru.ru_utime.tv_usec;
46 sec[2] = ru.ru_stime.tv_sec, nano[2] = ru.ru_stime.tv_usec;
47 for (ii = idx = 0; ii<3; ii++)
48 idx += sprintf(toybuf+idx, "%s%s%c%lld.%0*d\n", label[ii],
49 FLAG(v) ? " time (s):" : "", tab, sec[ii],
50 6>>!toys.optflags, nano[ii]);
51 if (FLAG(v)) idx += sprintf(toybuf+idx,
52 "Max RSS (KiB): %ld\nMajor faults: %ld\n"
53 "Minor faults: %ld\nFile system inputs: %ld\nFile system outputs: %ld\n"
54 "Voluntary context switches: %ld\nInvoluntary context switches: %ld\n",
55 ru.ru_maxrss, ru.ru_majflt, ru.ru_minflt, ru.ru_inblock,
56 ru.ru_oublock, ru.ru_nvcsw, ru.ru_nivcsw);
57 writeall(2, toybuf, idx);
58
59 toys.exitval = WIFEXITED(stat) ? WEXITSTATUS(stat) : WTERMSIG(stat);
60}
61