10d09e41aSPaolo Bonzini /* 20d09e41aSPaolo Bonzini * QEMU PS/2 keyboard/mouse emulation 30d09e41aSPaolo Bonzini * 40d09e41aSPaolo Bonzini * Copyright (C) 2003 Fabrice Bellard 50d09e41aSPaolo Bonzini * 60d09e41aSPaolo Bonzini * Permission is hereby granted, free of charge, to any person obtaining a copy 70d09e41aSPaolo Bonzini * of this software and associated documentation files (the "Software"), to deal 80d09e41aSPaolo Bonzini * in the Software without restriction, including without limitation the rights 90d09e41aSPaolo Bonzini * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 100d09e41aSPaolo Bonzini * copies of the Software, and to permit persons to whom the Software is 110d09e41aSPaolo Bonzini * furnished to do so, subject to the following conditions: 120d09e41aSPaolo Bonzini * 130d09e41aSPaolo Bonzini * The above copyright notice and this permission notice shall be included in 140d09e41aSPaolo Bonzini * all copies or substantial portions of the Software. 150d09e41aSPaolo Bonzini * 160d09e41aSPaolo Bonzini * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 170d09e41aSPaolo Bonzini * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 180d09e41aSPaolo Bonzini * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL 190d09e41aSPaolo Bonzini * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 200d09e41aSPaolo Bonzini * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 210d09e41aSPaolo Bonzini * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN 220d09e41aSPaolo Bonzini * THE SOFTWARE. 230d09e41aSPaolo Bonzini */ 240d09e41aSPaolo Bonzini 250d09e41aSPaolo Bonzini #ifndef HW_PS2_H 260d09e41aSPaolo Bonzini #define HW_PS2_H 270d09e41aSPaolo Bonzini 28*0c235e38SMark Cave-Ayland #include "hw/sysbus.h" 29*0c235e38SMark Cave-Ayland 308b0caab0SFabian Lesniak #define PS2_MOUSE_BUTTON_LEFT 0x01 31ed6f72b8SFabian Lesniak #define PS2_MOUSE_BUTTON_RIGHT 0x02 32ed6f72b8SFabian Lesniak #define PS2_MOUSE_BUTTON_MIDDLE 0x04 338b0caab0SFabian Lesniak #define PS2_MOUSE_BUTTON_SIDE 0x08 348b0caab0SFabian Lesniak #define PS2_MOUSE_BUTTON_EXTRA 0x10 358b0caab0SFabian Lesniak 36*0c235e38SMark Cave-Ayland /* 37*0c235e38SMark Cave-Ayland * PS/2 buffer size. Keep 256 bytes for compatibility with 38*0c235e38SMark Cave-Ayland * older QEMU versions. 39*0c235e38SMark Cave-Ayland */ 40*0c235e38SMark Cave-Ayland #define PS2_BUFFER_SIZE 256 41*0c235e38SMark Cave-Ayland 42*0c235e38SMark Cave-Ayland typedef struct { 43*0c235e38SMark Cave-Ayland uint8_t data[PS2_BUFFER_SIZE]; 44*0c235e38SMark Cave-Ayland int rptr, wptr, cwptr, count; 45*0c235e38SMark Cave-Ayland } PS2Queue; 46*0c235e38SMark Cave-Ayland 47*0c235e38SMark Cave-Ayland struct PS2State { 48*0c235e38SMark Cave-Ayland SysBusDevice parent_obj; 49*0c235e38SMark Cave-Ayland 50*0c235e38SMark Cave-Ayland PS2Queue queue; 51*0c235e38SMark Cave-Ayland int32_t write_cmd; 52*0c235e38SMark Cave-Ayland void (*update_irq)(void *, int); 53*0c235e38SMark Cave-Ayland void *update_arg; 54*0c235e38SMark Cave-Ayland }; 55*0c235e38SMark Cave-Ayland 56*0c235e38SMark Cave-Ayland #define TYPE_PS2_DEVICE "ps2-device" 57*0c235e38SMark Cave-Ayland OBJECT_DECLARE_SIMPLE_TYPE(PS2State, PS2_DEVICE) 58*0c235e38SMark Cave-Ayland 59*0c235e38SMark Cave-Ayland struct PS2KbdState { 60*0c235e38SMark Cave-Ayland PS2State parent_obj; 61*0c235e38SMark Cave-Ayland 62*0c235e38SMark Cave-Ayland int scan_enabled; 63*0c235e38SMark Cave-Ayland int translate; 64*0c235e38SMark Cave-Ayland int scancode_set; /* 1=XT, 2=AT, 3=PS/2 */ 65*0c235e38SMark Cave-Ayland int ledstate; 66*0c235e38SMark Cave-Ayland bool need_high_bit; 67*0c235e38SMark Cave-Ayland unsigned int modifiers; /* bitmask of MOD_* constants above */ 68*0c235e38SMark Cave-Ayland }; 69*0c235e38SMark Cave-Ayland 70*0c235e38SMark Cave-Ayland #define TYPE_PS2_KBD_DEVICE "ps2-kbd" 71*0c235e38SMark Cave-Ayland OBJECT_DECLARE_SIMPLE_TYPE(PS2KbdState, PS2_KBD_DEVICE) 72*0c235e38SMark Cave-Ayland 73*0c235e38SMark Cave-Ayland struct PS2MouseState { 74*0c235e38SMark Cave-Ayland PS2State parent_obj; 75*0c235e38SMark Cave-Ayland 76*0c235e38SMark Cave-Ayland uint8_t mouse_status; 77*0c235e38SMark Cave-Ayland uint8_t mouse_resolution; 78*0c235e38SMark Cave-Ayland uint8_t mouse_sample_rate; 79*0c235e38SMark Cave-Ayland uint8_t mouse_wrap; 80*0c235e38SMark Cave-Ayland uint8_t mouse_type; /* 0 = PS2, 3 = IMPS/2, 4 = IMEX */ 81*0c235e38SMark Cave-Ayland uint8_t mouse_detect_state; 82*0c235e38SMark Cave-Ayland int mouse_dx; /* current values, needed for 'poll' mode */ 83*0c235e38SMark Cave-Ayland int mouse_dy; 84*0c235e38SMark Cave-Ayland int mouse_dz; 85*0c235e38SMark Cave-Ayland int mouse_dw; 86*0c235e38SMark Cave-Ayland uint8_t mouse_buttons; 87*0c235e38SMark Cave-Ayland }; 88*0c235e38SMark Cave-Ayland 89*0c235e38SMark Cave-Ayland #define TYPE_PS2_MOUSE_DEVICE "ps2-mouse" 90*0c235e38SMark Cave-Ayland OBJECT_DECLARE_SIMPLE_TYPE(PS2MouseState, PS2_MOUSE_DEVICE) 91fa9414e9SPhilippe Mathieu-Daudé 920d09e41aSPaolo Bonzini /* ps2.c */ 930d09e41aSPaolo Bonzini void *ps2_kbd_init(void (*update_irq)(void *, int), void *update_arg); 940d09e41aSPaolo Bonzini void *ps2_mouse_init(void (*update_irq)(void *, int), void *update_arg); 950d09e41aSPaolo Bonzini void ps2_write_mouse(void *, int val); 960d09e41aSPaolo Bonzini void ps2_write_keyboard(void *, int val); 978498bb8dSGerd Hoffmann uint32_t ps2_read_data(PS2State *s); 987abe7eb2SGeoffrey McRae void ps2_queue_noirq(PS2State *s, int b); 997abe7eb2SGeoffrey McRae void ps2_raise_irq(PS2State *s); 1008498bb8dSGerd Hoffmann void ps2_queue(PS2State *s, int b); 1017abe7eb2SGeoffrey McRae void ps2_queue_2(PS2State *s, int b1, int b2); 1027abe7eb2SGeoffrey McRae void ps2_queue_3(PS2State *s, int b1, int b2, int b3); 1037abe7eb2SGeoffrey McRae void ps2_queue_4(PS2State *s, int b1, int b2, int b3, int b4); 1040d09e41aSPaolo Bonzini void ps2_keyboard_set_translation(void *opaque, int mode); 1050d09e41aSPaolo Bonzini void ps2_mouse_fake_event(void *opaque); 1062a6505b0SSven Schnelle int ps2_queue_empty(PS2State *s); 1070d09e41aSPaolo Bonzini 108175de524SMarkus Armbruster #endif /* HW_PS2_H */ 109