1 /******************************************************************************
3 * Copyright © International Business Machines Corp., 2009
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation; either version 2 of the License, or
8 * (at your option) any later version.
11 * Block on a futex and wait for timeout.
14 * Darren Hart <dvhart@linux.intel.com>
17 * 2009-Nov-6: Initial version by Darren Hart <dvhart@linux.intel.com>
19 *****************************************************************************/
27 #include "futextest.h"
30 #define TEST_NAME "futex-wait-timeout"
32 static long timeout_ns
= 100000; /* 100us default timeout */
34 void usage(char *prog
)
36 printf("Usage: %s\n", prog
);
37 printf(" -c Use color\n");
38 printf(" -h Display this help message\n");
39 printf(" -t N Timeout in nanoseconds (default: 100,000)\n");
40 printf(" -v L Verbosity level: %d=QUIET %d=CRITICAL %d=INFO\n",
41 VQUIET
, VCRITICAL
, VINFO
);
44 int main(int argc
, char *argv
[])
46 futex_t f1
= FUTEX_INITIALIZER
;
48 int res
, ret
= RET_PASS
;
51 while ((c
= getopt(argc
, argv
, "cht:v:")) != -1) {
57 usage(basename(argv
[0]));
60 timeout_ns
= atoi(optarg
);
63 log_verbosity(atoi(optarg
));
66 usage(basename(argv
[0]));
72 ksft_print_msg("%s: Block on a futex and wait for timeout\n",
74 ksft_print_msg("\tArguments: timeout=%ldns\n", timeout_ns
);
76 /* initialize timeout */
78 to
.tv_nsec
= timeout_ns
;
80 info("Calling futex_wait on f1: %u @ %p\n", f1
, &f1
);
81 res
= futex_wait(&f1
, f1
, &to
, FUTEX_PRIVATE_FLAG
);
82 if (!res
|| errno
!= ETIMEDOUT
) {
83 fail("futex_wait returned %d\n", ret
< 0 ? errno
: ret
);
87 print_result(TEST_NAME
, ret
);