2011-12-11 03:34:10 +04:00
|
|
|
/* vim: tabstop=4 shiftwidth=4 noexpandtab
|
|
|
|
* Mouse driver
|
|
|
|
*/
|
2011-10-29 09:33:45 +04:00
|
|
|
#include <system.h>
|
2011-12-15 05:43:14 +04:00
|
|
|
#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;
|
|
|
|
|
2011-10-31 21:36:02 +04:00
|
|
|
#define MOUSE_SCALE 10;
|
|
|
|
|
2011-10-31 04:15:32 +04:00
|
|
|
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;
|
2011-10-31 21:36:02 +04:00
|
|
|
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);
|
2011-10-31 10:30:48 +04:00
|
|
|
char t = inportb(0x60);
|
|
|
|
return t;
|
2011-10-29 09:33:45 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
void mouse_install() {
|
2011-12-15 05:43:14 +04:00
|
|
|
LOG(INFO, "Initializing mouse cursor driver");
|
2011-10-29 09:33:45 +04:00
|
|
|
uint8_t status;
|
2011-10-31 10:30:48 +04:00
|
|
|
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();
|
2012-01-25 10:19:52 +04:00
|
|
|
IRQ_RES;
|
2011-10-29 09:33:45 +04:00
|
|
|
irq_install_handler(12, mouse_handler);
|
|
|
|
}
|