sptests/sptimecounter04: New test

Ensure that the time flow of CLOCK_REALTIME and CLOCK_MONOTONIC is close to
the clock driver ticks time flow.
This commit is contained in:
Christian Mauderer
2017-10-17 11:46:14 +02:00
committed by Sebastian Huber
parent 6087f33e31
commit 205d8d71a6
6 changed files with 119 additions and 0 deletions

View File

@@ -53,6 +53,7 @@ _SUBDIRS += spintrcritical23
_SUBDIRS += sptimecounter01
_SUBDIRS += sptimecounter02
_SUBDIRS += sptimecounter03
_SUBDIRS += sptimecounter04
_SUBDIRS += spatomic01
_SUBDIRS += spintrcritical22
_SUBDIRS += spsem03

View File

@@ -51,6 +51,7 @@ spintrcritical23/Makefile
sptimecounter01/Makefile
sptimecounter02/Makefile
sptimecounter03/Makefile
sptimecounter04/Makefile
spatomic01/Makefile
spglobalcon01/Makefile
spintrcritical22/Makefile

View File

@@ -0,0 +1,19 @@
rtems_tests_PROGRAMS = sptimecounter04
sptimecounter04_SOURCES = init.c
dist_rtems_tests_DATA = sptimecounter04.scn sptimecounter04.doc
include $(RTEMS_ROOT)/make/custom/@RTEMS_BSP@.cfg
include $(top_srcdir)/../automake/compile.am
include $(top_srcdir)/../automake/leaf.am
AM_CPPFLAGS += -I$(top_srcdir)/../support/include
LINK_OBJS = $(sptimecounter04_OBJECTS)
LINK_LIBS = $(sptimecounter04_LDLIBS)
sptimecounter04$(EXEEXT): $(sptimecounter04_OBJECTS) $(sptimecounter04_DEPENDENCIES)
@rm -f sptimecounter04$(EXEEXT)
$(make-exe)
include $(top_srcdir)/../automake/local.am

View File

@@ -0,0 +1,84 @@
/*
* Copyright (c) 2017 embedded brains GmbH. All rights reserved.
*
* embedded brains GmbH
* Dornierstr. 4
* 82178 Puchheim
* Germany
* <rtems@embedded-brains.de>
*
* The license and distribution terms for this file may be
* found in the file LICENSE in this distribution or at
* http://www.rtems.org/license/LICENSE.
*/
#ifdef HAVE_CONFIG_H
#include "config.h"
#endif
#include <time.h>
#include <rtems.h>
#include <rtems/test.h>
#include <rtems/timespec.h>
#include "tmacros.h"
const char rtems_test_name[] = "SPTIMECOUNTER 4";
static void Init(rtems_task_argument arg)
{
struct timespec real_start;
struct timespec mono_start;
struct timespec real_end;
struct timespec mono_end;
struct timespec real_elapsed;
struct timespec mono_elapsed;
struct timespec min;
struct timespec max;
int rv;
TEST_BEGIN();
rtems_timespec_set(&min, 1, 980000000);
rtems_timespec_set(&max, 2, 20000000);
rv = clock_gettime(CLOCK_REALTIME, &real_start);
rtems_test_assert(rv == 0);
rv = clock_gettime(CLOCK_MONOTONIC, &mono_start);
rtems_test_assert(rv == 0);
rtems_task_wake_after(2 * rtems_clock_get_ticks_per_second());
rv = clock_gettime(CLOCK_REALTIME, &real_end);
rtems_test_assert(rv == 0);
rv = clock_gettime(CLOCK_MONOTONIC, &mono_end);
rtems_test_assert(rv == 0);
rtems_timespec_subtract(&real_start, &real_end, &real_elapsed);
rtems_timespec_subtract(&mono_start, &mono_end, &mono_elapsed);
rtems_test_assert(rtems_timespec_greater_than(&real_elapsed, &min));
rtems_test_assert(rtems_timespec_greater_than(&max, &real_elapsed));
rtems_test_assert(rtems_timespec_greater_than(&mono_elapsed, &min));
rtems_test_assert(rtems_timespec_greater_than(&max, &mono_elapsed));
TEST_END();
rtems_test_exit(0);
}
#define CONFIGURE_MICROSECONDS_PER_TICK 10000
#define CONFIGURE_APPLICATION_NEEDS_CLOCK_DRIVER
#define CONFIGURE_APPLICATION_NEEDS_CONSOLE_DRIVER
#define CONFIGURE_MAXIMUM_TASKS 1
#define CONFIGURE_RTEMS_INIT_TASKS_TABLE
#define CONFIGURE_INITIAL_EXTENSIONS RTEMS_TEST_INITIAL_EXTENSION
#define CONFIGURE_INIT
#include <rtems/confdefs.h>

View File

@@ -0,0 +1,12 @@
This file describes the directives and concepts tested by this test set.
test set name: sptimecounter04
directives:
- clock_gettime()
concepts:
- Ensure that the time flow of CLOCK_REALTIME and CLOCK_MONOTONIC is close to
the clock driver ticks time flow.

View File

@@ -0,0 +1,2 @@
*** BEGIN OF TEST SPTIMECOUNTER_4 ***
*** END OF TEST SPTIMECOUNTER_4 ***