void mouse_ps2_poll(int x, int y, int b) { uint8_t packet[3] = {0x08, 0, 0}; if (!x && !y && b == ps2_b) return; if (!mouse_scan) return; ps2_x += x; ps2_y -= y; if (mouse_ps2.mode == MOUSE_STREAM && (mouse_ps2.flags & MOUSE_ENABLE) && ((mouse_queue_end - mouse_queue_start) & 0xf) < 13) { ps2_b = b; // pclog("Send packet : %i %i\n", ps2_x, ps2_y); if (ps2_x > 255) ps2_x = 255; if (ps2_x < -256) ps2_x = -256; if (ps2_y > 255) ps2_y = 255; if (ps2_y < -256) ps2_y = -256; if (ps2_x < 0) packet[0] |= 0x10; if (ps2_y < 0) packet[0] |= 0x20; if (mouse_buttons & 1) packet[0] |= 1; if (mouse_buttons & 2) packet[0] |= 2; if (mouse_buttons & 4) packet[0] |= 4; packet[1] = ps2_x & 0xff; packet[2] = ps2_y & 0xff; ps2_x = ps2_y = 0; keyboard_at_adddata_mouse(packet[0]); keyboard_at_adddata_mouse(packet[1]); keyboard_at_adddata_mouse(packet[2]); } }
void keyboard_at_write(uint16_t port, uint8_t val, void *priv) { // pclog("keyboard_at : write %04X %02X %i %02X\n", port, val, keyboard_at.key_wantdata, ram[8]); /* if (ram[8] == 0xc3) { output = 3; }*/ switch (port) { case 0x60: if (keyboard_at.want60) { /*Write to controller*/ keyboard_at.want60 = 0; switch (keyboard_at.command) { case 0x60: case 0x61: case 0x62: case 0x63: case 0x64: case 0x65: case 0x66: case 0x67: case 0x68: case 0x69: case 0x6a: case 0x6b: case 0x6c: case 0x6d: case 0x6e: case 0x6f: case 0x70: case 0x71: case 0x72: case 0x73: case 0x74: case 0x75: case 0x76: case 0x77: case 0x78: case 0x79: case 0x7a: case 0x7b: case 0x7c: case 0x7d: case 0x7e: case 0x7f: keyboard_at.mem[keyboard_at.command & 0x1f] = val; if (keyboard_at.command == 0x60) { if ((val & 1) && (keyboard_at.status & STAT_OFULL)) keyboard_at.wantirq = 1; if (!(val & 1) && keyboard_at.wantirq) keyboard_at.wantirq = 0; } break; case 0xcb: /*AMI - set keyboard mode*/ break; case 0xcf: /*??? - sent by MegaPC BIOS*/ break; case 0xd1: /*Write output port*/ // pclog("Write output port - %02X %02X %04X:%04X\n", keyboard_at.output_port, val, CS, pc); if ((keyboard_at.output_port ^ val) & 0x02) /*A20 enable change*/ { mem_a20_key = val & 0x02; mem_a20_recalc(); // pclog("Rammask change to %08X %02X\n", rammask, val & 0x02); flushmmucache(); } keyboard_at.output_port = val; break; case 0xd3: /*Write to mouse output buffer*/ keyboard_at_adddata_mouse(val); break; case 0xd4: /*Write to mouse*/ if (mouse_write) mouse_write(val); break; default: pclog("Bad AT keyboard controller 0060 write %02X command %02X\n", val, keyboard_at.command); // dumpregs(); // exit(-1); } } else { /*Write to keyboard*/ keyboard_at.mem[0] &= ~0x10; if (keyboard_at.key_wantdata) { keyboard_at.key_wantdata = 0; switch (keyboard_at.key_command) { case 0xed: /*Set/reset LEDs*/ keyboard_at_adddata_keyboard(0xfa); break; case 0xf3: /*Set typematic rate/delay*/ keyboard_at_adddata_keyboard(0xfa); break; default: pclog("Bad AT keyboard 0060 write %02X command %02X\n", val, keyboard_at.key_command); // dumpregs(); // exit(-1); } } else { keyboard_at.key_command = val; switch (val) { case 0x05: /*??? - sent by NT 4.0*/ keyboard_at_adddata_keyboard(0xfe); break; case 0xed: /*Set/reset LEDs*/ keyboard_at.key_wantdata = 1; keyboard_at_adddata_keyboard(0xfa); break; case 0xf2: /*Read ID*/ keyboard_at_adddata_keyboard(0xfa); keyboard_at_adddata_keyboard(0xab); keyboard_at_adddata_keyboard(0x41); break; case 0xf3: /*Set typematic rate/delay*/ keyboard_at.key_wantdata = 1; keyboard_at_adddata_keyboard(0xfa); break; case 0xf4: /*Enable keyboard*/ keyboard_scan = 1; keyboard_at_adddata_keyboard(0xfa); break; case 0xf5: /*Disable keyboard*/ keyboard_scan = 0; keyboard_at_adddata_keyboard(0xfa); break; case 0xff: /*Reset*/ key_queue_start = key_queue_end = 0; /*Clear key queue*/ keyboard_at_adddata_keyboard(0xfa); keyboard_at_adddata_keyboard(0xaa); break; default: pclog("Bad AT keyboard command %02X\n", val); keyboard_at_adddata_keyboard(0xfe); // dumpregs(); // exit(-1); } } } break; case 0x61: ppi.pb = val; speaker_gated = val & 1; speaker_enable = val & 2; if (speaker_enable) was_speaker_enable = 1; pit_set_gate(2, val & 1); break; case 0x64: keyboard_at.want60 = 0; keyboard_at.command = val; /*New controller command*/ switch (val) { case 0x20: case 0x21: case 0x22: case 0x23: case 0x24: case 0x25: case 0x26: case 0x27: case 0x28: case 0x29: case 0x2a: case 0x2b: case 0x2c: case 0x2d: case 0x2e: case 0x2f: case 0x30: case 0x31: case 0x32: case 0x33: case 0x34: case 0x35: case 0x36: case 0x37: case 0x38: case 0x39: case 0x3a: case 0x3b: case 0x3c: case 0x3d: case 0x3e: case 0x3f: keyboard_at_adddata(keyboard_at.mem[val & 0x1f]); break; case 0x60: case 0x61: case 0x62: case 0x63: case 0x64: case 0x65: case 0x66: case 0x67: case 0x68: case 0x69: case 0x6a: case 0x6b: case 0x6c: case 0x6d: case 0x6e: case 0x6f: case 0x70: case 0x71: case 0x72: case 0x73: case 0x74: case 0x75: case 0x76: case 0x77: case 0x78: case 0x79: case 0x7a: case 0x7b: case 0x7c: case 0x7d: case 0x7e: case 0x7f: keyboard_at.want60 = 1; break; case 0xa1: /*AMI - get controlled version*/ break; case 0xa7: /*Disable mouse port*/ break; case 0xa9: /*Test mouse port*/ keyboard_at_adddata(0x00); /*no error*/ break; case 0xaa: /*Self-test*/ if (!keyboard_at.initialised) { keyboard_at.initialised = 1; key_ctrl_queue_start = key_ctrl_queue_end = 0; keyboard_at.status &= ~STAT_OFULL; } keyboard_at.status |= STAT_SYSFLAG; keyboard_at.mem[0] |= 0x04; keyboard_at_adddata(0x55); break; case 0xab: /*Interface test*/ keyboard_at_adddata(0x00); /*no error*/ break; case 0xad: /*Disable keyboard*/ keyboard_at.mem[0] |= 0x10; break; case 0xae: /*Enable keyboard*/ keyboard_at.mem[0] &= ~0x10; break; case 0xc0: /*Read input port*/ keyboard_at_adddata(keyboard_at.input_port); keyboard_at.input_port = ((keyboard_at.input_port + 1) & 3) | (keyboard_at.input_port & 0xfc); break; case 0xc9: /*AMI - block P22 and P23 ??? */ break; case 0xca: /*AMI - read keyboard mode*/ keyboard_at_adddata(0x00); /*ISA mode*/ break; case 0xcb: /*AMI - set keyboard mode*/ keyboard_at.want60 = 1; break; case 0xcf: /*??? - sent by MegaPC BIOS*/ keyboard_at.want60 = 1; break; case 0xd0: /*Read output port*/ keyboard_at_adddata(keyboard_at.output_port); break; case 0xd1: /*Write output port*/ keyboard_at.want60 = 1; break; case 0xd3: /*Write mouse output buffer*/ keyboard_at.want60 = 1; break; case 0xd4: /*Write to mouse*/ keyboard_at.want60 = 1; break; case 0xe0: /*Read test inputs*/ keyboard_at_adddata(0x00); break; case 0xef: /*??? - sent by AMI486*/ break; case 0xfe: /*Pulse output port - pin 0 selected - x86 reset*/ softresetx86(); /*Pulse reset!*/ break; case 0xff: /*Pulse output port - but no pins selected - sent by MegaPC BIOS*/ break; default: pclog("Bad AT keyboard controller command %02X\n", val); // dumpregs(); // exit(-1); } } }
void mouse_ps2_write(uint8_t val) { if (mouse_ps2.cd) { mouse_ps2.cd = 0; switch (mouse_ps2.command) { case 0xe8: /*Set mouse resolution*/ mouse_ps2.resolution = val; keyboard_at_adddata_mouse(0xfa); break; case 0xf3: /*Set sample rate*/ mouse_ps2.sample_rate = val; keyboard_at_adddata_mouse(0xfa); break; // default: // fatal("mouse_ps2 : Bad data write %02X for command %02X\n", val, mouse_ps2.command); } } else { uint8_t temp; mouse_ps2.command = val; switch (mouse_ps2.command) { case 0xe6: /*Set scaling to 1:1*/ mouse_ps2.flags &= ~MOUSE_SCALE; keyboard_at_adddata_mouse(0xfa); break; case 0xe7: /*Set scaling to 2:1*/ mouse_ps2.flags |= MOUSE_SCALE; keyboard_at_adddata_mouse(0xfa); break; case 0xe8: /*Set mouse resolution*/ mouse_ps2.cd = 1; keyboard_at_adddata_mouse(0xfa); break; case 0xe9: /*Status request*/ keyboard_at_adddata_mouse(0xfa); temp = mouse_ps2.flags; if (mouse_buttons & 1) temp |= 1; if (mouse_buttons & 2) temp |= 2; if (mouse_buttons & 4) temp |= 3; keyboard_at_adddata_mouse(temp); keyboard_at_adddata_mouse(mouse_ps2.resolution); keyboard_at_adddata_mouse(mouse_ps2.sample_rate); break; case 0xf2: /*Read ID*/ keyboard_at_adddata_mouse(0xfa); keyboard_at_adddata_mouse(0x00); break; case 0xf3: /*Set sample rate*/ mouse_ps2.cd = 1; keyboard_at_adddata_mouse(0xfa); break; case 0xf4: /*Enable*/ mouse_ps2.flags |= MOUSE_ENABLE; keyboard_at_adddata_mouse(0xfa); break; case 0xf5: /*Disable*/ mouse_ps2.flags &= ~MOUSE_ENABLE; keyboard_at_adddata_mouse(0xfa); break; case 0xff: /*Reset*/ mouse_ps2.mode = MOUSE_STREAM; mouse_ps2.flags = 0; keyboard_at_adddata_mouse(0xfa); keyboard_at_adddata_mouse(0xaa); keyboard_at_adddata_mouse(0x00); break; // default: // fatal("mouse_ps2 : Bad command %02X\n", val, mouse_ps2.command); } } }