[rtems commit] rtems: Always set the real priority during restart

Sebastian Huber sebh at rtems.org
Fri May 14 15:05:24 UTC 2021


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

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

rtems: Always set the real priority during restart

Unconditionally set the real priority of the task to its initial
priority during a task restart.

Close #4411.

---

 cpukit/score/src/threadrestart.c | 58 ++++++++++++++++++++++------------------
 1 file changed, 32 insertions(+), 26 deletions(-)

diff --git a/cpukit/score/src/threadrestart.c b/cpukit/score/src/threadrestart.c
index dcbf11c..d99c14a 100644
--- a/cpukit/score/src/threadrestart.c
+++ b/cpukit/score/src/threadrestart.c
@@ -375,17 +375,6 @@ static void _Thread_Remove_life_change_request( Thread_Control *the_thread )
   _Thread_State_release( the_thread, &lock_context );
 }
 
-static void _Thread_Finalize_life_change(
-  Thread_Control   *the_thread,
-  Priority_Control  priority
-)
-{
-  _Thread_queue_Extract_with_proxy( the_thread );
-  _Thread_Timer_remove( the_thread );
-  _Thread_Raise_real_priority( the_thread, priority );
-  _Thread_Remove_life_change_request( the_thread );
-}
-
 void _Thread_Join(
   Thread_Control       *the_thread,
   States_Control        waiting_for_join,
@@ -424,7 +413,6 @@ void _Thread_Cancel(
   ISR_lock_Context   lock_context;
   Thread_Life_state  previous;
   Per_CPU_Control   *cpu_self;
-  Priority_Control   priority;
 
   _Assert( the_thread != executing );
 
@@ -439,21 +427,26 @@ void _Thread_Cancel(
   );
 
   cpu_self = _Thread_Dispatch_disable_critical( &lock_context );
-  priority = _Thread_Get_priority( executing );
 
   if ( _States_Is_dormant( the_thread->current_state ) ) {
     _Thread_State_release( the_thread, &lock_context );
     _Thread_Make_zombie( the_thread );
-  } else if ( _Thread_Is_life_change_allowed( previous ) ) {
-    _Thread_Add_life_change_request( the_thread );
-    _Thread_State_release( the_thread, &lock_context );
-
-    _Thread_Finalize_life_change( the_thread, priority );
   } else {
+    Priority_Control priority;
+
     _Thread_Add_life_change_request( the_thread );
-    _Thread_Clear_state_locked( the_thread, STATES_SUSPENDED );
-    _Thread_State_release( the_thread, &lock_context );
 
+    if ( _Thread_Is_life_change_allowed( previous ) ) {
+      _Thread_State_release( the_thread, &lock_context );
+
+      _Thread_queue_Extract_with_proxy( the_thread );
+      _Thread_Timer_remove( the_thread );
+    } else {
+      _Thread_Clear_state_locked( the_thread, STATES_SUSPENDED );
+      _Thread_State_release( the_thread, &lock_context );
+    }
+
+    priority = _Thread_Get_priority( executing );
     _Thread_Raise_real_priority( the_thread, priority );
     _Thread_Remove_life_change_request( the_thread );
   }
@@ -530,8 +523,9 @@ Status_Control _Thread_Restart_other(
   ISR_lock_Context               *lock_context
 )
 {
-  Thread_Life_state  previous;
-  Per_CPU_Control   *cpu_self;
+  Thread_Life_state    previous;
+  Per_CPU_Control     *cpu_self;
+  Thread_queue_Context queue_context;
 
   _Thread_State_acquire_critical( the_thread, lock_context );
 
@@ -554,15 +548,27 @@ Status_Control _Thread_Restart_other(
     _Thread_Add_life_change_request( the_thread );
     _Thread_State_release( the_thread, lock_context );
 
-    _Thread_Finalize_life_change(
-      the_thread,
-      the_thread->Start.initial_priority
-    );
+    _Thread_queue_Extract_with_proxy( the_thread );
+    _Thread_Timer_remove( the_thread );
+    _Thread_Remove_life_change_request( the_thread );
   } else {
     _Thread_Clear_state_locked( the_thread, STATES_SUSPENDED );
     _Thread_State_release( the_thread, lock_context );
   }
 
+  _Thread_queue_Context_initialize( &queue_context );
+  _Thread_queue_Context_clear_priority_updates( &queue_context );
+  _Thread_Wait_acquire( the_thread, &queue_context );
+  _Thread_Priority_change(
+    the_thread,
+    &the_thread->Real_priority,
+    the_thread->Start.initial_priority,
+    false,
+    &queue_context
+  );
+  _Thread_Wait_release( the_thread, &queue_context );
+
+  _Thread_Priority_update( &queue_context );
   _Thread_Dispatch_enable( cpu_self );
   return STATUS_SUCCESSFUL;
 }



More information about the vc mailing list