1*4f1223e8SApple OSS Distributions #include <assert.h>
2*4f1223e8SApple OSS Distributions #include <errno.h>
3*4f1223e8SApple OSS Distributions #include <stdarg.h>
4*4f1223e8SApple OSS Distributions #include <stdio.h>
5*4f1223e8SApple OSS Distributions #include <stdlib.h>
6*4f1223e8SApple OSS Distributions #include <string.h>
7*4f1223e8SApple OSS Distributions #include <sys/sysctl.h>
8*4f1223e8SApple OSS Distributions
9*4f1223e8SApple OSS Distributions #include <sys/mman.h>
10*4f1223e8SApple OSS Distributions
11*4f1223e8SApple OSS Distributions #include "benchmark/helpers.h"
12*4f1223e8SApple OSS Distributions
13*4f1223e8SApple OSS Distributions #define K_CTIME_BUFFER_LEN 26
14*4f1223e8SApple OSS Distributions void
benchmark_log(bool verbose,const char * restrict fmt,...)15*4f1223e8SApple OSS Distributions benchmark_log(bool verbose, const char *restrict fmt, ...)
16*4f1223e8SApple OSS Distributions {
17*4f1223e8SApple OSS Distributions time_t now;
18*4f1223e8SApple OSS Distributions char time_buffer[K_CTIME_BUFFER_LEN];
19*4f1223e8SApple OSS Distributions struct tm local_time;
20*4f1223e8SApple OSS Distributions va_list args;
21*4f1223e8SApple OSS Distributions if (verbose) {
22*4f1223e8SApple OSS Distributions strncpy(time_buffer, "UNKNOWN", K_CTIME_BUFFER_LEN);
23*4f1223e8SApple OSS Distributions
24*4f1223e8SApple OSS Distributions now = time(NULL);
25*4f1223e8SApple OSS Distributions if (now != -1) {
26*4f1223e8SApple OSS Distributions struct tm* ret = localtime_r(&now, &local_time);
27*4f1223e8SApple OSS Distributions if (ret == &local_time) {
28*4f1223e8SApple OSS Distributions snprintf(time_buffer, K_CTIME_BUFFER_LEN,
29*4f1223e8SApple OSS Distributions "%.2d/%.2d/%.2d %.2d:%.2d:%.2d",
30*4f1223e8SApple OSS Distributions local_time.tm_mon + 1, local_time.tm_mday,
31*4f1223e8SApple OSS Distributions local_time.tm_year + 1900,
32*4f1223e8SApple OSS Distributions local_time.tm_hour, local_time.tm_min,
33*4f1223e8SApple OSS Distributions local_time.tm_sec);
34*4f1223e8SApple OSS Distributions }
35*4f1223e8SApple OSS Distributions }
36*4f1223e8SApple OSS Distributions
37*4f1223e8SApple OSS Distributions printf("%s: ", time_buffer);
38*4f1223e8SApple OSS Distributions va_start(args, fmt);
39*4f1223e8SApple OSS Distributions vprintf(fmt, args);
40*4f1223e8SApple OSS Distributions fflush(stdout);
41*4f1223e8SApple OSS Distributions }
42*4f1223e8SApple OSS Distributions }
43*4f1223e8SApple OSS Distributions
44*4f1223e8SApple OSS Distributions uint64_t
timespec_difference_us(const struct timespec * a,const struct timespec * b)45*4f1223e8SApple OSS Distributions timespec_difference_us(const struct timespec* a, const struct timespec* b)
46*4f1223e8SApple OSS Distributions {
47*4f1223e8SApple OSS Distributions assert(a->tv_sec >= b->tv_sec || a->tv_nsec >= b->tv_nsec);
48*4f1223e8SApple OSS Distributions long seconds_elapsed = a->tv_sec - b->tv_sec;
49*4f1223e8SApple OSS Distributions uint64_t nsec_elapsed;
50*4f1223e8SApple OSS Distributions if (b->tv_nsec > a->tv_nsec) {
51*4f1223e8SApple OSS Distributions seconds_elapsed--;
52*4f1223e8SApple OSS Distributions nsec_elapsed = kNumNanosecondsInSecond - (uint64_t) (b->tv_nsec - a->tv_nsec);
53*4f1223e8SApple OSS Distributions } else {
54*4f1223e8SApple OSS Distributions nsec_elapsed = (uint64_t) (a->tv_nsec - b->tv_nsec);
55*4f1223e8SApple OSS Distributions }
56*4f1223e8SApple OSS Distributions return (uint64_t) seconds_elapsed * kNumMicrosecondsInSecond + nsec_elapsed / kNumNanosecondsInMicrosecond;
57*4f1223e8SApple OSS Distributions }
58*4f1223e8SApple OSS Distributions
59*4f1223e8SApple OSS Distributions unsigned char *
mmap_buffer(size_t memsize)60*4f1223e8SApple OSS Distributions mmap_buffer(size_t memsize)
61*4f1223e8SApple OSS Distributions {
62*4f1223e8SApple OSS Distributions int fd = -1;
63*4f1223e8SApple OSS Distributions unsigned char* addr = (unsigned char *)mmap(NULL, memsize, PROT_READ | PROT_WRITE, MAP_ANON | MAP_PRIVATE,
64*4f1223e8SApple OSS Distributions fd, 0);
65*4f1223e8SApple OSS Distributions if ((void*) addr == MAP_FAILED) {
66*4f1223e8SApple OSS Distributions fprintf(stderr, "Unable to mmap a memory object: %s\n", strerror(errno));
67*4f1223e8SApple OSS Distributions exit(2);
68*4f1223e8SApple OSS Distributions }
69*4f1223e8SApple OSS Distributions return addr;
70*4f1223e8SApple OSS Distributions }
71*4f1223e8SApple OSS Distributions
72*4f1223e8SApple OSS Distributions unsigned int
get_ncpu(void)73*4f1223e8SApple OSS Distributions get_ncpu(void)
74*4f1223e8SApple OSS Distributions {
75*4f1223e8SApple OSS Distributions int ncpu;
76*4f1223e8SApple OSS Distributions size_t length = sizeof(ncpu);
77*4f1223e8SApple OSS Distributions
78*4f1223e8SApple OSS Distributions int ret = sysctlbyname("hw.ncpu", &ncpu, &length, NULL, 0);
79*4f1223e8SApple OSS Distributions if (ret == -1 || ncpu < 0) {
80*4f1223e8SApple OSS Distributions fprintf(stderr, "failed to query hw.ncpu");
81*4f1223e8SApple OSS Distributions exit(1);
82*4f1223e8SApple OSS Distributions }
83*4f1223e8SApple OSS Distributions return (unsigned int) ncpu;
84*4f1223e8SApple OSS Distributions }
85