adb_usb: Fix Apple Classic/Extended Mouse support
This commit is contained in:
parent
011fb9e731
commit
3a6fe4069d
1 changed files with 23 additions and 24 deletions
|
|
@ -296,7 +296,7 @@ again:
|
||||||
// set pseudo handler
|
// set pseudo handler
|
||||||
mouse_handler = ADB_HANDLER_LOGITECH_EXT;
|
mouse_handler = ADB_HANDLER_LOGITECH_EXT;
|
||||||
} else {
|
} else {
|
||||||
dmprintf("Unknown\n");
|
dmprintf("Extended\n");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -391,18 +391,6 @@ void adb_mouse_task(void)
|
||||||
mouse_init();
|
mouse_init();
|
||||||
}
|
}
|
||||||
|
|
||||||
// Extended Mouse Protocol data can be 2-5 bytes
|
|
||||||
// https://developer.apple.com/library/archive/technotes/hw/hw_01.html#Extended
|
|
||||||
//
|
|
||||||
// Byte 0: b00 y06 y05 y04 y03 y02 y01 y00
|
|
||||||
// Byte 1: b01 x06 x05 x04 x03 x02 x01 x00
|
|
||||||
// Byte 2: b02 y09 y08 y07 b03 x09 x08 x07
|
|
||||||
// Byte 3: b04 y12 y11 y10 b05 x12 x11 x10
|
|
||||||
// Byte 4: b06 y15 y14 y13 b07 x15 x14 x13
|
|
||||||
//
|
|
||||||
// b--: Button state.(0: on, 1: off)
|
|
||||||
// x--: X axis movement.
|
|
||||||
// y--: Y axis movement.
|
|
||||||
len = adb_host_talk_buf(ADB_ADDR_MOUSE_POLL, ADB_REG_0, buf, sizeof(buf));
|
len = adb_host_talk_buf(ADB_ADDR_MOUSE_POLL, ADB_REG_0, buf, sizeof(buf));
|
||||||
|
|
||||||
// If nothing received reset mouse acceleration, and quit.
|
// If nothing received reset mouse acceleration, and quit.
|
||||||
|
|
@ -416,13 +404,9 @@ void adb_mouse_task(void)
|
||||||
xprintf("%02X ", buf[i]);
|
xprintf("%02X ", buf[i]);
|
||||||
xprintf("] mh:%02X\n", mouse_handler);
|
xprintf("] mh:%02X\n", mouse_handler);
|
||||||
|
|
||||||
// Store off-buttons and 0-movements in unused bytes
|
|
||||||
bool xneg = false;
|
bool xneg = false;
|
||||||
bool yneg = false;
|
bool yneg = false;
|
||||||
if (len == 2) {
|
if (mouse_handler == ADB_HANDLER_LOGITECH) {
|
||||||
if (buf[0] & 0x40) yneg = true;
|
|
||||||
if (buf[1] & 0x40) xneg = true;
|
|
||||||
} else if (mouse_handler == ADB_HANDLER_LOGITECH) {
|
|
||||||
// Logitech:
|
// Logitech:
|
||||||
// Byte0: bbb y06 y05 y04 y03 y02 y01 y00
|
// Byte0: bbb y06 y05 y04 y03 y02 y01 y00
|
||||||
// Byte1: 1 x06 x05 x04 x03 x02 x01 x00
|
// Byte1: 1 x06 x05 x04 x03 x02 x01 x00
|
||||||
|
|
@ -503,9 +487,26 @@ void adb_mouse_task(void)
|
||||||
buf[1] = ((buf[2] & 4) << 5) | (buf[1] & 0x7F) ;
|
buf[1] = ((buf[2] & 4) << 5) | (buf[1] & 0x7F) ;
|
||||||
buf[2] = ((buf[2] & 2) << 6) | (yneg ? 0x70 : 0x00) | (xneg ? 0x0F : 0x08);
|
buf[2] = ((buf[2] & 2) << 6) | (yneg ? 0x70 : 0x00) | (xneg ? 0x0F : 0x08);
|
||||||
len = 3;
|
len = 3;
|
||||||
} else {
|
} else if (mouse_handler == ADB_HANDLER_EXTENDED_MOUSE ||
|
||||||
|
mouse_handler == ADB_HANDLER_TURBO_MOUSE) {
|
||||||
|
// Apple Extended Mouse:
|
||||||
|
// Byte0: b00 y06 y05 y04 y03 y02 y01 y00
|
||||||
|
// Byte1: b01 x06 x05 x04 x03 x02 x01 x00
|
||||||
|
// Byte2: b02 y09 y08 y07 b03 x09 x08 x07
|
||||||
|
// Byte3: b04 y12 y11 y10 b05 x12 x11 x10
|
||||||
|
// Byte4: b06 y15 y14 y13 b07 x15 x14 x13
|
||||||
|
// b--: button state(0:pressed, 1:released)
|
||||||
|
// Data can be 2-5 bytes.
|
||||||
|
// L=b00, R=b01, M=b02
|
||||||
if (buf[len - 1] & 0x40) yneg = true;
|
if (buf[len - 1] & 0x40) yneg = true;
|
||||||
if (buf[len - 1] & 0x04) xneg = true;
|
if (buf[len - 1] & 0x04) xneg = true;
|
||||||
|
} else {
|
||||||
|
// Apple Classic Mouse and Unknown devices:
|
||||||
|
// Byte0: b00 y06 y05 y04 y03 y02 y01 y00
|
||||||
|
// Byte1: b01 x06 x05 x04 x03 x02 x01 x00
|
||||||
|
if (buf[0] & 0x40) yneg = true;
|
||||||
|
if (buf[1] & 0x40) xneg = true;
|
||||||
|
len = 2;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Make unused buf bytes compatible with Extended Mouse Protocol
|
// Make unused buf bytes compatible with Extended Mouse Protocol
|
||||||
|
|
@ -520,17 +521,15 @@ void adb_mouse_task(void)
|
||||||
xprintf("%02X ", buf[i]);
|
xprintf("%02X ", buf[i]);
|
||||||
xprintf("]\n");
|
xprintf("]\n");
|
||||||
|
|
||||||
// 8 buttons at max
|
|
||||||
// TODO: Fix HID report descriptor for mouse to support button6-8
|
|
||||||
uint8_t buttons = 0;
|
uint8_t buttons = 0;
|
||||||
if (!(buf[4] & 0x08)) buttons |= MOUSE_BTN8;
|
if (!(buf[4] & 0x08)) buttons |= MOUSE_BTN8;
|
||||||
if (!(buf[4] & 0x80)) buttons |= MOUSE_BTN7;
|
if (!(buf[4] & 0x80)) buttons |= MOUSE_BTN7;
|
||||||
if (!(buf[3] & 0x08)) buttons |= MOUSE_BTN6;
|
if (!(buf[3] & 0x08)) buttons |= MOUSE_BTN6;
|
||||||
if (!(buf[3] & 0x80)) buttons |= MOUSE_BTN5;
|
if (!(buf[3] & 0x80)) buttons |= MOUSE_BTN5;
|
||||||
if (!(buf[2] & 0x08)) buttons |= MOUSE_BTN4;
|
if (!(buf[2] & 0x08)) buttons |= MOUSE_BTN4;
|
||||||
if (!(buf[2] & 0x80)) buttons |= MOUSE_BTN3;
|
if (!(buf[2] & 0x80)) buttons |= MOUSE_BTN3; // Middle
|
||||||
if (!(buf[1] & 0x80)) buttons |= MOUSE_BTN2;
|
if (!(buf[1] & 0x80)) buttons |= MOUSE_BTN2; // Right
|
||||||
if (!(buf[0] & 0x80)) buttons |= MOUSE_BTN1;
|
if (!(buf[0] & 0x80)) buttons |= MOUSE_BTN1; // Left
|
||||||
|
|
||||||
// check if the scroll enable button is pressed
|
// check if the scroll enable button is pressed
|
||||||
bool scroll_enable = (bool)(buttons & scroll_button_mask);
|
bool scroll_enable = (bool)(buttons & scroll_button_mask);
|
||||||
|
|
|
||||||
Loading…
Add table
Reference in a new issue