OSDN Git Service

usb-storage: fix SYNCHRONIZE_CACHE
authorGerd Hoffmann <kraxel@redhat.com>
Fri, 13 Jul 2012 09:38:13 +0000 (11:38 +0200)
committerGerd Hoffmann <kraxel@redhat.com>
Tue, 7 Aug 2012 08:49:06 +0000 (10:49 +0200)
Commit 59310659073d85745854f2f10c4292555c5a1c51 is incomplete,
we'll arrive in the scsi command complete callback in CSW state
and must handle that case correctly.

Signed-off-by: Gerd Hoffmann <kraxel@redhat.com>
hw/usb/dev-storage.c

index 976fe1a..ff48d91 100644 (file)
@@ -247,6 +247,9 @@ static void usb_msd_command_complete(SCSIRequest *req, uint32_t status, size_t r
                the status read packet.  */
             usb_msd_send_status(s, p);
             s->mode = USB_MSDM_CBW;
+        } else if (s->mode == USB_MSDM_CSW) {
+            usb_msd_send_status(s, p);
+            s->mode = USB_MSDM_CBW;
         } else {
             if (s->data_len) {
                 int len = (p->iov.size - p->result);