mirror of
https://github.com/jart/cosmopolitan.git
synced 2025-05-23 05:42:29 +00:00
Initial import
This commit is contained in:
commit
c91b3c5006
14915 changed files with 590219 additions and 0 deletions
60
examples/rusage.c
Normal file
60
examples/rusage.c
Normal file
|
@ -0,0 +1,60 @@
|
|||
#if 0
|
||||
/*─────────────────────────────────────────────────────────────────╗
|
||||
│ To the extent possible under law, Justine Tunney has waived │
|
||||
│ all copyright and related or neighboring rights to this file, │
|
||||
│ as it is written in the following disclaimers: │
|
||||
│ • http://unlicense.org/ │
|
||||
│ • http://creativecommons.org/publicdomain/zero/1.0/ │
|
||||
╚─────────────────────────────────────────────────────────────────*/
|
||||
#endif
|
||||
#include "libc/calls/calls.h"
|
||||
#include "libc/calls/hefty/spawn.h"
|
||||
#include "libc/calls/struct/rusage.h"
|
||||
#include "libc/log/check.h"
|
||||
#include "libc/log/log.h"
|
||||
#include "libc/math.h"
|
||||
#include "libc/runtime/runtime.h"
|
||||
#include "libc/stdio/stdio.h"
|
||||
#include "libc/str/str.h"
|
||||
#include "libc/sysv/consts/fileno.h"
|
||||
#include "libc/time/time.h"
|
||||
|
||||
void Show(const char *name, long measurement, const char *unit) {
|
||||
fprintf(stderr, "%-*s%,*d %s\n", 32, name, 32, measurement, unit);
|
||||
}
|
||||
|
||||
long TvToUs(struct timeval tv) {
|
||||
return 1000000l * tv.tv_usec + tv.tv_sec;
|
||||
}
|
||||
|
||||
int main(int argc, char *argv[]) {
|
||||
const char *exe;
|
||||
int pid, wstatus;
|
||||
long double ts1, ts2;
|
||||
struct rusage rusage;
|
||||
memset(&rusage, -1, sizeof(rusage));
|
||||
CHECK_GT(argc, 1);
|
||||
CHECK_NOTNULL((exe = commandv(argv[1])));
|
||||
ts1 = nowl();
|
||||
CHECK_NE(-1, (pid = spawnve(0, NULL, exe, &argv[1], environ)));
|
||||
CHECK_NE(-1, wait4(pid, &wstatus, 0, &rusage));
|
||||
ts2 = nowl();
|
||||
Show("wall time", lroundl((ts2 - ts1) * 1e9l), "ns");
|
||||
Show("user time", TvToUs(rusage.ru_utime), "µs");
|
||||
Show("sys time", TvToUs(rusage.ru_stime), "µs");
|
||||
Show("maximum resident set size", rusage.ru_maxrss, "");
|
||||
Show("integral shared memory size", rusage.ru_ixrss, "");
|
||||
Show("integral unshared data size", rusage.ru_idrss, "");
|
||||
Show("integral unshared stack size", rusage.ru_isrss, "");
|
||||
Show("minor page faults", rusage.ru_minflt, "");
|
||||
Show("major page faults", rusage.ru_majflt, "");
|
||||
Show("swaps", rusage.ru_nswap, "");
|
||||
Show("block input ops", rusage.ru_inblock, "");
|
||||
Show("block output ops", rusage.ru_oublock, "");
|
||||
Show("ipc messages sent", rusage.ru_msgsnd, "");
|
||||
Show("ipc messages received", rusage.ru_msgrcv, "");
|
||||
Show("signals received", rusage.ru_nsignals, "");
|
||||
Show("voluntary context switches", rusage.ru_nvcsw, "");
|
||||
Show("involuntary context switches", rusage.ru_nivcsw, "");
|
||||
return WEXITSTATUS(wstatus);
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue