diff options
author | Mounir IDRASSI <mounir.idrassi@idrix.fr> | 2019-09-26 23:00:07 +0200 |
---|---|---|
committer | Mounir IDRASSI <mounir.idrassi@idrix.fr> | 2019-09-26 23:01:46 +0200 |
commit | 684259b43833c0579fd03ea0c1a4215df26bb21f (patch) | |
tree | f8d5426bf28e8cf5e4ab3e2291176573815d6014 /src/Common/Dlgcode.c | |
parent | 0e2be7153fd189272ec2d228bcf94ec682a396bc (diff) | |
download | VeraCrypt-684259b43833c0579fd03ea0c1a4215df26bb21f.tar.gz VeraCrypt-684259b43833c0579fd03ea0c1a4215df26bb21f.zip |
Windows: Fix sporadic keyboard issue in Secure Desktop for password dialog by not using the trick to put it reliably in foreground. The trick is based on a emulation of ALT+TAB but sometimes ALT key would remain pressed in case of Secure Desktop making it impossible to type the password (a workaround was to press CTRL key which reset the state of ALT key)
Diffstat (limited to 'src/Common/Dlgcode.c')
-rw-r--r-- | src/Common/Dlgcode.c | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/src/Common/Dlgcode.c b/src/Common/Dlgcode.c index 64c1147b..63081dd5 100644 --- a/src/Common/Dlgcode.c +++ b/src/Common/Dlgcode.c @@ -221,6 +221,9 @@ static std::vector<HostDevice> rawHostDeviceList; /* Critical section used to ensure that only one thread at a time can create a secure desktop */ CRITICAL_SECTION csSecureDesktop; +/* Boolean that indicates if our Secure Desktop is active and being user of not */ +BOOL bSecureDesktopOngoing = FALSE; + HINSTANCE hInst = NULL; HCURSOR hCursor = NULL; @@ -13584,7 +13587,8 @@ INT_PTR SecureDesktopDialogBoxParam( HDESK hInputDesk = NULL; EnterCriticalSection (&csSecureDesktop); - finally_do ({ LeaveCriticalSection (&csSecureDesktop); }); + bSecureDesktopOngoing = TRUE; + finally_do ({ bSecureDesktopOngoing = FALSE; LeaveCriticalSection (&csSecureDesktop); }); // wait for the input desktop to be available before switching to // secure desktop. Under Windows 10, the user session can be started |