diff options
author | Sebastian Huber <sebastian.huber@embedded-brains.de> | 2013-04-23 14:30:52 +0200 |
---|---|---|
committer | Sebastian Huber <sebastian.huber@embedded-brains.de> | 2013-04-23 14:32:40 +0200 |
commit | dfd15081689328a651ce5323b4aa210e1c861aa2 (patch) | |
tree | 6f0f86322473ba20a89dc1fdc86c17a636cc918b | |
parent | libtests/exit01: New test (diff) | |
download | rtems-dfd15081689328a651ce5323b4aa210e1c861aa2.tar.bz2 |
libtests/exit02: New test
Diffstat (limited to '')
-rw-r--r-- | testsuites/libtests/Makefile.am | 1 | ||||
-rw-r--r-- | testsuites/libtests/configure.ac | 1 | ||||
-rw-r--r-- | testsuites/libtests/exit02/Makefile.am | 19 | ||||
-rw-r--r-- | testsuites/libtests/exit02/exit02.doc | 11 | ||||
-rw-r--r-- | testsuites/libtests/exit02/exit02.scn | 2 | ||||
-rw-r--r-- | testsuites/libtests/exit02/init.c | 95 |
6 files changed, 129 insertions, 0 deletions
diff --git a/testsuites/libtests/Makefile.am b/testsuites/libtests/Makefile.am index 31a692cd66..c30e857aaa 100644 --- a/testsuites/libtests/Makefile.am +++ b/testsuites/libtests/Makefile.am @@ -1,6 +1,7 @@ ACLOCAL_AMFLAGS = -I ../aclocal SUBDIRS = POSIX +SUBDIRS += exit02 SUBDIRS += exit01 SUBDIRS += md501 SUBDIRS += sparsedisk01 diff --git a/testsuites/libtests/configure.ac b/testsuites/libtests/configure.ac index efc15a6891..c2e1d9c0ea 100644 --- a/testsuites/libtests/configure.ac +++ b/testsuites/libtests/configure.ac @@ -43,6 +43,7 @@ AM_CONDITIONAL(HAS_POSIX,test x"${rtems_cv_RTEMS_POSIX_API}" = x"yes") # Explicitly list all Makefiles here AC_CONFIG_FILES([Makefile +exit02/Makefile exit01/Makefile md501/Makefile sparsedisk01/Makefile diff --git a/testsuites/libtests/exit02/Makefile.am b/testsuites/libtests/exit02/Makefile.am new file mode 100644 index 0000000000..bb08696711 --- /dev/null +++ b/testsuites/libtests/exit02/Makefile.am @@ -0,0 +1,19 @@ +rtems_tests_PROGRAMS = exit02 +exit02_SOURCES = init.c + +dist_rtems_tests_DATA = exit02.scn exit02.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 = $(exit02_OBJECTS) +LINK_LIBS = $(exit02_LDLIBS) + +exit02$(EXEEXT): $(exit02_OBJECTS) $(exit02_DEPENDENCIES) + @rm -f exit02$(EXEEXT) + $(make-exe) + +include $(top_srcdir)/../automake/local.am diff --git a/testsuites/libtests/exit02/exit02.doc b/testsuites/libtests/exit02/exit02.doc new file mode 100644 index 0000000000..5406e8c12f --- /dev/null +++ b/testsuites/libtests/exit02/exit02.doc @@ -0,0 +1,11 @@ +This file describes the directives and concepts tested by this test set. + +test set name: exit02 + +directives: + + _Exit() + +concepts: + + Ensure _Exit() works. diff --git a/testsuites/libtests/exit02/exit02.scn b/testsuites/libtests/exit02/exit02.scn new file mode 100644 index 0000000000..719ec8fb24 --- /dev/null +++ b/testsuites/libtests/exit02/exit02.scn @@ -0,0 +1,2 @@ +*** TEST EXIT 2 *** +*** END OF TEST EXIT 2 *** diff --git a/testsuites/libtests/exit02/init.c b/testsuites/libtests/exit02/init.c new file mode 100644 index 0000000000..35ace473d7 --- /dev/null +++ b/testsuites/libtests/exit02/init.c @@ -0,0 +1,95 @@ +/* + * Copyright (c) 2013 embedded brains GmbH. All rights reserved. + * + * embedded brains GmbH + * Obere Lagerstr. 30 + * 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.com/license/LICENSE. + */ + +#ifdef HAVE_CONFIG_H + #include "config.h" +#endif + +#include <stdlib.h> + +/* Use assert() not rtems_test_assert() since it uses exit() */ +#include <assert.h> + +#include <rtems.h> + +#define EXIT_STATUS 123 + +static void atexit_not_reached(void) +{ + assert(0); +} + +static void fatal_extension( + rtems_fatal_source source, + bool is_internal, + rtems_fatal_code error +) +{ + if ( + source == RTEMS_FATAL_SOURCE_EXIT + && !is_internal + && error == EXIT_STATUS + ) { + printk("*** END OF TEST EXIT 2 ***\n"); + } +} + +static void exit_task(rtems_task_argument arg) +{ + int rv; + + rv = atexit(atexit_not_reached); + assert(rv == 0); + + _Exit(EXIT_STATUS); +} + +static void Init(rtems_task_argument arg) +{ + rtems_status_code sc; + rtems_id id; + + printk("\n\n*** TEST EXIT 2 ***\n"); + + sc = rtems_task_create( + rtems_build_name('E', 'X', 'I', 'T'), + RTEMS_MINIMUM_PRIORITY, + RTEMS_MINIMUM_STACK_SIZE, + RTEMS_DEFAULT_MODES, + RTEMS_DEFAULT_ATTRIBUTES, + &id + ); + assert(sc == RTEMS_SUCCESSFUL); + + sc = rtems_task_start(id, exit_task, 0); + assert(sc == RTEMS_SUCCESSFUL); + + sc = rtems_task_delete(RTEMS_SELF); + assert(sc == RTEMS_SUCCESSFUL); +} + +#define CONFIGURE_APPLICATION_NEEDS_CLOCK_DRIVER +#define CONFIGURE_APPLICATION_NEEDS_CONSOLE_DRIVER + +#define CONFIGURE_USE_IMFS_AS_BASE_FILESYSTEM + +#define CONFIGURE_INITIAL_EXTENSIONS { .fatal = fatal_extension } + +#define CONFIGURE_MAXIMUM_TASKS 2 + +#define CONFIGURE_RTEMS_INIT_TASKS_TABLE + +#define CONFIGURE_INIT + +#include <rtems/confdefs.h> |