mirror of
https://github.com/jart/cosmopolitan.git
synced 2025-01-31 11:37:35 +00:00
3f0bcdc3ef
- Exhaustively document cancellation points - Rename SIGCANCEL to SIGTHR just like BSDs - Further improve POSIX thread cancellations - Ensure asynchronous cancellations work correctly - Elevate the quality of getrandom() and getentropy() - Make futexes cancel correctly on OpenBSD 6.x and 7.x - Add reboot.com and shutdown.com to examples directory - Remove underscore prefix from awesome timespec_*() APIs - Create assertions that help verify our cancellation points - Remove bad timespec APIs (cmp generalizes eq/ne/gt/gte/lt/lte)
41 lines
1.6 KiB
C
41 lines
1.6 KiB
C
#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/struct/timespec.h"
|
|
#include "libc/stdio/stdio.h"
|
|
#include "libc/time/time.h"
|
|
|
|
/**
|
|
* @fileoverview clock() function demo
|
|
*/
|
|
|
|
int main(int argc, char *argv[]) {
|
|
unsigned long i;
|
|
volatile unsigned long x;
|
|
struct timespec now, start, next, interval;
|
|
printf("hammering the cpu...\n");
|
|
next = start = timespec_mono();
|
|
interval = timespec_frommillis(500);
|
|
next = timespec_add(next, interval);
|
|
for (;;) {
|
|
for (i = 0;; ++i) {
|
|
x *= 7;
|
|
if (!(i % 256)) {
|
|
now = timespec_mono();
|
|
if (timespec_cmp(now, next) >= 0) {
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
next = timespec_add(next, interval);
|
|
printf("consumed %10g seconds monotonic time and %10g seconds cpu time\n",
|
|
timespec_tonanos(timespec_sub(now, start)) / 1000000000.,
|
|
(double)clock() / CLOCKS_PER_SEC);
|
|
}
|
|
}
|