[rtems commit] score: Obtain _Thread_Executing in proper context

Sebastian Huber sebh at rtems.org
Mon Jul 22 14:51:43 UTC 2013


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

Author:    Sebastian Huber <sebastian.huber at embedded-brains.de>
Date:      Fri Jul 19 16:20:49 2013 +0200

score: Obtain _Thread_Executing in proper context

---

 cpukit/posix/src/condwaitsupp.c |   10 ++++++----
 1 files changed, 6 insertions(+), 4 deletions(-)

diff --git a/cpukit/posix/src/condwaitsupp.c b/cpukit/posix/src/condwaitsupp.c
index 690431a..0da3a67 100644
--- a/cpukit/posix/src/condwaitsupp.c
+++ b/cpukit/posix/src/condwaitsupp.c
@@ -41,6 +41,7 @@ int _POSIX_Condition_variables_Wait_support(
   Objects_Locations                           location;
   int                                         status;
   int                                         mutex_status;
+  Thread_Control                             *executing;
 
   the_mutex = _POSIX_Mutex_Get( mutex, &location );
   if ( !the_mutex ) {
@@ -71,9 +72,10 @@ int _POSIX_Condition_variables_Wait_support(
         the_cond->Mutex = *mutex;
 
         _Thread_queue_Enter_critical_section( &the_cond->Wait_queue );
-        _Thread_Executing->Wait.return_code = 0;
-        _Thread_Executing->Wait.queue       = &the_cond->Wait_queue;
-        _Thread_Executing->Wait.id          = *cond;
+        executing = _Thread_Executing;
+        executing->Wait.return_code = 0;
+        executing->Wait.queue       = &the_cond->Wait_queue;
+        executing->Wait.id          = *cond;
 
         _Thread_queue_Enqueue( &the_cond->Wait_queue, timeout );
 
@@ -91,7 +93,7 @@ int _POSIX_Condition_variables_Wait_support(
          *  returns a success status, except for the fact that it was not
          *  woken up a pthread_cond_signal or a pthread_cond_broadcast.
          */
-        status = _Thread_Executing->Wait.return_code;
+        status = executing->Wait.return_code;
         if ( status == EINTR )
           status = 0;
 




More information about the vc mailing list