summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorOlivier Goffart <olivier.goffart@nokia.com>2011-02-02 10:31:20 (GMT)
committerOlivier Goffart <olivier.goffart@nokia.com>2011-02-02 12:36:41 (GMT)
commit7987d4cfd3ce86c20a55b5661a5221f12246b27e (patch)
tree9f9d3229c577be231b60d2f38ddfd58f8b0f0196 /src
parent4d38013cfc3058e36de1b6a6c20653ef2688a92b (diff)
downloadQt-7987d4cfd3ce86c20a55b5661a5221f12246b27e.zip
Qt-7987d4cfd3ce86c20a55b5661a5221f12246b27e.tar.gz
Qt-7987d4cfd3ce86c20a55b5661a5221f12246b27e.tar.bz2
Fix QMutex can deadlock when calling tryLock
in the unix code, if the QMutexPrivate::wait() with a timeout expires in the same moment that the mutex is released, wakeup would be set, but would be then ignored. (reset to false quickly after) If we waken up between the timeout and the re-aquisition of the internal mutex, we consider that the mutex has been locked. Reviewed-by: brad Task-number: QTBUG-16115
Diffstat (limited to 'src')
-rw-r--r--src/corelib/thread/qmutex_unix.cpp5
1 files changed, 4 insertions, 1 deletions
diff --git a/src/corelib/thread/qmutex_unix.cpp b/src/corelib/thread/qmutex_unix.cpp
index 41d87a7..dd7e5d1 100644
--- a/src/corelib/thread/qmutex_unix.cpp
+++ b/src/corelib/thread/qmutex_unix.cpp
@@ -94,8 +94,11 @@ bool QMutexPrivate::wait(int timeout)
errorCode = pthread_cond_timedwait(&cond, &mutex, &ti);
}
if (errorCode) {
- if (errorCode == ETIMEDOUT)
+ if (errorCode == ETIMEDOUT) {
+ if (wakeup)
+ errorCode = 0;
break;
+ }
report_error(errorCode, "QMutex::lock()", "cv wait");
}
}