Skip to content

Commit

Permalink
Pkg-Module: Features/VirtualKeyboardDxe
Browse files Browse the repository at this point in the history
The Keyboard.c driver did not include ScanCodes like F1,F2,F12,etc.
and UnicodeChars like Backspace, Tab in VK_NOTIFY NotifyList
which is why these keys were not getting registered and
not getting pushed in the KeyBuffer stack which resulted
in undefined behavior of continuous backspace and not recognizing the
relevant key push after the buffer overflow condition

Signed-off-by: Contributor Name <[email protected]>
  • Loading branch information
darbin-reyes committed Nov 26, 2024
1 parent 4f0b58d commit b41ed8c
Showing 1 changed file with 36 additions and 21 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -883,33 +883,48 @@ VkApiStart (

KeyData.KeyState.KeyToggleState = 0;
KeyData.KeyState.KeyShiftState = 0;
KeyData.Key.ScanCode = SCAN_ESC;
KeyData.Key.UnicodeChar = CHAR_NULL;
NotifyHandle = NULL;
Status = SimpleEx->RegisterKeyNotify (
SimpleEx,
&KeyData,
VkNotifyKeyCallback,
&NotifyHandle
);
if (EFI_ERROR (Status)) {
DEBUG ((DEBUG_VK_ROUTINE_ENTRY_EXIT | DEBUG_ERROR, "ERROR - Failed to register 'Esc', Status: %r\n", Status));
goto Error;

for (KeyData.Key.ScanCode = SCAN_UP; KeyData.Key.ScanCode <= SCAN_ESC; KeyData.Key.ScanCode++) {
Status = SimpleEx->RegisterKeyNotify (
SimpleEx,
&KeyData,
VkNotifyKeyCallback,
&NotifyHandle
);
if (EFI_ERROR (Status)) {
DEBUG ((
DEBUG_VK_ROUTINE_ENTRY_EXIT | DEBUG_ERROR,
"ERROR - Failed to register '%c', Status: %r\n",
KeyData.Key.ScanCode,
Status
));
break;
}
}

KeyData.KeyState.KeyToggleState = 0;
KeyData.KeyState.KeyShiftState = 0;
KeyData.Key.ScanCode = SCAN_NULL;
KeyData.Key.UnicodeChar = CHAR_CARRIAGE_RETURN;
Status = SimpleEx->RegisterKeyNotify (
SimpleEx,
&KeyData,
VkNotifyKeyCallback,
&NotifyHandle
);
if (EFI_ERROR (Status)) {
DEBUG ((DEBUG_VK_ROUTINE_ENTRY_EXIT | DEBUG_ERROR, "ERROR - Failed to register 'Enter', Status: %r\n", Status));
goto Error;
KeyData.Key.UnicodeChar = CHAR_NULL;
NotifyHandle = NULL;

for (KeyData.Key.UnicodeChar = CHAR_BACKSPACE; KeyData.Key.UnicodeChar <= CHAR_CARRIAGE_RETURN; KeyData.Key.UnicodeChar++) {
Status = SimpleEx->RegisterKeyNotify (
SimpleEx,
&KeyData,
VkNotifyKeyCallback,
&NotifyHandle
);
if (EFI_ERROR (Status)) {
DEBUG ((
DEBUG_VK_ROUTINE_ENTRY_EXIT | DEBUG_ERROR,
"ERROR - Failed to register '%c', Status: %r\n",
KeyData.Key.UnicodeChar,
Status
));
break;
}
}

for (KeyData.Key.UnicodeChar = L' '; KeyData.Key.UnicodeChar <= L'~'; KeyData.Key.UnicodeChar++) {
Expand Down

0 comments on commit b41ed8c

Please sign in to comment.