[PATCH] arm: Return the current handler from arm_cp15_set_exception_handler

chrisj at rtems.org chrisj at rtems.org
Tue Jun 25 08:47:19 UTC 2019


From: Chris Johns <chrisj at rtems.org>

Closes #3762
---
 bsps/arm/shared/cp15/arm-cp15-set-exception-handler.c | 9 +++++++--
 cpukit/score/cpu/arm/include/libcpu/arm-cp15.h        | 7 ++++++-
 2 files changed, 13 insertions(+), 3 deletions(-)

diff --git a/bsps/arm/shared/cp15/arm-cp15-set-exception-handler.c b/bsps/arm/shared/cp15/arm-cp15-set-exception-handler.c
index b24b7c4eb0..a0cec87589 100644
--- a/bsps/arm/shared/cp15/arm-cp15-set-exception-handler.c
+++ b/bsps/arm/shared/cp15/arm-cp15-set-exception-handler.c
@@ -16,15 +16,18 @@
 
 #include <bsp/linker-symbols.h>
 
-void arm_cp15_set_exception_handler(
+void* arm_cp15_set_exception_handler(
   Arm_symbolic_exception_name exception,
   void (*handler)(void)
 )
 {
+  uint32_t current_handler = 0;
+
   if ((unsigned) exception < MAX_EXCEPTIONS) {
     uint32_t *cpu_table = (uint32_t *) 0 + MAX_EXCEPTIONS;
     uint32_t *mirror_table = (uint32_t *) bsp_vector_table_begin + MAX_EXCEPTIONS;
-    uint32_t current_handler = mirror_table[exception];
+
+    current_handler = mirror_table[exception];
 
     if (current_handler != (uint32_t) handler) {
       size_t table_size = MAX_EXCEPTIONS * sizeof(uint32_t);
@@ -53,4 +56,6 @@ void arm_cp15_set_exception_handler(
       rtems_interrupt_local_enable(level);
     }
   }
+
+  return (void*) current_handler;
 }
diff --git a/cpukit/score/cpu/arm/include/libcpu/arm-cp15.h b/cpukit/score/cpu/arm/include/libcpu/arm-cp15.h
index 506d61a082..6e66b15b07 100644
--- a/cpukit/score/cpu/arm/include/libcpu/arm-cp15.h
+++ b/cpukit/score/cpu/arm/include/libcpu/arm-cp15.h
@@ -2246,7 +2246,12 @@ uint32_t arm_cp15_set_translation_table_entries(
   uint32_t section_flags
 );
 
-void arm_cp15_set_exception_handler(
+/**
+ * @brief Sets the @a exception @a handler in the vector table.
+ *
+ * @return Previous handler.
+ */
+void* arm_cp15_set_exception_handler(
   Arm_symbolic_exception_name exception,
   void (*handler)(void)
 );
-- 
2.20.1 (Apple Git-117)



More information about the devel mailing list