Home | History | Annotate | Download | only in futex
      1 /*
      2  * Copyright (C) 2015 Cyril Hrubis <chrubis (at) suse.cz>
      3  *
      4  * Licensed under the GNU GPLv2 or later.
      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.
      9  *
     10  * This program is distributed in the hope that it will be useful,
     11  * but WITHOUT ANY WARRANTY;  without even the implied warranty of
     12  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See
     13  * the GNU General Public License for more details.
     14  *
     15  * You should have received a copy of the GNU General Public License
     16  * along with this program;  if not, write to the Free Software
     17  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
     18  */
     19 
     20 #define TRESHOLD_US 100000
     21 
     22 static void verify_futex_wait_bitset(long long wait_us, clock_t clk_id)
     23 {
     24 	struct timespec start, to, end;
     25 	futex_t futex = FUTEX_INITIALIZER;
     26 	u_int32_t bitset = 0xffffffff;
     27 	int flags = clk_id == CLOCK_REALTIME ? FUTEX_CLOCK_REALTIME : 0;
     28 
     29 	tst_resm(TINFO, "testing futex_wait_bitset() timeout with %s",
     30 	         clk_id == CLOCK_REALTIME ? "CLOCK_REALTIME" : "CLOCK_MONOTONIC");
     31 
     32 	clock_gettime(clk_id, &start);
     33 	to = tst_timespec_add_us(start, wait_us);
     34 
     35 	TEST(futex_wait_bitset(&futex, futex, &to, bitset, flags));
     36 
     37 	clock_gettime(clk_id, &end);
     38 
     39 	if (TEST_RETURN != -1) {
     40 		tst_resm(TFAIL, "futex_wait_bitset() returned %li, expected -1",
     41 		         TEST_RETURN);
     42 		return;
     43 	}
     44 
     45 	if (TEST_ERRNO == ENOSYS) {
     46 		tst_resm(TCONF, "In this kernel, futex() does not support "
     47 			 "FUTEX_WAIT_BITSET operation");
     48 		return;
     49 	}
     50 
     51 	if (TEST_ERRNO != ETIMEDOUT) {
     52 		tst_resm(TFAIL | TTERRNO, "expected %s",
     53 		         tst_strerrno(ETIMEDOUT));
     54 		return;
     55 	}
     56 
     57 	if (tst_timespec_lt(end, to)) {
     58 		tst_resm(TFAIL,
     59 		         "futex_wait_bitset() woken up prematurely %llius, expected %llius",
     60 			 tst_timespec_diff_us(end, start), wait_us);
     61 		return;
     62 	}
     63 
     64 	if (tst_timespec_diff_us(end, to) > TRESHOLD_US) {
     65 		tst_resm(TFAIL,
     66 		         "futex_wait_bitset() waited too long %llius, expected %llius",
     67 			 tst_timespec_diff_us(end, start), wait_us);
     68 		return;
     69 	}
     70 
     71 	tst_resm(TPASS, "futex_wait_bitset() waited %llius, expected %llius",
     72 	         tst_timespec_diff_us(end, start), wait_us);
     73 }
     74