usb-storage: cancel I/O on reset
When resetting the usb-storage device we'll have to carefully cancel and clear any requests which might be in flight, otherwise we'll confuse the state machine. Signed-off-by: Gerd Hoffmann <kraxel@redhat.com>
This commit is contained in:
parent
7279a85f37
commit
24a5bbe1c8
12
hw/usb-msd.c
12
hw/usb-msd.c
@ -278,6 +278,18 @@ static void usb_msd_handle_reset(USBDevice *dev)
|
|||||||
MSDState *s = (MSDState *)dev;
|
MSDState *s = (MSDState *)dev;
|
||||||
|
|
||||||
DPRINTF("Reset\n");
|
DPRINTF("Reset\n");
|
||||||
|
if (s->req) {
|
||||||
|
scsi_req_cancel(s->req);
|
||||||
|
}
|
||||||
|
assert(s->req == NULL);
|
||||||
|
|
||||||
|
if (s->packet) {
|
||||||
|
USBPacket *p = s->packet;
|
||||||
|
s->packet = NULL;
|
||||||
|
p->result = USB_RET_STALL;
|
||||||
|
usb_packet_complete(dev, p);
|
||||||
|
}
|
||||||
|
|
||||||
s->mode = USB_MSDM_CBW;
|
s->mode = USB_MSDM_CBW;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user