diff options
Diffstat (limited to 'testsuites/smptests/smpfatal08/init.c')
-rw-r--r-- | testsuites/smptests/smpfatal08/init.c | 132 |
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> |