/*-*- mode:c;indent-tabs-mode:nil;c-basic-offset:2;tab-width:8;coding:utf-8 -*-│ │ vi: set et ft=c ts=2 sts=2 sw=2 fenc=utf-8 :vi │ ╞══════════════════════════════════════════════════════════════════════════════╡ │ Copyright 2023 Justine Alexandra Roberts Tunney │ │ │ │ Permission to use, copy, modify, and/or distribute this software for │ │ any purpose with or without fee is hereby granted, provided that the │ │ above copyright notice and this permission notice appear in all copies. │ │ │ │ THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL │ │ WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED │ │ WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE │ │ AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL │ │ DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR │ │ PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER │ │ TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR │ │ PERFORMANCE OF THIS SOFTWARE. │ ╚─────────────────────────────────────────────────────────────────────────────*/ #include "libc/assert.h" #include "libc/calls/struct/timespec.h" #include "libc/intrin/kprintf.h" #include "libc/runtime/runtime.h" #include "libc/stdio/stdio.h" #include "libc/sysv/consts/clock.h" #define MAXIMUM 1e9 #define ITERATIONS 10 void TestSleepRealRelative(void) { printf("\n"); printf("testing: clock_nanosleep(CLOCK_REALTIME) with relative " "timeout\n"); for (long nanos = 1; nanos < (long)MAXIMUM; nanos *= 2) { struct timespec t1, t2, wf; wf = timespec_fromnanos(nanos); clock_gettime(CLOCK_REALTIME, &t1); for (int i = 0; i < ITERATIONS; ++i) { npassert(!clock_nanosleep(CLOCK_REALTIME, 0, &wf, 0)); } clock_gettime(CLOCK_REALTIME, &t2); long took = timespec_tonanos(timespec_sub(t2, t1)) / ITERATIONS; printf("%,12ld ns sleep took %,12ld ns delta %,12ld ns\n", nanos, took, took - nanos); } } void TestSleepMonoRelative(void) { printf("\n"); printf("testing: clock_nanosleep(CLOCK_MONOTONIC) with relative " "timeout\n"); for (long nanos = 1; nanos < (long)MAXIMUM; nanos *= 2) { struct timespec t1, t2, wf; wf = timespec_fromnanos(nanos); clock_gettime(CLOCK_REALTIME, &t1); for (int i = 0; i < ITERATIONS; ++i) { npassert(!clock_nanosleep(CLOCK_MONOTONIC, 0, &wf, 0)); } clock_gettime(CLOCK_REALTIME, &t2); long took = timespec_tonanos(timespec_sub(t2, t1)) / ITERATIONS; printf("%,12ld ns sleep took %,12ld ns delta %,12ld ns\n", nanos, took, took - nanos); } } int main(int argc, char *argv[]) { TestSleepRealRelative(); TestSleepMonoRelative(); }