12c28215423293e443469a07ae7011135d058b671Garrett Cooper/*
20dc076565f772bb1953209fb69ea150b494aaa40robbiew * Copyright (c) 2002, Intel Corporation. All rights reserved.
30dc076565f772bb1953209fb69ea150b494aaa40robbiew * Created by:  julie.n.fleischer REMOVE-THIS AT intel DOT com
40dc076565f772bb1953209fb69ea150b494aaa40robbiew * This file is licensed under the GPL license.  For the full content
52c28215423293e443469a07ae7011135d058b671Garrett Cooper * of this license, see the COPYING file at the top level of this
60dc076565f772bb1953209fb69ea150b494aaa40robbiew * source tree.
70dc076565f772bb1953209fb69ea150b494aaa40robbiew
80dc076565f772bb1953209fb69ea150b494aaa40robbiew * Test that timer_gettime() sets sets itimerspec.it_value to the
90dc076565f772bb1953209fb69ea150b494aaa40robbiew * amount of time remaining in the middle of a timer.
100dc076565f772bb1953209fb69ea150b494aaa40robbiew * - Create and arm a timer for TIMERSEC seconds.
110dc076565f772bb1953209fb69ea150b494aaa40robbiew * - Sleep for SLEEPSEC < TIMERSEC.
120dc076565f772bb1953209fb69ea150b494aaa40robbiew * - Call timer_gettime().
130dc076565f772bb1953209fb69ea150b494aaa40robbiew * - Ensure the value returned is within ACCEPTABLEDELTA less than
140dc076565f772bb1953209fb69ea150b494aaa40robbiew *   TIMERSEC-SLEEPSEC.
150dc076565f772bb1953209fb69ea150b494aaa40robbiew *
160dc076565f772bb1953209fb69ea150b494aaa40robbiew * Signal SIGCONT will be used so that it will not affect the test if
170dc076565f772bb1953209fb69ea150b494aaa40robbiew * the timer expires.
180dc076565f772bb1953209fb69ea150b494aaa40robbiew * Clock CLOCK_REALTIME will be used.
190dc076565f772bb1953209fb69ea150b494aaa40robbiew */
200dc076565f772bb1953209fb69ea150b494aaa40robbiew
210dc076565f772bb1953209fb69ea150b494aaa40robbiew#include <time.h>
220dc076565f772bb1953209fb69ea150b494aaa40robbiew#include <signal.h>
230dc076565f772bb1953209fb69ea150b494aaa40robbiew#include <stdio.h>
240dc076565f772bb1953209fb69ea150b494aaa40robbiew#include <unistd.h>
250dc076565f772bb1953209fb69ea150b494aaa40robbiew#include <stdlib.h>
260dc076565f772bb1953209fb69ea150b494aaa40robbiew#include "posixtest.h"
270dc076565f772bb1953209fb69ea150b494aaa40robbiew
280dc076565f772bb1953209fb69ea150b494aaa40robbiew#define TIMERSEC 8
290dc076565f772bb1953209fb69ea150b494aaa40robbiew#define SLEEPSEC 2
300dc076565f772bb1953209fb69ea150b494aaa40robbiew#define ACCEPTABLEDELTA 1
310dc076565f772bb1953209fb69ea150b494aaa40robbiew
324ca2bbdcd3003f3c8df4e6129e9c7b2bd1514f87Cyril Hrubisint main(void)
330dc076565f772bb1953209fb69ea150b494aaa40robbiew{
340dc076565f772bb1953209fb69ea150b494aaa40robbiew	struct sigevent ev;
350dc076565f772bb1953209fb69ea150b494aaa40robbiew	timer_t tid;
360dc076565f772bb1953209fb69ea150b494aaa40robbiew	struct itimerspec itsset, itsget;
370dc076565f772bb1953209fb69ea150b494aaa40robbiew	int delta;
380dc076565f772bb1953209fb69ea150b494aaa40robbiew
390dc076565f772bb1953209fb69ea150b494aaa40robbiew	ev.sigev_notify = SIGEV_SIGNAL;
400dc076565f772bb1953209fb69ea150b494aaa40robbiew	ev.sigev_signo = SIGCONT;
410dc076565f772bb1953209fb69ea150b494aaa40robbiew
420dc076565f772bb1953209fb69ea150b494aaa40robbiew	itsset.it_interval.tv_sec = 0;
430dc076565f772bb1953209fb69ea150b494aaa40robbiew	itsset.it_interval.tv_nsec = 0;
440dc076565f772bb1953209fb69ea150b494aaa40robbiew	itsset.it_value.tv_sec = TIMERSEC;
450dc076565f772bb1953209fb69ea150b494aaa40robbiew	itsset.it_value.tv_nsec = 0;
460dc076565f772bb1953209fb69ea150b494aaa40robbiew
470dc076565f772bb1953209fb69ea150b494aaa40robbiew	if (timer_create(CLOCK_REALTIME, &ev, &tid) != 0) {
480dc076565f772bb1953209fb69ea150b494aaa40robbiew		perror("timer_create() did not return success\n");
490dc076565f772bb1953209fb69ea150b494aaa40robbiew		return PTS_UNRESOLVED;
500dc076565f772bb1953209fb69ea150b494aaa40robbiew	}
510dc076565f772bb1953209fb69ea150b494aaa40robbiew
520dc076565f772bb1953209fb69ea150b494aaa40robbiew	if (timer_settime(tid, 0, &itsset, NULL) != 0) {
530dc076565f772bb1953209fb69ea150b494aaa40robbiew		perror("timer_settime() did not return success\n");
540dc076565f772bb1953209fb69ea150b494aaa40robbiew		return PTS_UNRESOLVED;
550dc076565f772bb1953209fb69ea150b494aaa40robbiew	}
560dc076565f772bb1953209fb69ea150b494aaa40robbiew
570dc076565f772bb1953209fb69ea150b494aaa40robbiew	if (sleep(SLEEPSEC) != 0) {
580dc076565f772bb1953209fb69ea150b494aaa40robbiew		perror("sleep() did not return 0\n");
590dc076565f772bb1953209fb69ea150b494aaa40robbiew		return PTS_UNRESOLVED;
600dc076565f772bb1953209fb69ea150b494aaa40robbiew	}
610dc076565f772bb1953209fb69ea150b494aaa40robbiew
620dc076565f772bb1953209fb69ea150b494aaa40robbiew	if (timer_gettime(tid, &itsget) != 0) {
630dc076565f772bb1953209fb69ea150b494aaa40robbiew		perror("timer_gettime() did not return success\n");
640dc076565f772bb1953209fb69ea150b494aaa40robbiew		return PTS_UNRESOLVED;
650dc076565f772bb1953209fb69ea150b494aaa40robbiew	}
660dc076565f772bb1953209fb69ea150b494aaa40robbiew
670dc076565f772bb1953209fb69ea150b494aaa40robbiew	delta = (itsset.it_value.tv_sec - SLEEPSEC) - itsget.it_value.tv_sec;
680dc076565f772bb1953209fb69ea150b494aaa40robbiew
690dc076565f772bb1953209fb69ea150b494aaa40robbiew	if (delta < 0) {
700dc076565f772bb1953209fb69ea150b494aaa40robbiew		printf("FAIL:  timer_gettime() value > time expected left\n");
71354ebb48db8e66a853a58379a4808d5dcd1ceac3Wanlong Gao		printf("%d > %d\n", (int)itsget.it_value.tv_sec,
72354ebb48db8e66a853a58379a4808d5dcd1ceac3Wanlong Gao		       (int)itsset.it_value.tv_sec - SLEEPSEC);
730dc076565f772bb1953209fb69ea150b494aaa40robbiew		return PTS_FAIL;
740dc076565f772bb1953209fb69ea150b494aaa40robbiew	}
750dc076565f772bb1953209fb69ea150b494aaa40robbiew
760dc076565f772bb1953209fb69ea150b494aaa40robbiew	if (delta <= ACCEPTABLEDELTA) {
770dc076565f772bb1953209fb69ea150b494aaa40robbiew		printf("Test PASSED\n");
780dc076565f772bb1953209fb69ea150b494aaa40robbiew		return PTS_PASS;
790dc076565f772bb1953209fb69ea150b494aaa40robbiew	}
800dc076565f772bb1953209fb69ea150b494aaa40robbiew
819ca9633cb75c407a81b98673891982b2e0702b29Cyril Hrubis	printf("FAIL:  timer_gettime() value !~= time expected left\n");
829ca9633cb75c407a81b98673891982b2e0702b29Cyril Hrubis	printf("%d !~= %d\n", (int)itsget.it_value.tv_sec,
839ca9633cb75c407a81b98673891982b2e0702b29Cyril Hrubis	       (int)itsset.it_value.tv_sec - SLEEPSEC);
849ca9633cb75c407a81b98673891982b2e0702b29Cyril Hrubis	return PTS_FAIL;
85ec6edca7aa42b6affd989ef91b5897f96795e40fChris Dearman}
86