summaryrefslogtreecommitdiff
path: root/lib/libc_r/BENCH/once_overhead.c
blob: c353ffb8d521fb8a99c69a65ecd57dc07c8dd60a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30

#include  <pthread.h>
#include "bench.h"

static char name[] =  "Once Overhead";
static char doc[] = 
"\tThe time needed for the highest priority thread to execute the\n"
"\tpthread_once() function when the init_routine has already been\n"
"\texecuted.";

void
init_routine()
{
}

int
main() {
	pthread_once_t once_control = PTHREAD_ONCE_INIT;
	bench_t b;
	bench_init(&b, name, doc, "per call");
	bench_header(&b);
	pthread_once(&once_control, init_routine);
	bench_amortize(&b, BENCH_LOOPS) {
		pthread_once(&once_control, init_routine);
	}
	bench_report(&b);
	exit(0);
}