diff options
author | Gerd Hoffmann <kraxel@redhat.com> | 2012-04-18 12:08:29 +0200 |
---|---|---|
committer | Gerd Hoffmann <kraxel@redhat.com> | 2012-04-26 12:21:16 +0200 |
commit | 6d7aeeeb8985634a2015e804045a1ca52573ccc5 (patch) | |
tree | 37a839e19ab8af7dd3b7c7e4cd6dd6b49573ed99 /hw/xilinx_axidma.h | |
parent | 8a771f77e2abfb81f1f33a986810c16ecae54ca7 (diff) |
usb-storage: fix request canceling
Little fix for usb packet handling on i/o cancelation. The
usb packet pointer (s->packet) is cleared at the wrong place:
The scsi request cancel handler does it. When a usb packet
is canceled the usb-storage emulation canceles the scsi request
if present. In most cases there is one, so usually s->packet
is cleared as needed even with the code sitting at the wrong
place.
If there is no scsi request in flight s->packet is not cleared
though. The usb-storage emulation will then try to complete an
usb packet which is not in flight any more and thereby trigger
an assert() in the usb core.
Fix this by clearing s->packet at the correct place, which is
the usb packet cancel header.
Signed-off-by: Gerd Hoffmann <kraxel@redhat.com>
Diffstat (limited to 'hw/xilinx_axidma.h')
0 files changed, 0 insertions, 0 deletions