usb-ehci: Ensure frindex writes leave a valid frindex value
frindex is a 14 bits counter, so bits 31-14 should always be 0, and after the commit titled "usb-ehci: frindex always is a 14 bits counter" we rely on frindex always being a multiple of 8. I've not seen this in practice, but theoretically a guest can write a value >= 0x4000 or a value which is not a multiple of 8 value to frindex, this patch ensures that things will still work when that happens. Signed-off-by: Hans de Goede <hdegoede@redhat.com> Signed-off-by: Gerd Hoffmann <kraxel@redhat.com>
This commit is contained in:
parent
0cc6a0f19e
commit
8a771f77e2
@ -1101,6 +1101,10 @@ static void ehci_mem_writel(void *ptr, target_phys_addr_t addr, uint32_t val)
|
|||||||
val &= USBINTR_MASK;
|
val &= USBINTR_MASK;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case FRINDEX:
|
||||||
|
val &= 0x00003ff8; /* frindex is 14bits and always a multiple of 8 */
|
||||||
|
break;
|
||||||
|
|
||||||
case CONFIGFLAG:
|
case CONFIGFLAG:
|
||||||
val &= 0x1;
|
val &= 0x1;
|
||||||
if (val) {
|
if (val) {
|
||||||
|
Loading…
Reference in New Issue
Block a user