diff options
author | axis <qt-info@nokia.com> | 2010-07-12 18:06:14 (GMT) |
---|---|---|
committer | axis <qt-info@nokia.com> | 2010-07-13 13:51:59 (GMT) |
commit | fc260f7ce9c139da93e005b2b51ef37c4d23998d (patch) | |
tree | 1d5cfbd8c7a481f768c8ab0783121dc243a09777 /src/corelib/kernel | |
parent | 61daa2f419696881ccdbc1cde2dc197eaf028ff6 (diff) | |
download | Qt-fc260f7ce9c139da93e005b2b51ef37c4d23998d.zip Qt-fc260f7ce9c139da93e005b2b51ef37c4d23998d.tar.gz Qt-fc260f7ce9c139da93e005b2b51ef37c4d23998d.tar.bz2 |
Fixed a possible hanging bug in the Symbian networking.
I haven't seen the bug happening in practice, but I decided to be
safe rather than sorry.
The rationale is that if a network request comes in, the select
thread will signal the active object in the main thread, remove the
socket from the set of monitored sockets, and then go to sleep in the
waitCond.wait() call, waiting for reactivation by the
QSelectMutexGrabber. However, in
QEventDispatcherSymbian::socketFired(), if the event causes the
socket to be deleted, reactivateSocketNotifier will never be called,
and therefore the wait condition will never be terminated.
Fixed by only entering the wait condition if a grabber has already
written to the pipe, signalling that it wants the lock.
AutoTest: Passed
RevBy: Markus Goetz
Diffstat (limited to 'src/corelib/kernel')
-rw-r--r-- | src/corelib/kernel/qeventdispatcher_symbian.cpp | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/src/corelib/kernel/qeventdispatcher_symbian.cpp b/src/corelib/kernel/qeventdispatcher_symbian.cpp index 7da1b69..1b0c31b 100644 --- a/src/corelib/kernel/qeventdispatcher_symbian.cpp +++ b/src/corelib/kernel/qeventdispatcher_symbian.cpp @@ -480,7 +480,8 @@ void QSelectThread::run() updateActivatedNotifiers(QSocketNotifier::Write, &writefds); } - m_waitCond.wait(&m_mutex); + if (FD_ISSET(m_pipeEnds[0], &readfds)) + m_waitCond.wait(&m_mutex); } m_mutex.unlock(); |