1*f50a7f3dSThomas Gleixner // SPDX-License-Identifier: GPL-2.0-only
20c63e8b7SMichael Ellerman /*
30c63e8b7SMichael Ellerman * Copyright 2016, Anton Blanchard, Michael Ellerman, IBM Corp.
40c63e8b7SMichael Ellerman */
50c63e8b7SMichael Ellerman
60c63e8b7SMichael Ellerman #define _GNU_SOURCE
70c63e8b7SMichael Ellerman
80c63e8b7SMichael Ellerman #include <stdio.h>
90c63e8b7SMichael Ellerman #include <sys/syscall.h>
100c63e8b7SMichael Ellerman #include <time.h>
110c63e8b7SMichael Ellerman #include <unistd.h>
120c63e8b7SMichael Ellerman #include <linux/futex.h>
130c63e8b7SMichael Ellerman
140c63e8b7SMichael Ellerman #include "utils.h"
150c63e8b7SMichael Ellerman
160c63e8b7SMichael Ellerman #define ITERATIONS 100000000
170c63e8b7SMichael Ellerman
180c63e8b7SMichael Ellerman #define futex(A, B, C, D, E, F) syscall(__NR_futex, A, B, C, D, E, F)
190c63e8b7SMichael Ellerman
test_futex(void)200c63e8b7SMichael Ellerman int test_futex(void)
210c63e8b7SMichael Ellerman {
220c63e8b7SMichael Ellerman struct timespec ts_start, ts_end;
230c63e8b7SMichael Ellerman unsigned long i = ITERATIONS;
240c63e8b7SMichael Ellerman
250c63e8b7SMichael Ellerman clock_gettime(CLOCK_MONOTONIC, &ts_start);
260c63e8b7SMichael Ellerman
270c63e8b7SMichael Ellerman while (i--) {
280c63e8b7SMichael Ellerman unsigned int addr = 0;
290c63e8b7SMichael Ellerman futex(&addr, FUTEX_WAKE, 1, NULL, NULL, 0);
300c63e8b7SMichael Ellerman }
310c63e8b7SMichael Ellerman
320c63e8b7SMichael Ellerman clock_gettime(CLOCK_MONOTONIC, &ts_end);
330c63e8b7SMichael Ellerman
340c63e8b7SMichael Ellerman printf("time = %.6f\n", ts_end.tv_sec - ts_start.tv_sec + (ts_end.tv_nsec - ts_start.tv_nsec) / 1e9);
350c63e8b7SMichael Ellerman
360c63e8b7SMichael Ellerman return 0;
370c63e8b7SMichael Ellerman }
380c63e8b7SMichael Ellerman
main(void)390c63e8b7SMichael Ellerman int main(void)
400c63e8b7SMichael Ellerman {
41d97e7f19SMichael Ellerman test_harness_set_timeout(300);
420c63e8b7SMichael Ellerman return test_harness(test_futex, "futex_bench");
430c63e8b7SMichael Ellerman }
44