summaryrefslogtreecommitdiffstats
path: root/testsuites/smptests/smpfatal08/init.c
diff options
context:
space:
mode:
Diffstat (limited to 'testsuites/smptests/smpfatal08/init.c')
-rw-r--r--testsuites/smptests/smpfatal08/init.c132
1 files changed, 132 insertions, 0 deletions
diff --git a/testsuites/smptests/smpfatal08/init.c b/testsuites/smptests/smpfatal08/init.c
new file mode 100644
index 0000000000..59fe4a6543
--- /dev/null
+++ b/testsuites/smptests/smpfatal08/init.c
@@ -0,0 +1,132 @@
+/*
+ * Copyright (c) 2014 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 <rtems.h>
+#include <rtems/test.h>
+#include <rtems/score/smpimpl.h>
+
+#include <assert.h>
+#include <stdlib.h>
+
+const char rtems_test_name[] = "SMPFATAL 8";
+
+/*
+ * This test is a hack since there is no easy way to test this fatal error path
+ * without BSP support.
+ */
+
+#if defined(__PPC__)
+void qoriq_secondary_cpu_initialize(void)
+{
+ /* Provided to avoid multiple definitions of the CPU SMP support functions */
+}
+#endif
+
+#if defined(__sparc__)
+void leon3_secondary_cpu_initialize(uint32_t cpu_index)
+{
+ (void) cpu_index;
+
+ /* Provided to avoid multiple definitions of the CPU SMP support functions */
+}
+#endif
+
+uint32_t _CPU_SMP_Initialize(void)
+{
+ return 2;
+}
+
+bool _CPU_SMP_Start_processor(uint32_t cpu_index)
+{
+ (void) cpu_index;
+
+ return false;
+}
+
+void _CPU_SMP_Finalize_initialization(uint32_t cpu_count)
+{
+ (void) cpu_count;
+
+ assert(0);
+}
+
+#if !defined(__leon__) && !defined(__PPC__) && !defined(__arm__)
+uint32_t _CPU_SMP_Get_current_processor(void)
+{
+ return 0;
+}
+#endif
+
+void _CPU_SMP_Send_interrupt(uint32_t target_processor_index)
+{
+ (void) target_processor_index;
+}
+
+static void Init(rtems_task_argument arg)
+{
+ assert(0);
+}
+
+static void fatal_extension(
+ rtems_fatal_source source,
+ bool is_internal,
+ rtems_fatal_code code
+)
+{
+ rtems_test_begink();
+
+ if (
+ source == RTEMS_FATAL_SOURCE_SMP
+ && !is_internal
+ && code == SMP_FATAL_START_OF_MANDATORY_PROCESSOR_FAILED
+ ) {
+ rtems_test_endk();
+ }
+}
+
+#define CONFIGURE_APPLICATION_DOES_NOT_NEED_CLOCK_DRIVER
+#define CONFIGURE_APPLICATION_NEEDS_CONSOLE_DRIVER
+
+#define CONFIGURE_INITIAL_EXTENSIONS \
+ { .fatal = fatal_extension }, \
+ RTEMS_TEST_INITIAL_EXTENSION
+
+#define CONFIGURE_SMP_APPLICATION
+
+#define CONFIGURE_SMP_MAXIMUM_PROCESSORS 2
+
+#define CONFIGURE_SCHEDULER_SIMPLE_SMP
+
+#include <rtems/scheduler.h>
+
+RTEMS_SCHEDULER_CONTEXT_SIMPLE_SMP(a);
+
+#define CONFIGURE_SCHEDULER_CONTROLS \
+ RTEMS_SCHEDULER_CONTROL_SIMPLE_SMP(a, rtems_build_name('S', 'I', 'M', 'P'))
+
+#define CONFIGURE_SMP_SCHEDULER_ASSIGNMENTS \
+ RTEMS_SCHEDULER_ASSIGN(0, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_MANDATORY), \
+ RTEMS_SCHEDULER_ASSIGN(0, RTEMS_SCHEDULER_ASSIGN_PROCESSOR_MANDATORY)
+
+#define CONFIGURE_MAXIMUM_TASKS 1
+
+#define CONFIGURE_RTEMS_INIT_TASKS_TABLE
+
+#define CONFIGURE_INIT
+
+#include <rtems/confdefs.h>