summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorSebastian Huber <sebastian.huber@embedded-brains.de>2013-04-23 14:30:52 +0200
committerSebastian Huber <sebastian.huber@embedded-brains.de>2013-04-23 14:32:40 +0200
commitdfd15081689328a651ce5323b4aa210e1c861aa2 (patch)
tree6f0f86322473ba20a89dc1fdc86c17a636cc918b
parentlibtests/exit01: New test (diff)
downloadrtems-dfd15081689328a651ce5323b4aa210e1c861aa2.tar.bz2
libtests/exit02: New test
Diffstat (limited to '')
-rw-r--r--testsuites/libtests/Makefile.am1
-rw-r--r--testsuites/libtests/configure.ac1
-rw-r--r--testsuites/libtests/exit02/Makefile.am19
-rw-r--r--testsuites/libtests/exit02/exit02.doc11
-rw-r--r--testsuites/libtests/exit02/exit02.scn2
-rw-r--r--testsuites/libtests/exit02/init.c95
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>