mirror of https://github.com/PCSX2/pcsx2.git
USB: Merge generic HID Keyboard and Konami Beatmania
This commit is contained in:
parent
1df2fdff3e
commit
3a55653c3e
|
@ -71,13 +71,12 @@ void RegisterDevice::Register()
|
||||||
inst.Add(DEVTYPE_SINGSTAR, new usb_mic::SingstarDevice());
|
inst.Add(DEVTYPE_SINGSTAR, new usb_mic::SingstarDevice());
|
||||||
inst.Add(DEVTYPE_LOGITECH_MIC, new usb_mic::LogitechMicDevice());
|
inst.Add(DEVTYPE_LOGITECH_MIC, new usb_mic::LogitechMicDevice());
|
||||||
inst.Add(DEVTYPE_LOGITECH_HEADSET, new usb_mic::HeadsetDevice());
|
inst.Add(DEVTYPE_LOGITECH_HEADSET, new usb_mic::HeadsetDevice());
|
||||||
inst.Add(DEVTYPE_HIDKBD, new usb_hid::HIDKbdDevice());
|
inst.Add(DEVTYPE_HIDKEYBOARD, new usb_hid::HIDKbdDevice());
|
||||||
inst.Add(DEVTYPE_HIDMOUSE, new usb_hid::HIDMouseDevice());
|
inst.Add(DEVTYPE_HIDMOUSE, new usb_hid::HIDMouseDevice());
|
||||||
inst.Add(DEVTYPE_RBKIT, new usb_pad::RBDrumKitDevice());
|
inst.Add(DEVTYPE_RBKIT, new usb_pad::RBDrumKitDevice());
|
||||||
inst.Add(DEVTYPE_DJ, new usb_pad::DJTurntableDevice());
|
inst.Add(DEVTYPE_DJ, new usb_pad::DJTurntableDevice());
|
||||||
inst.Add(DEVTYPE_BUZZ, new usb_pad::BuzzDevice());
|
inst.Add(DEVTYPE_BUZZ, new usb_pad::BuzzDevice());
|
||||||
inst.Add(DEVTYPE_EYETOY, new usb_eyetoy::EyeToyWebCamDevice());
|
inst.Add(DEVTYPE_EYETOY, new usb_eyetoy::EyeToyWebCamDevice());
|
||||||
inst.Add(DEVTYPE_BEATMANIA_DADADA, new usb_hid::BeatManiaDevice());
|
|
||||||
inst.Add(DEVTYPE_TRANCE_VIBRATOR, new usb_pad::TranceVibratorDevice());
|
inst.Add(DEVTYPE_TRANCE_VIBRATOR, new usb_pad::TranceVibratorDevice());
|
||||||
inst.Add(DEVTYPE_SEGA_SEAMIC, new usb_pad::SeamicDevice());
|
inst.Add(DEVTYPE_SEGA_SEAMIC, new usb_pad::SeamicDevice());
|
||||||
inst.Add(DEVTYPE_PRINTER, new usb_printer::PrinterDevice());
|
inst.Add(DEVTYPE_PRINTER, new usb_printer::PrinterDevice());
|
||||||
|
|
|
@ -29,12 +29,11 @@ enum DeviceType : s32
|
||||||
DEVTYPE_SINGSTAR,
|
DEVTYPE_SINGSTAR,
|
||||||
DEVTYPE_LOGITECH_MIC,
|
DEVTYPE_LOGITECH_MIC,
|
||||||
DEVTYPE_LOGITECH_HEADSET,
|
DEVTYPE_LOGITECH_HEADSET,
|
||||||
DEVTYPE_HIDKBD,
|
DEVTYPE_HIDKEYBOARD,
|
||||||
DEVTYPE_HIDMOUSE,
|
DEVTYPE_HIDMOUSE,
|
||||||
DEVTYPE_RBKIT,
|
DEVTYPE_RBKIT,
|
||||||
DEVTYPE_BUZZ,
|
DEVTYPE_BUZZ,
|
||||||
DEVTYPE_EYETOY,
|
DEVTYPE_EYETOY,
|
||||||
DEVTYPE_BEATMANIA_DADADA,
|
|
||||||
DEVTYPE_TRANCE_VIBRATOR,
|
DEVTYPE_TRANCE_VIBRATOR,
|
||||||
DEVTYPE_SEGA_SEAMIC,
|
DEVTYPE_SEGA_SEAMIC,
|
||||||
DEVTYPE_PRINTER,
|
DEVTYPE_PRINTER,
|
||||||
|
|
|
@ -18,8 +18,6 @@
|
||||||
#define HID_MOUSE 1
|
#define HID_MOUSE 1
|
||||||
#define HID_TABLET 2
|
#define HID_TABLET 2
|
||||||
#define HID_KEYBOARD 3
|
#define HID_KEYBOARD 3
|
||||||
// idk
|
|
||||||
#define HID_SUBKIND_BEATMANIA 1
|
|
||||||
|
|
||||||
/* scancode without modifiers */
|
/* scancode without modifiers */
|
||||||
#define SCANCODE_KEYMASK 0xff
|
#define SCANCODE_KEYMASK 0xff
|
||||||
|
@ -312,11 +310,9 @@ struct HIDState
|
||||||
uint32_t head; /* index into circular queue */
|
uint32_t head; /* index into circular queue */
|
||||||
uint32_t n;
|
uint32_t n;
|
||||||
int kind;
|
int kind;
|
||||||
int sub_kind;
|
|
||||||
int32_t protocol;
|
int32_t protocol;
|
||||||
uint8_t idle;
|
uint8_t idle;
|
||||||
bool idle_pending;
|
bool idle_pending;
|
||||||
//QEMUTimer *idle_timer;
|
|
||||||
HIDEventFunc event;
|
HIDEventFunc event;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -88,85 +88,6 @@ namespace usb_hid
|
||||||
"USB JIS Mini Keyboard",
|
"USB JIS Mini Keyboard",
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
/* mostly the same values as the Bochs USB Keyboard device */
|
|
||||||
static const uint8_t kbd_dev_desc[] = {
|
|
||||||
0x12, /* u8 bLength; */
|
|
||||||
0x01, /* u8 bDescriptorType; Device */
|
|
||||||
0x10, 0x00, /* u16 bcdUSB; v1.0 */
|
|
||||||
|
|
||||||
0x00, /* u8 bDeviceClass; */
|
|
||||||
0x00, /* u8 bDeviceSubClass; */
|
|
||||||
0x00, /* u8 bDeviceProtocol; [ low/full speeds only ] */
|
|
||||||
0x08, /* u8 bMaxPacketSize0; 8 Bytes */
|
|
||||||
|
|
||||||
// 0x27, 0x06, /* u16 idVendor; */
|
|
||||||
0x4C, 0x05,
|
|
||||||
// 0x01, 0x00, /* u16 idProduct; */
|
|
||||||
0x00, 0x10,
|
|
||||||
0x00, 0x00, /* u16 bcdDevice */
|
|
||||||
|
|
||||||
STR_MANUFACTURER, /* u8 iManufacturer; */
|
|
||||||
STR_PRODUCT_KEYBOARD, /* u8 iProduct; */
|
|
||||||
STR_SERIALNUMBER, /* u8 iSerialNumber; */
|
|
||||||
0x01 /* u8 bNumConfigurations; */
|
|
||||||
};
|
|
||||||
|
|
||||||
static const uint8_t kbd_config_desc[] = {
|
|
||||||
/* one configuration */
|
|
||||||
0x09, /* u8 bLength; */
|
|
||||||
0x02, /* u8 bDescriptorType; Configuration */
|
|
||||||
0x22, 0x00, /* u16 wTotalLength; */
|
|
||||||
0x01, /* u8 bNumInterfaces; (1) */
|
|
||||||
0x01, /* u8 bConfigurationValue; */
|
|
||||||
0x04, /* u8 iConfiguration; */
|
|
||||||
0xa0, /* u8 bmAttributes;
|
|
||||||
Bit 7: must be set,
|
|
||||||
6: Self-powered,
|
|
||||||
5: Remote wakeup,
|
|
||||||
4..0: resvd */
|
|
||||||
50, /* u8 MaxPower; */
|
|
||||||
|
|
||||||
/* USB 1.1:
|
|
||||||
* USB 2.0, single TT organization (mandatory):
|
|
||||||
* one interface, protocol 0
|
|
||||||
*
|
|
||||||
* USB 2.0, multiple TT organization (optional):
|
|
||||||
* two interfaces, protocols 1 (like single TT)
|
|
||||||
* and 2 (multiple TT mode) ... config is
|
|
||||||
* sometimes settable
|
|
||||||
* NOT IMPLEMENTED
|
|
||||||
*/
|
|
||||||
|
|
||||||
/* one interface */
|
|
||||||
0x09, /* u8 if_bLength; */
|
|
||||||
0x04, /* u8 if_bDescriptorType; Interface */
|
|
||||||
0x00, /* u8 if_bInterfaceNumber; */
|
|
||||||
0x00, /* u8 if_bAlternateSetting; */
|
|
||||||
0x01, /* u8 if_bNumEndpoints; */
|
|
||||||
0x03, /* u8 if_bInterfaceClass; */
|
|
||||||
0x01, /* u8 if_bInterfaceSubClass; */
|
|
||||||
0x01, /* u8 if_bInterfaceProtocol; [usb1.1 or single tt] */
|
|
||||||
0x05, /* u8 if_iInterface; */
|
|
||||||
|
|
||||||
/* HID descriptor */
|
|
||||||
0x09, /* u8 bLength; */
|
|
||||||
0x21, /* u8 bDescriptorType; */
|
|
||||||
0x01, 0x00, /* u16 HID_class */
|
|
||||||
0x00, /* u8 country_code */
|
|
||||||
0x01, /* u8 num_descriptors */
|
|
||||||
0x22, /* u8 type; Report */
|
|
||||||
63, 0, /* u16 len */
|
|
||||||
|
|
||||||
/* one endpoint (status change endpoint) */
|
|
||||||
0x07, /* u8 ep_bLength; */
|
|
||||||
0x05, /* u8 ep_bDescriptorType; Endpoint */
|
|
||||||
0x81, /* u8 ep_bEndpointAddress; IN Endpoint 1 */
|
|
||||||
0x03, /* u8 ep_bmAttributes; Interrupt */
|
|
||||||
0x08, 0x00, /* u16 ep_wMaxPacketSize; */
|
|
||||||
0x0a, /* u8 ep_bInterval; (255ms -- usb 2.0 spec) */
|
|
||||||
};
|
|
||||||
|
|
||||||
/* mostly the same values as the Bochs USB Mouse device */
|
/* mostly the same values as the Bochs USB Mouse device */
|
||||||
static const uint8_t qemu_mouse_dev_descriptor[] = {
|
static const uint8_t qemu_mouse_dev_descriptor[] = {
|
||||||
0x12, /* u8 bLength; */
|
0x12, /* u8 bLength; */
|
||||||
|
@ -368,41 +289,6 @@ namespace usb_hid
|
||||||
0xc0, /* End Collection */
|
0xc0, /* End Collection */
|
||||||
};
|
};
|
||||||
|
|
||||||
static const uint8_t qemu_keyboard_hid_report_descriptor[] = {
|
|
||||||
0x05, 0x01, /* Usage Page (Generic Desktop) */
|
|
||||||
0x09, 0x06, /* Usage (Keyboard) */
|
|
||||||
0xa1, 0x01, /* Collection (Application) */
|
|
||||||
0x75, 0x01, /* Report Size (1) */
|
|
||||||
0x95, 0x08, /* Report Count (8) */
|
|
||||||
0x05, 0x07, /* Usage Page (Key Codes) */
|
|
||||||
0x19, 0xe0, /* Usage Minimum (224) */
|
|
||||||
0x29, 0xe7, /* Usage Maximum (231) */
|
|
||||||
0x15, 0x00, /* Logical Minimum (0) */
|
|
||||||
0x25, 0x01, /* Logical Maximum (1) */
|
|
||||||
0x81, 0x02, /* Input (Data, Variable, Absolute) */
|
|
||||||
0x95, 0x01, /* Report Count (1) */
|
|
||||||
0x75, 0x08, /* Report Size (8) */
|
|
||||||
0x81, 0x01, /* Input (Constant) */
|
|
||||||
0x95, 0x05, /* Report Count (5) */
|
|
||||||
0x75, 0x01, /* Report Size (1) */
|
|
||||||
0x05, 0x08, /* Usage Page (LEDs) */
|
|
||||||
0x19, 0x01, /* Usage Minimum (1) */
|
|
||||||
0x29, 0x05, /* Usage Maximum (5) */
|
|
||||||
0x91, 0x02, /* Output (Data, Variable, Absolute) */
|
|
||||||
0x95, 0x01, /* Report Count (1) */
|
|
||||||
0x75, 0x03, /* Report Size (3) */
|
|
||||||
0x91, 0x01, /* Output (Constant) */
|
|
||||||
0x95, 0x06, /* Report Count (6) */
|
|
||||||
0x75, 0x08, /* Report Size (8) */
|
|
||||||
0x15, 0x00, /* Logical Minimum (0) */
|
|
||||||
0x25, 0xff, /* Logical Maximum (255) */
|
|
||||||
0x05, 0x07, /* Usage Page (Key Codes) */
|
|
||||||
0x19, 0x00, /* Usage Minimum (0) */
|
|
||||||
0x29, 0xff, /* Usage Maximum (255) */
|
|
||||||
0x81, 0x00, /* Input (Data, Array) */
|
|
||||||
0xc0, /* End Collection */
|
|
||||||
};
|
|
||||||
|
|
||||||
static const uint8_t beatmania_dev_desc[] = {
|
static const uint8_t beatmania_dev_desc[] = {
|
||||||
0x12, /* u8 bLength; */
|
0x12, /* u8 bLength; */
|
||||||
0x01, /* u8 bDescriptorType; Device */
|
0x01, /* u8 bDescriptorType; Device */
|
||||||
|
@ -701,16 +587,8 @@ namespace usb_hid
|
||||||
}
|
}
|
||||||
else if (hs->kind == HID_KEYBOARD)
|
else if (hs->kind == HID_KEYBOARD)
|
||||||
{
|
{
|
||||||
if (hs->sub_kind == HID_SUBKIND_BEATMANIA)
|
p->actual_length = sizeof(beatmania_dadada_hid_report_descriptor);
|
||||||
{
|
memcpy(data, beatmania_dadada_hid_report_descriptor, p->actual_length);
|
||||||
p->actual_length = sizeof(beatmania_dadada_hid_report_descriptor);
|
|
||||||
memcpy(data, beatmania_dadada_hid_report_descriptor, p->actual_length);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
p->actual_length = sizeof(qemu_keyboard_hid_report_descriptor);
|
|
||||||
memcpy(data, qemu_keyboard_hid_report_descriptor, p->actual_length);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
|
@ -893,11 +771,11 @@ namespace usb_hid
|
||||||
{
|
{
|
||||||
UsbHIDState* s = new UsbHIDState(port);
|
UsbHIDState* s = new UsbHIDState(port);
|
||||||
s->desc.full = &s->desc_dev;
|
s->desc.full = &s->desc_dev;
|
||||||
s->desc.str = desc_strings;
|
s->desc.str = beatmania_dadada_desc_strings;
|
||||||
|
|
||||||
if (usb_desc_parse_dev(kbd_dev_desc, sizeof(kbd_dev_desc), s->desc, s->desc_dev) < 0)
|
if (usb_desc_parse_dev(beatmania_dev_desc, sizeof(beatmania_dev_desc), s->desc, s->desc_dev) < 0)
|
||||||
goto fail;
|
goto fail;
|
||||||
if (usb_desc_parse_config(kbd_config_desc, sizeof(kbd_config_desc), s->desc_dev) < 0)
|
if (usb_desc_parse_config(beatmania_config_desc, sizeof(beatmania_config_desc), s->desc_dev) < 0)
|
||||||
goto fail;
|
goto fail;
|
||||||
|
|
||||||
s->dev.speed = USB_SPEED_FULL;
|
s->dev.speed = USB_SPEED_FULL;
|
||||||
|
@ -940,7 +818,7 @@ namespace usb_hid
|
||||||
|
|
||||||
const char* HIDKbdDevice::Name() const
|
const char* HIDKbdDevice::Name() const
|
||||||
{
|
{
|
||||||
return TRANSLATE_NOOP("USB", "HID Keyboard");
|
return TRANSLATE_NOOP("USB", "HID Keyboard (Konami)");
|
||||||
}
|
}
|
||||||
|
|
||||||
const char* HIDKbdDevice::TypeName() const
|
const char* HIDKbdDevice::TypeName() const
|
||||||
|
@ -1083,59 +961,4 @@ namespace usb_hid
|
||||||
else
|
else
|
||||||
s->QueueMouseAxisState(static_cast<InputPointerAxis>(bind - INPUT_BUTTON__MAX), value);
|
s->QueueMouseAxisState(static_cast<InputPointerAxis>(bind - INPUT_BUTTON__MAX), value);
|
||||||
}
|
}
|
||||||
|
|
||||||
// ---- BeatMania Da Da Da!! ----
|
|
||||||
|
|
||||||
USBDevice* BeatManiaDevice::CreateDevice(SettingsInterface& si, u32 port, u32 subtype) const
|
|
||||||
{
|
|
||||||
UsbHIDState* s = new UsbHIDState(port);
|
|
||||||
|
|
||||||
s->desc.full = &s->desc_dev;
|
|
||||||
s->desc.str = beatmania_dadada_desc_strings;
|
|
||||||
|
|
||||||
if (usb_desc_parse_dev(beatmania_dev_desc, sizeof(beatmania_dev_desc), s->desc, s->desc_dev) < 0)
|
|
||||||
goto fail;
|
|
||||||
if (usb_desc_parse_config(beatmania_config_desc, sizeof(beatmania_config_desc), s->desc_dev) < 0)
|
|
||||||
goto fail;
|
|
||||||
|
|
||||||
s->dev.speed = USB_SPEED_FULL;
|
|
||||||
s->dev.klass.handle_attach = usb_desc_attach;
|
|
||||||
s->dev.klass.handle_reset = usb_hid_handle_reset;
|
|
||||||
s->dev.klass.handle_control = usb_hid_handle_control;
|
|
||||||
s->dev.klass.handle_data = usb_hid_handle_data;
|
|
||||||
s->dev.klass.unrealize = usb_hid_unrealize;
|
|
||||||
s->dev.klass.usb_desc = &s->desc;
|
|
||||||
s->dev.klass.product_desc = s->desc.str[2];
|
|
||||||
|
|
||||||
usb_desc_init(&s->dev);
|
|
||||||
usb_ep_init(&s->dev);
|
|
||||||
s->intr = usb_ep_get(&s->dev, USB_TOKEN_IN, 1);
|
|
||||||
hid_init(&s->hid, HID_KEYBOARD, usb_hid_changed);
|
|
||||||
s->hid.sub_kind = HID_SUBKIND_BEATMANIA;
|
|
||||||
|
|
||||||
usb_hid_handle_reset(&s->dev);
|
|
||||||
|
|
||||||
s->SetKeycodeMapping();
|
|
||||||
|
|
||||||
return &s->dev;
|
|
||||||
fail:
|
|
||||||
usb_hid_unrealize(&s->dev);
|
|
||||||
return nullptr;
|
|
||||||
}
|
|
||||||
|
|
||||||
const char* BeatManiaDevice::Name() const
|
|
||||||
{
|
|
||||||
return TRANSLATE_NOOP("USB", "Konami Keyboard");
|
|
||||||
}
|
|
||||||
|
|
||||||
const char* BeatManiaDevice::TypeName() const
|
|
||||||
{
|
|
||||||
return "beatmania";
|
|
||||||
}
|
|
||||||
|
|
||||||
bool BeatManiaDevice::Freeze(USBDevice* dev, StateWrapper& sw) const
|
|
||||||
{
|
|
||||||
return HIDKbdDevice::Freeze(dev, sw);
|
|
||||||
}
|
|
||||||
|
|
||||||
} // namespace usb_hid
|
} // namespace usb_hid
|
||||||
|
|
|
@ -31,14 +31,4 @@ namespace usb_hid
|
||||||
USBDevice* CreateDevice(SettingsInterface& si, u32 port, u32 subtype) const override;
|
USBDevice* CreateDevice(SettingsInterface& si, u32 port, u32 subtype) const override;
|
||||||
bool Freeze(USBDevice* dev, StateWrapper& sw) const override;
|
bool Freeze(USBDevice* dev, StateWrapper& sw) const override;
|
||||||
};
|
};
|
||||||
|
|
||||||
class BeatManiaDevice final : public HIDKbdDevice
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
const char* Name() const override;
|
|
||||||
const char* TypeName() const override;
|
|
||||||
USBDevice* CreateDevice(SettingsInterface& si, u32 port, u32 subtype) const override;
|
|
||||||
bool Freeze(USBDevice* dev, StateWrapper& sw) const override;
|
|
||||||
};
|
|
||||||
|
|
||||||
} // namespace usb_hid
|
} // namespace usb_hid
|
||||||
|
|
Loading…
Reference in New Issue