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