2016-09-20 01:19:49 +02:00
|
|
|
use std::fs::File;
|
|
|
|
use std::io::{Read, Write};
|
|
|
|
use std::mem;
|
|
|
|
use std::thread;
|
|
|
|
|
|
|
|
use keymap;
|
|
|
|
|
2016-09-22 18:10:27 +02:00
|
|
|
pub fn keyboard() {
|
2016-09-20 01:19:49 +02:00
|
|
|
let mut file = File::open("irq:1").expect("ps2d: failed to open irq:1");
|
2016-09-22 18:10:27 +02:00
|
|
|
let mut input = File::open("display:input").expect("ps2d: failed to open display:input");
|
2016-09-20 01:19:49 +02:00
|
|
|
|
2016-09-22 18:10:27 +02:00
|
|
|
let mut lshift = false;
|
|
|
|
let mut rshift = false;
|
2016-09-20 01:19:49 +02:00
|
|
|
loop {
|
|
|
|
let mut irqs = [0; 8];
|
|
|
|
if file.read(&mut irqs).expect("ps2d: failed to read irq:1") >= mem::size_of::<usize>() {
|
|
|
|
let data: u8;
|
|
|
|
unsafe {
|
|
|
|
asm!("in al, dx" : "={al}"(data) : "{dx}"(0x60) : : "intel", "volatile");
|
|
|
|
}
|
|
|
|
|
2016-09-22 18:10:27 +02:00
|
|
|
file.write(&irqs).expect("ps2d: failed to write irq:1");
|
|
|
|
|
2016-09-20 01:19:49 +02:00
|
|
|
let (scancode, pressed) = if data >= 0x80 {
|
|
|
|
(data - 0x80, false)
|
|
|
|
} else {
|
|
|
|
(data, true)
|
|
|
|
};
|
|
|
|
|
2016-09-22 18:10:27 +02:00
|
|
|
if scancode == 0x2A {
|
|
|
|
lshift = pressed;
|
|
|
|
} else if scancode == 0x36 {
|
|
|
|
rshift = pressed;
|
|
|
|
} else if pressed {
|
|
|
|
let c = keymap::get_char(scancode, lshift || rshift);
|
|
|
|
if c != '\0' {
|
|
|
|
input.write(&[c as u8]).expect("ps2d: failed to write input");
|
|
|
|
}
|
2016-09-20 01:19:49 +02:00
|
|
|
}
|
|
|
|
} else {
|
|
|
|
thread::yield_now();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|