summaryrefslogtreecommitdiffstats
path: root/kdesktop/lock/lockprocess.cc
diff options
context:
space:
mode:
authorTimothy Pearson <kb9vqf@pearsoncomputing.net>2015-04-12 23:05:48 -0500
committerTimothy Pearson <kb9vqf@pearsoncomputing.net>2015-04-12 23:05:48 -0500
commit37bc5cdd0e31fd9c8712c0bd88039dd474be4418 (patch)
treef71caed49e7e08980f2a5b42d7b10d864bbcefcf /kdesktop/lock/lockprocess.cc
parente569dd46ac06ef5a5f2ad03a311640e1834c749f (diff)
downloadtdebase-37bc5cdd0e31fd9c8712c0bd88039dd474be4418.tar.gz
tdebase-37bc5cdd0e31fd9c8712c0bd88039dd474be4418.zip
Fix long-standing inverted signal mask in kdesktop_lock initial sigsuspend
Prevent helper thread termination signal from errantly being handled by main thread
Diffstat (limited to 'kdesktop/lock/lockprocess.cc')
-rw-r--r--kdesktop/lock/lockprocess.cc7
1 files changed, 7 insertions, 0 deletions
diff --git a/kdesktop/lock/lockprocess.cc b/kdesktop/lock/lockprocess.cc
index da12bd46c..a4a2badd3 100644
--- a/kdesktop/lock/lockprocess.cc
+++ b/kdesktop/lock/lockprocess.cc
@@ -2842,6 +2842,13 @@ void ControlPipeHandlerObject::run(void) {
mThreadID = pthread_self();
mRunning = true;
+ sigset_t new_mask;
+ sigemptyset(&new_mask);
+ sigaddset(&new_mask, SIGUSR1);
+
+ // Unblock SIGUSR1
+ pthread_sigmask(SIG_UNBLOCK, &new_mask, NULL);
+
int display_number = atoi(TQString(XDisplayString(tqt_xdisplay())).replace(":","").ascii());
if (display_number < 0) {