• H
    usb: split packet result into actual_length + status · 9a77a0f5
    Hans de Goede 提交于
    Since with the ehci and xhci controllers a single packet can be larger
    then maxpacketsize, it is possible for the result of a single packet
    to be both having transferred some data as well as the transfer to have
    an error.
    
    An example would be an input transfer from a bulk endpoint successfully
    receiving 1 or more maxpacketsize packets from the device, followed
    by a packet signalling halt.
    
    While already touching all the devices and controllers handle_packet /
    handle_data / handle_control code, also change the return type of
    these functions to void, solely storing the status in the packet. To
    make the code paths for regular versus async packet handling more
    uniform.
    
    This patch unfortunately is somewhat invasive, since makeing the qemu
    usb core deal with this requires changes everywhere. This patch only
    prepares the usb core for this, all the hcd / device changes are done
    in such a way that there are no functional changes.
    
    This patch has been tested with uhci and ehci hcds, together with usb-audio,
    usb-hid and usb-storage devices, as well as with usb-redir redirection
    with a wide variety of real devices.
    
    Note that there is usually no need to directly set packet->actual_length
    form devices handle_data callback, as that is done by usb_packet_copy()
    Signed-off-by: NHans de Goede <hdegoede@redhat.com>
    Signed-off-by: NGerd Hoffmann <kraxel@redhat.com>
    9a77a0f5
dev-network.c 43.4 KB