/******************************************************************************
* Copyright (c) Crackerjack Project., 2007 *
* Porting from Crackerjack to LTP is done by: *
* Manas Kumar Nayak <maknayak@in.ibm.com> *
* Copyright (c) 2013 Cyril Hrubis <chrubis@suse.cz> *
* *
* This program is free software; you can redistribute it and/or modify *
* it under the terms of the GNU General Public License as published by *
* the Free Software Foundation; either version 2 of the License, or *
* (at your option) any later version. *
* *
* This program is distributed in the hope that it will be useful, *
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See *
* the GNU General Public License for more details. *
* *
* You should have received a copy of the GNU General Public License *
* along with this program; if not, write to the Free Software Foundation, *
* Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA *
* *
******************************************************************************/
#include <time.h>
#include <signal.h>
#include <sys/syscall.h>
#include <stdio.h>
#include <errno.h>
#include "test.h"
#include "lapi/syscalls.h"
char *TCID = "timer_gettime01";
int TST_TOTAL = 3;
static void cleanup(void)
{
tst_rmdir();
}
static void setup(void)
{
TEST_PAUSE;
tst_tmpdir();
}
int main(int ac, char **av)
{
int lc;
struct sigevent ev;
struct itimerspec spec;
int timer;
tst_parse_opts(ac, av, NULL, NULL);
setup();
ev.sigev_value = (union sigval) 0;
ev.sigev_signo = SIGALRM;
ev.sigev_notify = SIGEV_SIGNAL;
TEST(ltp_syscall(__NR_timer_create, CLOCK_REALTIME, &ev, &timer));
if (TEST_RETURN != 0)
tst_brkm(TBROK | TERRNO, cleanup, "Failed to create timer");
for (lc = 0; TEST_LOOPING(lc); ++lc) {
tst_count = 0;
TEST(ltp_syscall(__NR_timer_gettime, timer, &spec));
if (TEST_RETURN == 0) {
tst_resm(TPASS, "timer_gettime(CLOCK_REALTIME) Passed");
} else {
tst_resm(TFAIL | TERRNO,
"timer_gettime(CLOCK_REALTIME) Failed");
}
TEST(ltp_syscall(__NR_timer_gettime, -1, &spec));
if (TEST_RETURN == -1 && TEST_ERRNO == EINVAL) {
tst_resm(TPASS, "timer_gettime(-1) Failed: EINVAL");
} else {
tst_resm(TFAIL | TERRNO,
"timer_gettime(-1) = %li", TEST_RETURN);
}
TEST(ltp_syscall(__NR_timer_gettime, timer, NULL));
if (TEST_RETURN == -1 && TEST_ERRNO == EFAULT) {
tst_resm(TPASS, "timer_gettime(NULL) Failed: EFAULT");
} else {
tst_resm(TFAIL | TERRNO,
"timer_gettime(-1) = %li", TEST_RETURN);
}
}
cleanup();
tst_exit();
}