[rtems commit] score: Add and use _Per_CPU_Is_ISR_in_progress()

Sebastian Huber sebh at rtems.org
Mon May 17 06:05:42 UTC 2021


Module:    rtems
Branch:    master
Commit:    2cc25cf1b22f36c00c774c3abff94b4ba5dcf26c
Changeset: http://git.rtems.org/rtems/commit/?id=2cc25cf1b22f36c00c774c3abff94b4ba5dcf26c

Author:    Sebastian Huber <sebastian.huber at embedded-brains.de>
Date:      Fri May 14 17:33:24 2021 +0200

score: Add and use _Per_CPU_Is_ISR_in_progress()

Add _Per_CPU_Is_ISR_in_progress() as an optimized version of
_ISR_Is_in_progress().

---

 cpukit/include/rtems/score/isr.h      | 12 ------------
 cpukit/include/rtems/score/isrlevel.h | 11 +++++++++++
 cpukit/include/rtems/score/percpu.h   | 10 ++++++++++
 cpukit/score/src/threadrestart.c      |  2 +-
 4 files changed, 22 insertions(+), 13 deletions(-)

diff --git a/cpukit/include/rtems/score/isr.h b/cpukit/include/rtems/score/isr.h
index 3c6a9f1..47c24f3 100644
--- a/cpukit/include/rtems/score/isr.h
+++ b/cpukit/include/rtems/score/isr.h
@@ -147,18 +147,6 @@ void _ISR_Handler_initialization ( void );
  */
 void _ISR_Handler( void );
 
-/**
- * @brief Checks if an ISR in progress.
- *
- * This function returns true if the processor is currently servicing
- * and interrupt and false otherwise.   A return value of true indicates
- * that the caller is an interrupt service routine, NOT a thread.
- *
- * @retval true Returns true when called from an ISR.
- * @retval false Returns false when not called from an ISR.
- */
-bool _ISR_Is_in_progress( void );
-
 #ifdef __cplusplus
 }
 #endif
diff --git a/cpukit/include/rtems/score/isrlevel.h b/cpukit/include/rtems/score/isrlevel.h
index 3981f2c..d578a32 100644
--- a/cpukit/include/rtems/score/isrlevel.h
+++ b/cpukit/include/rtems/score/isrlevel.h
@@ -144,6 +144,17 @@ typedef uint32_t   ISR_Level;
     RTEMS_COMPILER_MEMORY_BARRIER();  \
   } while (0)
 
+/**
+ * @brief Checks if an ISR in progress.
+ *
+ * This function returns true, if the processor is currently servicing
+ * and interrupt, and false otherwise.   A return value of true indicates
+ * that the caller is an interrupt service routine, **not** a thread.
+ *
+ * @return true Returns true, if called from within an ISR, otherwise false.
+ */
+bool _ISR_Is_in_progress( void );
+
 /** @} */
 
 #ifdef __cplusplus
diff --git a/cpukit/include/rtems/score/percpu.h b/cpukit/include/rtems/score/percpu.h
index 58a89ec..1aed17a 100644
--- a/cpukit/include/rtems/score/percpu.h
+++ b/cpukit/include/rtems/score/percpu.h
@@ -683,6 +683,16 @@ static inline struct _Thread_Control *_Per_CPU_Get_executing(
   return cpu->executing;
 }
 
+static inline bool _Per_CPU_Is_ISR_in_progress( const Per_CPU_Control *cpu )
+{
+#if CPU_PROVIDES_ISR_IS_IN_PROGRESS == TRUE
+  (void) cpu;
+  return _ISR_Is_in_progress();
+#else
+  return cpu->isr_nest_level != 0;
+#endif
+}
+
 static inline bool _Per_CPU_Is_processor_online(
   const Per_CPU_Control *cpu
 )
diff --git a/cpukit/score/src/threadrestart.c b/cpukit/score/src/threadrestart.c
index 7a1c8e4..c8f7f7b 100644
--- a/cpukit/score/src/threadrestart.c
+++ b/cpukit/score/src/threadrestart.c
@@ -538,7 +538,7 @@ Status_Control _Thread_Restart(
 
   if (
     the_thread == _Per_CPU_Get_executing( cpu_self ) &&
-    !_ISR_Is_in_progress()
+    !_Per_CPU_Is_ISR_in_progress( cpu_self )
   ) {
     ignored_life_states = THREAD_LIFE_PROTECTED | THREAD_LIFE_CHANGE_DEFERRED;
   } else {



More information about the vc mailing list