summaryrefslogtreecommitdiff
path: root/drivers
diff options
context:
space:
mode:
authorFoster Snowhill <forst@pen.gy>2024-08-06 19:28:07 +0200
committerDavid S. Miller <davem@davemloft.net>2024-08-09 13:54:20 +0100
commit94d7eeb6c0ef0310992944f0d0296929816a2cb0 (patch)
tree0b709b0ed9772b9f25182d78ef521b2694707cdf /drivers
parent655b46d7a39ac6f049698b27c1568c0f7ff85d1e (diff)
downloadlinux-94d7eeb6c0ef0310992944f0d0296929816a2cb0.tar.gz
linux-94d7eeb6c0ef0310992944f0d0296929816a2cb0.tar.bz2
linux-94d7eeb6c0ef0310992944f0d0296929816a2cb0.zip
usbnet: ipheth: drop RX URBs with no payload
On iPhone 15 Pro Max one can observe periodic URBs with no payload on the "bulk in" (RX) endpoint. These don't seem to do anything meaningful. Reproduced on iOS 17.5.1 and 17.6. This behaviour isn't observed on iPhone 11 on the same iOS version. The nature of these zero-length URBs is so far unknown. Drop RX URBs with no payload. Signed-off-by: Foster Snowhill <forst@pen.gy> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/net/usb/ipheth.c6
1 files changed, 6 insertions, 0 deletions
diff --git a/drivers/net/usb/ipheth.c b/drivers/net/usb/ipheth.c
index 017255615508..f04c7bf79665 100644
--- a/drivers/net/usb/ipheth.c
+++ b/drivers/net/usb/ipheth.c
@@ -286,6 +286,12 @@ static void ipheth_rcvbulk_callback(struct urb *urb)
return;
}
+ /* iPhone may periodically send URBs with no payload
+ * on the "bulk in" endpoint. It is safe to ignore them.
+ */
+ if (urb->actual_length == 0)
+ goto rx_submit;
+
/* RX URBs starting with 0x00 0x01 do not encapsulate Ethernet frames,
* but rather are control frames. Their purpose is not documented, and
* they don't affect driver functionality, okay to drop them.