aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net/usb/usbnet.c
diff options
context:
space:
mode:
authorElina Pasheva <epasheva@sierrawireless.com>2010-04-06 10:23:07 -0400
committerDavid S. Miller <davem@davemloft.net>2010-04-06 22:50:22 -0400
commitb4d562e3c3553ac58c7120555c4e4aefbb090a2a (patch)
tree57399d164d3882f0f19080c0cd0014d039af6109 /drivers/net/usb/usbnet.c
parent17a328ca8c04cf88be9a9ef1cb74f359c59f1802 (diff)
NET: usb: Adding URB_ZERO_PACKET flag to usbnet.c
This patch adds setting of the urb transfer flag URB_ZERO_PACKET before submitting an urb for drivers that have requested it (by advertising flag FLAG_SEND_ZLP). The modification is in usbnet.c function usbnet_start_xmit(). This patch only adds the zero length flag. A subsequent patch will address the buggy code we found when devices do not advertise FLAG_SEND_ZLP in which case there is a possibility of transferring packets with non-deterministic length. This patch has been tested on kernel-2.6.34-rc3. This patch has been checked against net-2.6 tree. Signed-off-by: Elina Pasheva <epasheva@sierrawireless.com> Signed-off-by: Rory Filer <rfiler@sierrawireless.com> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'drivers/net/usb/usbnet.c')
-rw-r--r--drivers/net/usb/usbnet.c15
1 files changed, 9 insertions, 6 deletions
diff --git a/drivers/net/usb/usbnet.c b/drivers/net/usb/usbnet.c
index 17b6a62d206e..c0f64392627c 100644
--- a/drivers/net/usb/usbnet.c
+++ b/drivers/net/usb/usbnet.c
@@ -1068,12 +1068,15 @@ netdev_tx_t usbnet_start_xmit (struct sk_buff *skb,
1068 * NOTE: strictly conforming cdc-ether devices should expect 1068 * NOTE: strictly conforming cdc-ether devices should expect
1069 * the ZLP here, but ignore the one-byte packet. 1069 * the ZLP here, but ignore the one-byte packet.
1070 */ 1070 */
1071 if (!(info->flags & FLAG_SEND_ZLP) && (length % dev->maxpacket) == 0) { 1071 if (length % dev->maxpacket == 0) {
1072 urb->transfer_buffer_length++; 1072 if (!(info->flags & FLAG_SEND_ZLP)) {
1073 if (skb_tailroom(skb)) { 1073 urb->transfer_buffer_length++;
1074 skb->data[skb->len] = 0; 1074 if (skb_tailroom(skb)) {
1075 __skb_put(skb, 1); 1075 skb->data[skb->len] = 0;
1076 } 1076 __skb_put(skb, 1);
1077 }
1078 } else
1079 urb->transfer_flags |= URB_ZERO_PACKET;
1077 } 1080 }
1078 1081
1079 spin_lock_irqsave(&dev->txq.lock, flags); 1082 spin_lock_irqsave(&dev->txq.lock, flags);