forked from Imagelibrary/rtems
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:
committed by
Sebastian Huber
parent
6087f33e31
commit
205d8d71a6
@@ -53,6 +53,7 @@ _SUBDIRS += spintrcritical23
|
||||
_SUBDIRS += sptimecounter01
|
||||
_SUBDIRS += sptimecounter02
|
||||
_SUBDIRS += sptimecounter03
|
||||
_SUBDIRS += sptimecounter04
|
||||
_SUBDIRS += spatomic01
|
||||
_SUBDIRS += spintrcritical22
|
||||
_SUBDIRS += spsem03
|
||||
|
||||
@@ -51,6 +51,7 @@ spintrcritical23/Makefile
|
||||
sptimecounter01/Makefile
|
||||
sptimecounter02/Makefile
|
||||
sptimecounter03/Makefile
|
||||
sptimecounter04/Makefile
|
||||
spatomic01/Makefile
|
||||
spglobalcon01/Makefile
|
||||
spintrcritical22/Makefile
|
||||
|
||||
19
testsuites/sptests/sptimecounter04/Makefile.am
Normal file
19
testsuites/sptests/sptimecounter04/Makefile.am
Normal 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
|
||||
84
testsuites/sptests/sptimecounter04/init.c
Normal file
84
testsuites/sptests/sptimecounter04/init.c
Normal 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>
|
||||
12
testsuites/sptests/sptimecounter04/sptimecounter04.doc
Normal file
12
testsuites/sptests/sptimecounter04/sptimecounter04.doc
Normal 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.
|
||||
2
testsuites/sptests/sptimecounter04/sptimecounter04.scn
Normal file
2
testsuites/sptests/sptimecounter04/sptimecounter04.scn
Normal file
@@ -0,0 +1,2 @@
|
||||
*** BEGIN OF TEST SPTIMECOUNTER_4 ***
|
||||
*** END OF TEST SPTIMECOUNTER_4 ***
|
||||
Reference in New Issue
Block a user