From b177cfc1c96bf1d5deb57cf1de368a4d55a9eb87 Mon Sep 17 00:00:00 2001 From: Sebastian Huber Date: Mon, 12 Jul 2021 18:05:19 +0200 Subject: sparc: Prefer RTEMS_FATAL_SOURCE_EXCEPTION Prefer RTEMS_FATAL_SOURCE_EXCEPTION over INTERNAL_ERROR_ILLEGAL_USE_OF_FLOATING_POINT_UNIT since the fatal code (rtems_exception_frame) provides more context. --- testsuites/sptests/spfatal30/init.c | 37 ++++++++++++++++++++++++++++--------- testsuites/sptests/spfatal31/init.c | 35 +++++++++++++++++++++++++++-------- 2 files changed, 55 insertions(+), 17 deletions(-) (limited to 'testsuites') diff --git a/testsuites/sptests/spfatal30/init.c b/testsuites/sptests/spfatal30/init.c index a02bf062f4..a76fe1f309 100644 --- a/testsuites/sptests/spfatal30/init.c +++ b/testsuites/sptests/spfatal30/init.c @@ -22,9 +22,28 @@ const char rtems_test_name[] = "SPFATAL 30"; -#if (CPU_HARDWARE_FP == TRUE && CPU_ALL_TASKS_ARE_FP == FALSE) \ - || SPARC_HAS_FPU == 1 -#define EXPECT_ILLEGAL_USE_OF_FLOATING_POINT_UNIT +#if ( CPU_HARDWARE_FP == TRUE && CPU_ALL_TASKS_ARE_FP == FALSE ) || \ + defined(SPARC_USE_LAZY_FP_SWITCH) + +#define EXPECTED_FATAL_SOURCE INTERNAL_ERROR_CORE + +static bool is_expected_fatal_code( rtems_fatal_code code ) +{ + return code == INTERNAL_ERROR_ILLEGAL_USE_OF_FLOATING_POINT_UNIT; +} + +#elif defined(SPARC_USE_SYNCHRONOUS_FP_SWITCH) + +#define EXPECTED_FATAL_SOURCE RTEMS_FATAL_SOURCE_EXCEPTION + +static bool is_expected_fatal_code( rtems_fatal_code code ) +{ + const rtems_exception_frame *frame; + + frame = (const rtems_exception_frame *) code; + return frame->trap == 4; +} + #endif static volatile double f = 1.0; @@ -35,7 +54,7 @@ static void Init(rtems_task_argument arg) f *= 123.456; -#ifdef EXPECT_ILLEGAL_USE_OF_FLOATING_POINT_UNIT +#ifdef EXPECTED_FATAL_SOURCE rtems_test_assert(0); #else TEST_END(); @@ -43,7 +62,7 @@ static void Init(rtems_task_argument arg) #endif } -#ifdef EXPECT_ILLEGAL_USE_OF_FLOATING_POINT_UNIT +#ifdef EXPECTED_FATAL_SOURCE static void fatal_extension( rtems_fatal_source source, bool always_set_to_false, @@ -51,9 +70,9 @@ static void fatal_extension( ) { if ( - source == INTERNAL_ERROR_CORE + source == EXPECTED_FATAL_SOURCE && !always_set_to_false - && code == INTERNAL_ERROR_ILLEGAL_USE_OF_FLOATING_POINT_UNIT + && is_expected_fatal_code( code ) ) { TEST_END(); } @@ -63,11 +82,11 @@ static void fatal_extension( { .fatal = fatal_extension }, \ RTEMS_TEST_INITIAL_EXTENSION -#else /* EXPECT_ILLEGAL_USE_OF_FLOATING_POINT_UNIT */ +#else /* EXPECTED_FATAL_SOURCE */ #define CONFIGURE_INITIAL_EXTENSIONS RTEMS_TEST_INITIAL_EXTENSION -#endif /* EXPECT_ILLEGAL_USE_OF_FLOATING_POINT_UNIT */ +#endif /* EXPECTED_FATAL_SOURCE */ #define CONFIGURE_APPLICATION_DOES_NOT_NEED_CLOCK_DRIVER diff --git a/testsuites/sptests/spfatal31/init.c b/testsuites/sptests/spfatal31/init.c index 5aab6630dc..782e7632cc 100644 --- a/testsuites/sptests/spfatal31/init.c +++ b/testsuites/sptests/spfatal31/init.c @@ -22,8 +22,27 @@ const char rtems_test_name[] = "SPFATAL 31"; -#if SPARC_HAS_FPU == 1 -#define EXPECT_ILLEGAL_USE_OF_FLOATING_POINT_UNIT +#if defined(SPARC_USE_LAZY_FP_SWITCH) + +#define EXPECTED_FATAL_SOURCE INTERNAL_ERROR_CORE + +static bool is_expected_fatal_code( rtems_fatal_code code ) +{ + return code == INTERNAL_ERROR_ILLEGAL_USE_OF_FLOATING_POINT_UNIT; +} + +#elif defined(SPARC_USE_SYNCHRONOUS_FP_SWITCH) + +#define EXPECTED_FATAL_SOURCE RTEMS_FATAL_SOURCE_EXCEPTION + +static bool is_expected_fatal_code( rtems_fatal_code code ) +{ + const rtems_exception_frame *frame; + + frame = (const rtems_exception_frame *) code; + return frame->trap == 4; +} + #endif static volatile double f = 1.0; @@ -49,7 +68,7 @@ static void Init(rtems_task_argument arg) sc = rtems_task_wake_after(2); rtems_test_assert(sc == RTEMS_SUCCESSFUL); -#ifdef EXPECT_ILLEGAL_USE_OF_FLOATING_POINT_UNIT +#ifdef EXPECTED_FATAL_SOURCE rtems_test_assert(0); #else TEST_END(); @@ -57,7 +76,7 @@ static void Init(rtems_task_argument arg) #endif } -#ifdef EXPECT_ILLEGAL_USE_OF_FLOATING_POINT_UNIT +#ifdef EXPECTED_FATAL_SOURCE static void fatal_extension( rtems_fatal_source source, bool always_set_to_false, @@ -65,9 +84,9 @@ static void fatal_extension( ) { if ( - source == INTERNAL_ERROR_CORE + source == EXPECTED_FATAL_SOURCE && !always_set_to_false - && code == INTERNAL_ERROR_ILLEGAL_USE_OF_FLOATING_POINT_UNIT + && is_expected_fatal_code( code ) ) { TEST_END(); } @@ -77,11 +96,11 @@ static void fatal_extension( { .fatal = fatal_extension }, \ RTEMS_TEST_INITIAL_EXTENSION -#else /* EXPECT_ILLEGAL_USE_OF_FLOATING_POINT_UNIT */ +#else /* EXPECTED_FATAL_SOURCE */ #define CONFIGURE_INITIAL_EXTENSIONS RTEMS_TEST_INITIAL_EXTENSION -#endif /* EXPECT_ILLEGAL_USE_OF_FLOATING_POINT_UNIT */ +#endif /* EXPECTED_FATAL_SOURCE */ #define CONFIGURE_APPLICATION_NEEDS_CLOCK_DRIVER -- cgit v1.2.3