zd1211rw: remove URB_SHORT_NOT_OK flag in zd_usb_iowrite16v_async()

Patch removes the bogus flag introduced by upstream commit
eefdbec1ea8b7093d2c09d1825f68438701723cf. Old code had buffer length check
that new code tried to handle with URB_SHORT_NOT_OK flag. With USB debugging
enabled bogus flag caused usb_submit_urb fail.

Remove URB_SHORT_NOT_OK flag and add buffer length check to urb completion
handler.

Bugzilla: https://bugzilla.kernel.org/show_bug.cgi?id=32092
Reported-by: Jonathan Callen <abcd@gentoo.org>
Signed-off-by: Jussi Kivilinna <jussi.kivilinna@mbnet.fi>
Signed-off-by: John W. Linville <linville@tuxdriver.com>

authored by Jussi Kivilinna and committed by John W. Linville 2fc713b2 fcf8bd3b

+5 -1
+5 -1
drivers/net/wireless/zd1211rw/zd_usb.c
··· 1671 1671 1672 1672 if (urb->status && !usb->cmd_error) 1673 1673 usb->cmd_error = urb->status; 1674 + 1675 + if (!usb->cmd_error && 1676 + urb->actual_length != urb->transfer_buffer_length) 1677 + usb->cmd_error = -EIO; 1674 1678 } 1675 1679 1676 1680 static int zd_submit_waiting_urb(struct zd_usb *usb, bool last) ··· 1809 1805 usb_fill_int_urb(urb, udev, usb_sndintpipe(udev, EP_REGS_OUT), 1810 1806 req, req_len, iowrite16v_urb_complete, usb, 1811 1807 ep->desc.bInterval); 1812 - urb->transfer_flags |= URB_FREE_BUFFER | URB_SHORT_NOT_OK; 1808 + urb->transfer_flags |= URB_FREE_BUFFER; 1813 1809 1814 1810 /* Submit previous URB */ 1815 1811 r = zd_submit_waiting_urb(usb, false);