]> git.karo-electronics.de Git - mv-sheeva.git/blobdiff - drivers/net/usb/hso.c
Merge tag 'v2.6.38' of git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux-2.6
[mv-sheeva.git] / drivers / net / usb / hso.c
index 812edf85d6d32b017454f449f4d03e300ed4ec50..6d83812603b6b92fe02c2d06f43956a6a24df050 100644 (file)
@@ -997,6 +997,18 @@ static void packetizeRx(struct hso_net *odev, unsigned char *ip_pkt,
        }
 }
 
+static void fix_crc_bug(struct urb *urb, __le16 max_packet_size)
+{
+       static const u8 crc_check[4] = { 0xDE, 0xAD, 0xBE, 0xEF };
+       u32 rest = urb->actual_length % le16_to_cpu(max_packet_size);
+
+       if (((rest == 5) || (rest == 6)) &&
+           !memcmp(((u8 *)urb->transfer_buffer) + urb->actual_length - 4,
+                   crc_check, 4)) {
+               urb->actual_length -= 4;
+       }
+}
+
 /* Moving data from usb to kernel (in interrupt state) */
 static void read_bulk_callback(struct urb *urb)
 {
@@ -1025,17 +1037,8 @@ static void read_bulk_callback(struct urb *urb)
                return;
        }
 
-       if (odev->parent->port_spec & HSO_INFO_CRC_BUG) {
-               u32 rest;
-               u8 crc_check[4] = { 0xDE, 0xAD, 0xBE, 0xEF };
-               rest = urb->actual_length %
-                       le16_to_cpu(odev->in_endp->wMaxPacketSize);
-               if (((rest == 5) || (rest == 6)) &&
-                   !memcmp(((u8 *) urb->transfer_buffer) +
-                           urb->actual_length - 4, crc_check, 4)) {
-                       urb->actual_length -= 4;
-               }
-       }
+       if (odev->parent->port_spec & HSO_INFO_CRC_BUG)
+               fix_crc_bug(urb, odev->in_endp->wMaxPacketSize);
 
        /* do we even have a packet? */
        if (urb->actual_length) {
@@ -1227,18 +1230,8 @@ static void hso_std_serial_read_bulk_callback(struct urb *urb)
                return;
 
        if (status == 0) {
-               if (serial->parent->port_spec & HSO_INFO_CRC_BUG) {
-                       u32 rest;
-                       u8 crc_check[4] = { 0xDE, 0xAD, 0xBE, 0xEF };
-                       rest =
-                           urb->actual_length %
-                           le16_to_cpu(serial->in_endp->wMaxPacketSize);
-                       if (((rest == 5) || (rest == 6)) &&
-                           !memcmp(((u8 *) urb->transfer_buffer) +
-                                   urb->actual_length - 4, crc_check, 4)) {
-                               urb->actual_length -= 4;
-                       }
-               }
+               if (serial->parent->port_spec & HSO_INFO_CRC_BUG)
+                       fix_crc_bug(urb, serial->in_endp->wMaxPacketSize);
                /* Valid data, handle RX data */
                spin_lock(&serial->serial_lock);
                serial->rx_urb_filled[hso_urb_to_index(serial, urb)] = 1;
@@ -1741,7 +1734,6 @@ static int hso_serial_ioctl(struct tty_struct *tty, struct file *file,
                            unsigned int cmd, unsigned long arg)
 {
        struct hso_serial *serial =  get_serial_by_tty(tty);
-       void __user *uarg = (void __user *)arg;
        int ret = 0;
        D4("IOCTL cmd: %d, arg: %ld", cmd, arg);
 
@@ -2636,15 +2628,15 @@ exit:
 
 static void hso_free_tiomget(struct hso_serial *serial)
 {
-       struct hso_tiocmget *tiocmget = serial->tiocmget;
+       struct hso_tiocmget *tiocmget;
+       if (!serial)
+               return;
+       tiocmget = serial->tiocmget;
        if (tiocmget) {
-               if (tiocmget->urb) {
-                       usb_free_urb(tiocmget->urb);
-                       tiocmget->urb = NULL;
-               }
+               usb_free_urb(tiocmget->urb);
+               tiocmget->urb = NULL;
                serial->tiocmget = NULL;
                kfree(tiocmget);
-
        }
 }