diff options
author | Steve Huston <shuston@riverace.com> | 2010-10-20 16:29:52 +0000 |
---|---|---|
committer | Steve Huston <shuston@riverace.com> | 2010-10-20 16:29:52 +0000 |
commit | fba193569e09cedb03dce32042b91dfc1dd43c24 (patch) | |
tree | 43f94fcdd05b396739977037bb0fdb3502a2bf18 | |
parent | 16c5d5145d40a1d2e72023ac760f6595cfbb1e3b (diff) | |
download | ATCD-fba193569e09cedb03dce32042b91dfc1dd43c24.tar.gz |
ChangeLogTag:Wed Oct 20 16:07:09 UTC 2010 Steve Huston <shuston@riverace.com>
-rw-r--r-- | ChangeLog | 8 | ||||
-rw-r--r-- | ace/Timer_Queue_Adapters.cpp | 12 | ||||
-rw-r--r-- | ace/Timer_Queue_T.cpp | 4 |
3 files changed, 22 insertions, 2 deletions
diff --git a/ChangeLog b/ChangeLog index 361108fdfa3..ca8f74c3f0d 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,11 @@ +Wed Oct 20 16:07:09 UTC 2010 Steve Huston <shuston@riverace.com> + + * ace/Timer_Queue_Adapters.cpp (ACE_Thread_Timer_Queue_Adapter::svc): + * ace/Timer_Queue_T.cpp (expire): + Temporarily release and reacquire the mutex around timer dispatch. + This prevents a deadlock on user code with multiple threads doing + timer-related operations. + Thu Sep 02 11:18:34 EDT 2010 Steve Huston <shuston@riverace.com> * ACE version 5.7b released. diff --git a/ace/Timer_Queue_Adapters.cpp b/ace/Timer_Queue_Adapters.cpp index 0c4fc51b573..6b6db9f1bf4 100644 --- a/ace/Timer_Queue_Adapters.cpp +++ b/ace/Timer_Queue_Adapters.cpp @@ -17,6 +17,7 @@ # include "ace/Timer_Queue_Adapters.inl" # endif /* __ACE_INLINE__ */ +#include "ace/Reverse_Lock_T.h" #include "ace/Signal.h" #include "ace/OS_NS_unistd.h" #include "ace/OS_NS_sys_time.h" @@ -278,8 +279,15 @@ ACE_Thread_Timer_Queue_Adapter<TQ>::svc (void) } } - // Expire timers anyway, at worst this is a no-op. - this->timer_queue_->expire (); + // Expire timers anyway, at worst this is a no-op. Release the lock + // while dispatching; the timer queue has its own lock to protect + // itself. + { + ACE_Reverse_Lock<ACE_SYNCH_RECURSIVE_MUTEX> rel (this->mutex_); + ACE_GUARD_RETURN (ACE_Reverse_Lock<ACE_SYNCH_RECURSIVE_MUTEX>, + rmon, rel, -1); + this->timer_queue_->expire (); + } } // Thread cancellation point, if ACE supports it. diff --git a/ace/Timer_Queue_T.cpp b/ace/Timer_Queue_T.cpp index 2ac9a29e9aa..5f5cb126d36 100644 --- a/ace/Timer_Queue_T.cpp +++ b/ace/Timer_Queue_T.cpp @@ -18,6 +18,7 @@ #include "ace/Guard_T.h" #include "ace/Log_Msg.h" #include "ace/Reactor_Timer_Interface.h" +#include "ace/Reverse_Lock_T.h" #include "ace/Null_Mutex.h" #include "ace/OS_NS_sys_time.h" @@ -267,6 +268,9 @@ ACE_Timer_Queue_T<TYPE, FUNCTOR, ACE_LOCK>::expire (const ACE_Time_Value &cur_ti while ((result = this->dispatch_info_i (cur_time, info)) != 0) { + ACE_MT (ACE_Reverse_Lock<ACE_LOCK> rev_lk(this->mutex_)); + ACE_MT (ACE_GUARD_RETURN (ACE_Reverse_Lock<ACE_LOCK>, rmon, rev_lk, -1)); + const void *upcall_act = 0; this->preinvoke (info, cur_time, upcall_act); |