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