usb: hso: remove bogus check for EINPROGRESS
authorOliver Neukum <oneukum@suse.com>
Wed, 5 Aug 2020 12:07:09 +0000 (14:07 +0200)
committerDavid S. Miller <davem@davemloft.net>
Thu, 6 Aug 2020 00:43:39 +0000 (17:43 -0700)
This check an inherent race. It opens a race where
an error code has already been set or cleared yet
the URB has not been given back. We cannot do
such an optimization and must unlink unconditionally.

Signed-off-by: Oliver Neukum <oneukum@suse.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
drivers/net/usb/hso.c

index 5762876..2bb28db 100644 (file)
@@ -831,8 +831,7 @@ static void hso_net_tx_timeout(struct net_device *net, unsigned int txqueue)
        dev_warn(&net->dev, "Tx timed out.\n");
 
        /* Tear the waiting frame off the list */
-       if (odev->mux_bulk_tx_urb &&
-           (odev->mux_bulk_tx_urb->status == -EINPROGRESS))
+       if (odev->mux_bulk_tx_urb)
                usb_unlink_urb(odev->mux_bulk_tx_urb);
 
        /* Update statistics */