summaryrefslogtreecommitdiffstats
path: root/testsuites/sptests/spfatal03/testcase.h
diff options
context:
space:
mode:
authorJennifer Averett <Jennifer.Averett@OARcorp.com>2008-01-28 19:19:35 +0000
committerJennifer Averett <Jennifer.Averett@OARcorp.com>2008-01-28 19:19:35 +0000
commit5fdb1e7bc0319ce06b4e427f01e8d95beeab09ad (patch)
tree738799d79979c4b374a2ec5b44a43c39b4003a83 /testsuites/sptests/spfatal03/testcase.h
parent2008-01-28 Joel Sherrill <joel.sherrill@OARcorp.com> (diff)
downloadrtems-5fdb1e7bc0319ce06b4e427f01e8d95beeab09ad.tar.bz2
2008-01-28 Jennifer Averett <jennifer.averett@OARcorp.com>
* Makefile.am, configure.ac: Added fatal error tests * spfatal01/Makefile.am, spfatal01/spfatal01.scn, spfatal01/testcase.h, spfatal02/Makefile.am, spfatal02/spfatal02.scn, spfatal02/testcase.h, spfatal03/Makefile.am, spfatal03/spfatal03.scn, spfatal03/testcase.h, spfatal04/Makefile.am, spfatal04/spfatal04.scn, spfatal04/testcase.h, spfatal05/Makefile.am, spfatal05/spfatal05.scn, spfatal05/testcase.h, spfatal06/Makefile.am, spfatal06/spfatal06.scn, spfatal06/testcase.h, spfatal07/Makefile.am, spfatal07/spfatal07.scn, spfatal07/testcase.h, spfatal08/Makefile.am, spfatal08/spfatal08.scn, spfatal08/testcase.h, spfatal09/Makefile.am, spfatal09/spfatal09.scn, spfatal09/testcase.h, spfatal10/Makefile.am, spfatal10/spfatal10.scn, spfatal10/testcase.h, spfatal_support/init.c, spfatal_support/system.h: New files.
Diffstat (limited to 'testsuites/sptests/spfatal03/testcase.h')
-rw-r--r--testsuites/sptests/spfatal03/testcase.h67
1 files changed, 67 insertions, 0 deletions
diff --git a/testsuites/sptests/spfatal03/testcase.h b/testsuites/sptests/spfatal03/testcase.h
new file mode 100644
index 0000000000..0c72212863
--- /dev/null
+++ b/testsuites/sptests/spfatal03/testcase.h
@@ -0,0 +1,67 @@
+/*
+ * Classic API Init task create failure
+ *
+ * $Id$
+ */
+
+/*
+ * Way too much stack space. Should generate a fatal error
+ * on the init task create.
+ */
+#define CONFIGURE_HAS_OWN_INIT_TASK_TABLE
+#define CONFIGURE_INIT_TASK_STACK_SIZE RTEMS_MINIMUM_STACK_SIZE
+rtems_initialization_tasks_table Initialization_tasks[] = {
+ { rtems_build_name('I', 'N', 'I', ' '),
+ RTEMS_MINIMUM_STACK_SIZE,
+ 1,
+ RTEMS_DEFAULT_ATTRIBUTES,
+ Init,
+ RTEMS_DEFAULT_MODES,
+ 0
+ }
+};
+#define CONFIGURE_INIT_TASK_TABLE Initialization_tasks
+#define CONFIGURE_INIT_TASK_TABLE_SIZE \
+ sizeof(CONFIGURE_INIT_TASK_TABLE) / sizeof(rtems_initialization_tasks_table)
+
+#define CONFIGURE_MAXIMUM_SEMAPHORES 10
+
+#define FATAL_ERROR_DESCRIPTION "Core Mutex obtain in critical section"
+#define FATAL_ERROR_EXPECTED_SOURCE INTERNAL_ERROR_CORE
+#define FATAL_ERROR_EXPECTED_IS_INTERNAL FALSE
+#define FATAL_ERROR_EXPECTED_ERROR INTERNAL_ERROR_MUTEX_OBTAIN_FROM_BAD_STATE
+
+rtems_id Mutex_id[1];
+rtems_name Mutex_name[1];
+
+void force_error()
+{
+ ISR_Level level;
+ rtems_status_code status;
+
+
+ Mutex_name[0] = rtems_build_name( 'S','0',' ',' ');
+ status = rtems_semaphore_create(
+ Mutex_name[0],
+ 1,
+ RTEMS_LOCAL|
+ RTEMS_SIMPLE_BINARY_SEMAPHORE|
+ RTEMS_PRIORITY_CEILING |
+ RTEMS_PRIORITY,
+ 0,
+ &Mutex_id[0]
+ );
+ directive_failed( status, "rtems_semaphore_create of S0");
+ printf("Create S0\n");
+
+
+ _Thread_Disable_dispatch();
+ status = rtems_semaphore_obtain( Mutex_id[0], RTEMS_DEFAULT_OPTIONS, 0 );
+ /* !!! SHOULD NOT RETURN FROM THE ABOVE CALL */
+
+ _Thread_Enable_dispatch();
+ _ISR_Enable( level );
+ directive_failed( status, "rtems_semaphore_obtain" );
+
+ /* we will not run this far */
+}