summaryrefslogtreecommitdiffstats
path: root/kdesktop/lockeng.cc
diff options
context:
space:
mode:
authorTimothy Pearson <[email protected]>2012-04-23 14:59:01 -0500
committerSlávek Banko <[email protected]>2012-06-03 03:27:09 +0200
commit1bd1c6586c658d3aa7195c34eaf009c61ffa7e73 (patch)
treeb8371a1aa9c5dc9c1b9d4888805216593fcc1208 /kdesktop/lockeng.cc
parent4a67f231f00d75b9b91e13874d70d5e9fcf9c460 (diff)
downloadtdebase-1bd1c6586c658d3aa7195c34eaf009c61ffa7e73.tar.gz
tdebase-1bd1c6586c658d3aa7195c34eaf009c61ffa7e73.zip
Fix desktop lock failure due to race condition within signal handler between qt and xcb
(cherry picked from commit 67a3a8f34892a6491ba0073a3f583503b44e58e7)
Diffstat (limited to 'kdesktop/lockeng.cc')
-rw-r--r--kdesktop/lockeng.cc9
1 files changed, 8 insertions, 1 deletions
diff --git a/kdesktop/lockeng.cc b/kdesktop/lockeng.cc
index 278c49fc0..e178328c3 100644
--- a/kdesktop/lockeng.cc
+++ b/kdesktop/lockeng.cc
@@ -34,7 +34,7 @@ SaverEngine* m_masterSaverEngine = NULL;
static void sigusr1_handler(int)
{
if (m_masterSaverEngine) {
- m_masterSaverEngine->lockProcessWaiting();
+ m_masterSaverEngine->slotLockProcessWaiting();
}
}
@@ -445,6 +445,13 @@ void SaverEngine::lockProcessExited()
}
}
+void SaverEngine::slotLockProcessWaiting()
+{
+ // lockProcessWaiting cannot be called directly from a signal handler, as it will hang in certain obscure circumstances
+ // Instead we use a single-shot timer to immediately call lockProcessWaiting once control has returned to the Qt main loop
+ TQTimer::singleShot(0, this, SLOT(lockProcessWaiting()));
+}
+
void SaverEngine::lockProcessWaiting()
{
kdDebug(1204) << "SaverEngine: lock exited" << endl;