mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-05 08:43:55 -06:00
adb: fix adb-mouse read length and revert disable-reg3-direct-writes workaround
Commit 84051eb400
"adb: add property to disable direct reg 3 writes" introduced
a workaround for spurious writes to ADB register 3 when MacOS 9 enables
autopoll on the mouse device. Further analysis shows that the problem is that
only a partial request is sent, and since the len parameter is ignored then
stale data from the previous request is used causing the incorrect address
assignment.
Remove the disable-reg3-direct-writes workaround and instead check the length
parameter when the write is attempted, discarding the invalid request.
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk>
Tested-by: Finn Thain <fthain@telegraphics.com.au>
Acked-by: Laurent Vivier <laurent@vivier.eu>
Message-Id: <20200623204936.24064-3-mark.cave-ayland@ilande.co.uk>
This commit is contained in:
parent
bcaaefdbb2
commit
167f1667b1
5 changed files with 40 additions and 44 deletions
|
@ -259,21 +259,19 @@ static int adb_kbd_request(ADBDevice *d, uint8_t *obuf,
|
|||
trace_adb_kbd_request_change_addr(d->devaddr);
|
||||
break;
|
||||
default:
|
||||
if (!d->disable_direct_reg3_writes) {
|
||||
d->devaddr = buf[1] & 0xf;
|
||||
|
||||
/* we support handlers:
|
||||
* 1: Apple Standard Keyboard
|
||||
* 2: Apple Extended Keyboard (LShift = RShift)
|
||||
* 3: Apple Extended Keyboard (LShift != RShift)
|
||||
*/
|
||||
if (buf[2] == 1 || buf[2] == 2 || buf[2] == 3) {
|
||||
d->handler = buf[2];
|
||||
}
|
||||
|
||||
trace_adb_kbd_request_change_addr_and_handler(d->devaddr,
|
||||
d->handler);
|
||||
d->devaddr = buf[1] & 0xf;
|
||||
/*
|
||||
* we support handlers:
|
||||
* 1: Apple Standard Keyboard
|
||||
* 2: Apple Extended Keyboard (LShift = RShift)
|
||||
* 3: Apple Extended Keyboard (LShift != RShift)
|
||||
*/
|
||||
if (buf[2] == 1 || buf[2] == 2 || buf[2] == 3) {
|
||||
d->handler = buf[2];
|
||||
}
|
||||
|
||||
trace_adb_kbd_request_change_addr_and_handler(d->devaddr,
|
||||
d->handler);
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue