Re: [PATCH] net/usb: kalmia: Various fixes for better support of non-x86 architectures.

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Den 23. juni 2011 12:46, skrev Sergei Shtylyov:
Hello.

On 22-06-2011 19:26, Marius B. Kotsbak wrote:

-Support for big endian.
-Do not use USB buffers at the stack.
-Safer/more efficient code for local constants.

Signed-off-by: Marius B. Kotsbak<marius@xxxxxxxxxxx>
---
drivers/net/usb/kalmia.c | 40 ++++++++++++++++++++++++----------------
  1 files changed, 24 insertions(+), 16 deletions(-)


-    char receive_buf[28];
+    const static int buflen = 28;

   Why declare it at all, when it's used only once?

+    char *usb_buf;
      int status;

- status = kalmia_send_init_packet(dev, init_msg_1, sizeof(init_msg_1)
-        / sizeof(init_msg_1[0]), receive_buf, 24);
+    usb_buf = kmalloc(buflen, GFP_DMA | GFP_KERNEL);
+    if (!usb_buf)
+        return -ENOMEM;
+
+    memcpy(usb_buf, init_msg_1, 12);

   s/12/sizeof(init_msg_1)/

+    status = kalmia_send_init_packet(dev, usb_buf, sizeof(init_msg_1)
+        / sizeof(init_msg_1[0]), usb_buf, 24);

   There's ARRAY_SIZE() macro to replace:

sizeof(init_msg_1) / sizeof(init_msg_1[0])

   and why not use just sizeof(init_msg_1)?

      if (status != 0)
          return status;

- status = kalmia_send_init_packet(dev, init_msg_2, sizeof(init_msg_2)
-        / sizeof(init_msg_2[0]), receive_buf, 28);
+    memcpy(usb_buf, init_msg_2, 12);

   s/12/sizeof(init_msg_2)/

+    status = kalmia_send_init_packet(dev, usb_buf, sizeof(init_msg_2)
+        / sizeof(init_msg_2[0]), usb_buf, 28);

   The same comment here about:

sizeof(init_msg_2) / sizeof(init_msg_2[0])


Thanks for the tips. I know some parts of the code are a bit ugly, but the primary goal was to get it working despite the quirky state of the current modem firmware. I have noted it for later fixing.

--
Marius

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


[Index of Archives]     [Linux Media]     [Linux Input]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]     [Old Linux USB Devel Archive]

  Powered by Linux