reverie/tests/c_tests/nanosleep.c

59 lines
1.3 KiB
C
Raw Normal View History

/*
* Copyright (c) Meta Platforms, Inc. and affiliates.
* All rights reserved.
*
* This source code is licensed under the BSD-style license found in the
* LICENSE file in the root directory of this source tree.
*/
#include <errno.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/types.h>
#include <time.h>
#define NITERATIONS 1000
static long long diff_time(
const struct timespec* begin,
const struct timespec* end) {
long long r = 0;
r = (end->tv_sec - begin->tv_sec) * 1000000000 +
(end->tv_nsec - begin->tv_nsec);
return r / 1000;
}
int main(int argc, char* argv[]) {
struct timespec req = {
.tv_sec = 0,
.tv_nsec = 1000000,
};
struct timespec begin, end;
int ntests = NITERATIONS;
// ignore first nanosleep
nanosleep(&req, NULL);
// ignore first clock_gettime
clock_gettime(CLOCK_REALTIME, &end);
clock_gettime(CLOCK_REALTIME, &begin);
for (int i = 0; i < 1000; i++) {
printf("nanosleep, iteration: %u\n", i);
nanosleep(&req, NULL);
}
clock_gettime(CLOCK_REALTIME, &end);
long long elapsed = diff_time(&begin, &end);
printf(
"time elapsed %lluus for %u iterations, mean: %.3lfus\n",
elapsed,
ntests,
(double)elapsed / ntests);
return 0;
}