calloc - Work around gcc-8 bug (2).
[dragonfly.git] / test / sysperf / syscall2.c
blobe9468bb9ce96de60d480d09d11deecd482d64e6b
1 /*
2 * syscall2.c
4 * All-threads getuid timing test.
5 */
7 #include <sys/types.h>
8 #include <sys/errno.h>
9 #include <sys/mman.h>
10 #include <time.h>
11 #include <stdio.h>
13 #include <machine/atomic.h>
15 #include "blib.h"
17 extern int getuid_test(void);
19 int
20 main(void)
22 struct timespec ts, ts2;
23 int error;
24 long long count = 0;
25 long long max;
26 int j;
27 int cpuno;
28 int ncpu;
29 int *done;
30 size_t ncpu_size;
32 done = mmap(NULL, 4096, PROT_READ|PROT_WRITE,
33 MAP_SHARED|MAP_ANON, -1, 0);
36 * How many cpu threads are there?
38 ncpu = 0;
39 ncpu_size = sizeof(ncpu);
40 if (sysctlbyname("hw.ncpu", &ncpu, &ncpu_size, NULL, 0) < 0) {
41 perror("sysctl hw.ncpu");
42 exit(1);
44 printf("timing standard getuid() syscall, %d threads\n", ncpu);
45 printf("if using powerd, run several times\n");
46 *done = 0;
49 * Approximate timing run length
51 start_timing();
52 while (stop_timing(0, NULL) == 0) {
53 for (j = 0; j < 100; ++j)
54 getuid();
55 count += 100;
57 max = count;
60 * Run same length on all threads.
62 for (cpuno = 0; cpuno < ncpu; ++cpuno) {
63 if (fork() == 0) {
65 * Give scheduler time to move threads around
67 start_timing();
68 while (stop_timing(0, NULL) == 0) {
69 for (j = 0; j < 100; ++j)
70 getuid();
74 * Actual timing test is here.
76 start_timing();
77 for (count = 0; count < max; count += 100) {
78 for (j = 0; j < 100; ++j)
79 getuid();
81 stop_timing(count, "getuid() sysmsg");
84 * Don't unbusy the cpu until the other threads are
85 * done.
87 atomic_add_int(done, 1);
88 while (*done < ncpu) /* wait for other threads */
89 getuid();
90 exit(0);
93 while (wait3(NULL, 0, NULL) > 0 || errno == EINTR)
95 return 0;