xref: /openbmc/qemu/include/hw/input/ps2.h (revision 0c235e38893c9376c7f235f7ecaf83c091436187)
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