diff options
author | Timothy Pearson <[email protected]> | 2012-04-23 14:59:01 -0500 |
---|---|---|
committer | Slávek Banko <[email protected]> | 2012-06-03 03:27:09 +0200 |
commit | 1bd1c6586c658d3aa7195c34eaf009c61ffa7e73 (patch) | |
tree | b8371a1aa9c5dc9c1b9d4888805216593fcc1208 | |
parent | 4a67f231f00d75b9b91e13874d70d5e9fcf9c460 (diff) | |
download | tdebase-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)
-rw-r--r-- | kdesktop/lock/lockprocess.cc | 2 | ||||
-rw-r--r-- | kdesktop/lock/main.cc | 2 | ||||
-rw-r--r-- | kdesktop/lockeng.cc | 9 | ||||
-rw-r--r-- | kdesktop/lockeng.h | 3 |
4 files changed, 13 insertions, 3 deletions
diff --git a/kdesktop/lock/lockprocess.cc b/kdesktop/lock/lockprocess.cc index f3f1e6cfe..0981d2a50 100644 --- a/kdesktop/lock/lockprocess.cc +++ b/kdesktop/lock/lockprocess.cc @@ -664,6 +664,7 @@ void LockProcess::startSecureDialog() } trinity_desktop_lock_in_sec_dlg = false; if (ret == 0) { + trinity_desktop_lock_closing_windows = 1; kapp->quit(); } if (ret == 1) { @@ -687,6 +688,7 @@ void LockProcess::startSecureDialog() mBusy = false; } if (ret == 2) { + trinity_desktop_lock_closing_windows = 1; if (system("ksysguard &") == -1) { // Error handler to shut up gcc warnings } diff --git a/kdesktop/lock/main.cc b/kdesktop/lock/main.cc index 658472c22..89dc1917c 100644 --- a/kdesktop/lock/main.cc +++ b/kdesktop/lock/main.cc @@ -266,7 +266,7 @@ int main( int argc, char **argv ) bool rt; bool sig = false; - if( (!child && (args->isSet( "forcelock" )) || (signalled_forcelock == TRUE))) { + if( (((!child) && (args->isSet( "forcelock" ))) || (signalled_forcelock == TRUE))) { rt = process.lock(); sig = true; } 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; diff --git a/kdesktop/lockeng.h b/kdesktop/lockeng.h index ae08e9ad8..e42a048bb 100644 --- a/kdesktop/lockeng.h +++ b/kdesktop/lockeng.h @@ -79,11 +79,12 @@ public: virtual void saverLockReady(); public slots: - void lockProcessWaiting(); + void slotLockProcessWaiting(); protected slots: void idleTimeout(); void lockProcessExited(); + void lockProcessWaiting(); private slots: void handleSecureDialog(); |