hw/usb: Regroup USB HID protocol values

Group some HID values that are used pretty much everywhere when
dealing with HID devices.

Signed-off-by: César Belley <cesar.belley@lse.epita.fr>
Message-id: 20200812094135.20550-2-cesar.belley@lse.epita.fr
Signed-off-by: Gerd Hoffmann <kraxel@redhat.com>
This commit is contained in:
César Belley 2020-08-12 11:41:23 +02:00 committed by Gerd Hoffmann
parent 10b2d90c94
commit 84b6c23629
3 changed files with 27 additions and 28 deletions

View File

@ -32,21 +32,9 @@
#include "qemu/module.h" #include "qemu/module.h"
#include "qemu/timer.h" #include "qemu/timer.h"
#include "hw/input/hid.h" #include "hw/input/hid.h"
#include "hw/usb/hid.h"
#include "hw/qdev-properties.h" #include "hw/qdev-properties.h"
/* HID interface requests */
#define GET_REPORT 0xa101
#define GET_IDLE 0xa102
#define GET_PROTOCOL 0xa103
#define SET_REPORT 0x2109
#define SET_IDLE 0x210a
#define SET_PROTOCOL 0x210b
/* HID descriptor types */
#define USB_DT_HID 0x21
#define USB_DT_REPORT 0x22
#define USB_DT_PHY 0x23
typedef struct USBHIDState { typedef struct USBHIDState {
USBDevice dev; USBDevice dev;
USBEndpoint *intr; USBEndpoint *intr;
@ -618,38 +606,38 @@ static void usb_hid_handle_control(USBDevice *dev, USBPacket *p,
goto fail; goto fail;
} }
break; break;
case GET_REPORT: case HID_GET_REPORT:
if (hs->kind == HID_MOUSE || hs->kind == HID_TABLET) { if (hs->kind == HID_MOUSE || hs->kind == HID_TABLET) {
p->actual_length = hid_pointer_poll(hs, data, length); p->actual_length = hid_pointer_poll(hs, data, length);
} else if (hs->kind == HID_KEYBOARD) { } else if (hs->kind == HID_KEYBOARD) {
p->actual_length = hid_keyboard_poll(hs, data, length); p->actual_length = hid_keyboard_poll(hs, data, length);
} }
break; break;
case SET_REPORT: case HID_SET_REPORT:
if (hs->kind == HID_KEYBOARD) { if (hs->kind == HID_KEYBOARD) {
p->actual_length = hid_keyboard_write(hs, data, length); p->actual_length = hid_keyboard_write(hs, data, length);
} else { } else {
goto fail; goto fail;
} }
break; break;
case GET_PROTOCOL: case HID_GET_PROTOCOL:
if (hs->kind != HID_KEYBOARD && hs->kind != HID_MOUSE) { if (hs->kind != HID_KEYBOARD && hs->kind != HID_MOUSE) {
goto fail; goto fail;
} }
data[0] = hs->protocol; data[0] = hs->protocol;
p->actual_length = 1; p->actual_length = 1;
break; break;
case SET_PROTOCOL: case HID_SET_PROTOCOL:
if (hs->kind != HID_KEYBOARD && hs->kind != HID_MOUSE) { if (hs->kind != HID_KEYBOARD && hs->kind != HID_MOUSE) {
goto fail; goto fail;
} }
hs->protocol = value; hs->protocol = value;
break; break;
case GET_IDLE: case HID_GET_IDLE:
data[0] = hs->idle; data[0] = hs->idle;
p->actual_length = 1; p->actual_length = 1;
break; break;
case SET_IDLE: case HID_SET_IDLE:
hs->idle = (uint8_t) (value >> 8); hs->idle = (uint8_t) (value >> 8);
hid_set_next_idle(hs); hid_set_next_idle(hs);
if (hs->kind == HID_MOUSE || hs->kind == HID_TABLET) { if (hs->kind == HID_MOUSE || hs->kind == HID_TABLET) {

View File

@ -29,6 +29,7 @@
#include "qemu/osdep.h" #include "qemu/osdep.h"
#include "ui/console.h" #include "ui/console.h"
#include "hw/usb.h" #include "hw/usb.h"
#include "hw/usb/hid.h"
#include "migration/vmstate.h" #include "migration/vmstate.h"
#include "qemu/module.h" #include "qemu/module.h"
#include "desc.h" #include "desc.h"
@ -37,13 +38,6 @@
#define WACOM_GET_REPORT 0x2101 #define WACOM_GET_REPORT 0x2101
#define WACOM_SET_REPORT 0x2109 #define WACOM_SET_REPORT 0x2109
/* HID interface requests */
#define HID_GET_REPORT 0xa101
#define HID_GET_IDLE 0xa102
#define HID_GET_PROTOCOL 0xa103
#define HID_SET_IDLE 0x210a
#define HID_SET_PROTOCOL 0x210b
typedef struct USBWacomState { typedef struct USBWacomState {
USBDevice dev; USBDevice dev;
USBEndpoint *intr; USBEndpoint *intr;
@ -86,11 +80,11 @@ static const USBDescIface desc_iface_wacom = {
/* HID descriptor */ /* HID descriptor */
.data = (uint8_t[]) { .data = (uint8_t[]) {
0x09, /* u8 bLength */ 0x09, /* u8 bLength */
0x21, /* u8 bDescriptorType */ USB_DT_HID, /* u8 bDescriptorType */
0x01, 0x10, /* u16 HID_class */ 0x01, 0x10, /* u16 HID_class */
0x00, /* u8 country_code */ 0x00, /* u8 country_code */
0x01, /* u8 num_descriptors */ 0x01, /* u8 num_descriptors */
0x22, /* u8 type: Report */ USB_DT_REPORT, /* u8 type: Report */
0x6e, 0, /* u16 len */ 0x6e, 0, /* u16 len */
}, },
}, },

17
include/hw/usb/hid.h Normal file
View File

@ -0,0 +1,17 @@
#ifndef HW_USB_HID_H
#define HW_USB_HID_H
/* HID interface requests */
#define HID_GET_REPORT 0xa101
#define HID_GET_IDLE 0xa102
#define HID_GET_PROTOCOL 0xa103
#define HID_SET_REPORT 0x2109
#define HID_SET_IDLE 0x210a
#define HID_SET_PROTOCOL 0x210b
/* HID descriptor types */
#define USB_DT_HID 0x21
#define USB_DT_REPORT 0x22
#define USB_DT_PHY 0x23
#endif