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