1
0

Fix arrow keys

This commit is contained in:
Mark 2025-03-02 10:23:37 -08:00
parent bf202a42ba
commit 903b2d7ead
Signed by: Mark
GPG Key ID: C6D63995FE72FD80

View File

@ -89,23 +89,37 @@ enum InputKey {
} }
extern "x86-interrupt" fn keyboard_handler(_stack_frame: InterruptStackFrame) { extern "x86-interrupt" fn keyboard_handler(_stack_frame: InterruptStackFrame) {
'key_block: {
let scancode = unsafe { inb(0x60) }; let scancode = unsafe { inb(0x60) };
println!("{:x?}", scancode);
let key = match scancode { let key = match scancode {
0x11 => Some(InputKey::Up), 0x11 => Some(InputKey::Up), // W
0x1E => Some(InputKey::Left), 0x1E => Some(InputKey::Left), // A
0x1F => Some(InputKey::Down), 0x1F => Some(InputKey::Down), // S
0x20 => Some(InputKey::Right), 0x20 => Some(InputKey::Right), // D
// Extended codes
0xE0 => { 0xE0 => {
let scancode = unsafe { inb(0x60) }; let scancode = unsafe { inb(0x60) };
println!("e {:x?}", scancode); match scancode {
None 0x48 => Some(InputKey::Up), // Up arrow
0x4B => Some(InputKey::Left), // Left arrow
0x50 => Some(InputKey::Down), // Down arrow
0x4D => Some(InputKey::Right), // Right arrow
_ => break 'key_block, // Ignore unknown codes
} }
_ => None, }
// Ignore unrecognized keycodes.
//
// Note that this does NOT return to None!
// If we do that, "release" keycodes will
// immediately clear "press" keycodes.
_ => break 'key_block,
}; };
*LAST_INPUT.lock() = key; *LAST_INPUT.lock() = key;
}
PIC.lock().send_eoi(InterruptIndex::Keyboard.as_u8()); PIC.lock().send_eoi(InterruptIndex::Keyboard.as_u8());
} }