Hi Oliver,

I will get to testing this and get back to you with the results asap.

I expect that this will work as I have seen it implemented this way
before.

Thanks,
 -Kevin
-----Original Message-----
From: Oliver Neukum [mailto:[EMAIL PROTECTED] 
Sent: Wednesday, January 30, 2008 3:22 AM
To: Linux Development Group; linux-usb@vger.kernel.org
Subject: some fixes of the sierra driver

Hi,

while I was adding autosuspend to that driver I noticed a few
issues. You were having DMAed buffers as a part of a structure.
This will fail on platforms that are not DMA-coherent (arm, sparc, ppc,
...)
Please test this patch to fix it.

        Regards
                Oliver

----

--- linux-2.6.24-sierra/drivers/usb/serial/sierra.c.alt2
2008-01-30 12:03:57.000000000 +0100
+++ linux-2.6.24-sierra/drivers/usb/serial/sierra.c     2008-01-30
12:11:39.000000000 +0100
@@ -56,9 +56,9 @@ struct sierra_port_private {
        int outstanding_urbs;   /* number of out urbs in flight */
        struct usb_anchor transmit_urbs;
 
-       /* Input endpoints and buffer for this port */
+       /* Input endpoints and buffers for this port */
        struct urb *in_urbs[N_IN_URB];
-       char in_buffer[N_IN_URB][IN_BUFLEN];
+       char *in_buffer[N_IN_URB];
 
        /* Settings for the port */
        int rts_state;  /* Handshaking pins (outputs) */
@@ -714,6 +714,15 @@ static int sierra_startup(struct usb_ser
                }
                spin_lock_init(&portdata->lock);
                init_usb_anchor(&portdata->transmit_urbs);
+               for (j = 0; j < N_IN_URB; j++) {
+                       portdata->in_buffer[j] = kmalloc(IN_BUFLEN,
GFP_KERNEL);
+                       if (!portdata->in_buffer[j]) {
+                               for ( --j; j >= 0; j--)
+                                       kfree(portdata->in_buffer[j]);
+                               kfree(portdata);
+                               return -ENOMEM;
+                       } 
+               }
 
                usb_set_serial_port_data(port, portdata);
 
@@ -757,7 +766,7 @@ static void sierra_shutdown(struct usb_s
                for (j = 0; j < N_IN_URB; j++) {
                        usb_kill_urb(portdata->in_urbs[j]);
                        usb_free_urb(portdata->in_urbs[j]);
-                       portdata->in_urbs[j] = NULL;
+                       kfree(portdata->in_buffer[j]);
                }
                kfree(portdata);
                usb_set_serial_port_data(port, NULL);

-
To unsubscribe from this list: send the line "unsubscribe linux-usb" in
the body of a message to [EMAIL PROTECTED]
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to