[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <4E03198A.2060600@ru.mvista.com>
Date: Thu, 23 Jun 2011 14:46:34 +0400
From: Sergei Shtylyov <sshtylyov@...sta.com>
To: "Marius B. Kotsbak" <marius.kotsbak@...il.com>
CC: davem@...emloft.net, netdev@...r.kernel.org,
linux-usb@...r.kernel.org, "Marius B. Kotsbak" <marius@...sbak.com>
Subject: Re: [PATCH] net/usb: kalmia: Various fixes for better support of
non-x86 architectures.
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@...sbak.com>
> ---
> drivers/net/usb/kalmia.c | 40 ++++++++++++++++++++++++----------------
> 1 files changed, 24 insertions(+), 16 deletions(-)
> diff --git a/drivers/net/usb/kalmia.c b/drivers/net/usb/kalmia.c
> index d965fb1..d4edeb2 100644
> --- a/drivers/net/usb/kalmia.c
> +++ b/drivers/net/usb/kalmia.c
> @@ -100,27 +100,35 @@ kalmia_send_init_packet(struct usbnet *dev, u8 *init_msg, u8 init_msg_len,
> static int
> kalmia_init_and_get_ethernet_addr(struct usbnet *dev, u8 *ethernet_addr)
> {
> - char init_msg_1[] =
> + const static char init_msg_1[] =
> { 0x57, 0x50, 0x04, 0x00, 0x00, 0x00, 0x00, 0x20, 0x00, 0x00,
> 0x00, 0x00 };
> - char init_msg_2[] =
> + const static char init_msg_2[] =
> { 0x57, 0x50, 0x04, 0x00, 0x00, 0x00, 0x00, 0x02, 0x00, 0xf4,
> 0x00, 0x00 };
Actually 'const' alone should've been enough for the variable to be placed
in the data section ISO stack.
> - 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])
WBR, Sergei
--
To unsubscribe from this list: send the line "unsubscribe netdev" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Powered by blists - more mailing lists