toaruos/kernel/devices/mouse.c

91 lines
1.6 KiB
C
Raw Normal View History

/* vim: tabstop=4 shiftwidth=4 noexpandtab
* Mouse driver
*/
2011-10-29 09:33:45 +04:00
#include <system.h>
#include <logging.h>
2011-10-29 09:33:45 +04:00
uint8_t mouse_cycle = 0;
int8_t mouse_byte[3];
int8_t mouse_x = 0;
int8_t mouse_y = 0;
#define MOUSE_SCALE 10;
int32_t actual_x = 5120;
int32_t actual_y = 3835;
2011-10-29 09:33:45 +04:00
void mouse_handler(struct regs *r) {
switch (mouse_cycle) {
case 0:
mouse_byte[0] = inportb(0x60);
++mouse_cycle;
break;
case 1:
mouse_byte[1] = inportb(0x60);
++mouse_cycle;
break;
case 2:
mouse_byte[2] = inportb(0x60);
mouse_x = mouse_byte[1];
mouse_y = mouse_byte[2];
mouse_cycle = 0;
actual_x = actual_x + mouse_x * MOUSE_SCALE;
actual_y = actual_y + mouse_y * MOUSE_SCALE;
2011-10-29 09:33:45 +04:00
break;
}
}
void mouse_wait(uint8_t a_type) {
uint32_t timeout = 100000;
if (!a_type) {
while (--timeout) {
if ((inportb(0x64) & 0x01) == 1) {
return;
}
}
return;
} else {
while (--timeout) {
if (!((inportb(0x64) & 0x02))) {
return;
}
}
return;
}
}
void mouse_write(uint8_t write) {
mouse_wait(1);
outportb(0x64, 0xD4);
mouse_wait(1);
outportb(0x60, write);
}
uint8_t mouse_read() {
mouse_wait(0);
char t = inportb(0x60);
return t;
2011-10-29 09:33:45 +04:00
}
void mouse_install() {
LOG(INFO, "Initializing mouse cursor driver");
2011-10-29 09:33:45 +04:00
uint8_t status;
IRQ_OFF;
2011-10-29 09:33:45 +04:00
mouse_wait(1);
outportb(0x64,0xA8);
mouse_wait(1);
outportb(0x64,0x20);
mouse_wait(0);
status = inportb(0x60) | 2;
mouse_wait(1);
outportb(0x64, 0x60);
mouse_wait(1);
outportb(0x60, status);
mouse_write(0xF6);
mouse_read();
mouse_write(0xF4);
mouse_read();
IRQ_RES;
2011-10-29 09:33:45 +04:00
irq_install_handler(12, mouse_handler);
}