All of lore.kernel.org
 help / color / mirror / Atom feed
* [PATCH] rtlwifi: fix incorrect use of usb_alloc_coherent with usb_control_msg
@ 2012-12-20 14:24 Jussi Kivilinna
  2012-12-20 18:00 ` Larry Finger
  0 siblings, 1 reply; 2+ messages in thread
From: Jussi Kivilinna @ 2012-12-20 14:24 UTC (permalink / raw)
  To: linux-wireless; +Cc: Chaoming Li, John W. Linville, stable, Larry Finger

Incorrect use of usb_alloc_coherent memory as input buffer to usb_control_msg
can cause problems in arch DMA code, for example kernel BUG at
'arch/arm/include/asm/dma-mapping.h:321' on ARM (linux-3.4).

Change _usb_writeN_sync use kmalloc'd buffer instead.

Cc: stable@vger.kernel.org
Signed-off-by: Jussi Kivilinna <jussi.kivilinna@mbnet.fi>
---
 drivers/net/wireless/rtlwifi/usb.c |    7 +++----
 1 file changed, 3 insertions(+), 4 deletions(-)

diff --git a/drivers/net/wireless/rtlwifi/usb.c b/drivers/net/wireless/rtlwifi/usb.c
index 29f0969..a3312b7 100644
--- a/drivers/net/wireless/rtlwifi/usb.c
+++ b/drivers/net/wireless/rtlwifi/usb.c
@@ -210,17 +210,16 @@ static void _usb_writeN_sync(struct rtl_priv *rtlpriv, u32 addr, void *data,
 	u16 index = REALTEK_USB_VENQT_CMD_IDX;
 	int pipe = usb_sndctrlpipe(udev, 0); /* write_out */
 	u8 *buffer;
-	dma_addr_t dma_addr;
 
-	wvalue = (u16)(addr&0x0000ffff);
-	buffer = usb_alloc_coherent(udev, (size_t)len, GFP_ATOMIC, &dma_addr);
+	wvalue = (u16)(addr & 0x0000ffff);
+	buffer = kmalloc(len, GFP_ATOMIC);
 	if (!buffer)
 		return;
 	memcpy(buffer, data, len);
 	usb_control_msg(udev, pipe, request, reqtype, wvalue,
 			index, buffer, len, 50);
 
-	usb_free_coherent(udev, (size_t)len, buffer, dma_addr);
+	kfree(buffer);
 }
 
 static void _rtl_usb_io_handler_init(struct device *dev,


^ permalink raw reply related	[flat|nested] 2+ messages in thread

* Re: [PATCH] rtlwifi: fix incorrect use of usb_alloc_coherent with usb_control_msg
  2012-12-20 14:24 [PATCH] rtlwifi: fix incorrect use of usb_alloc_coherent with usb_control_msg Jussi Kivilinna
@ 2012-12-20 18:00 ` Larry Finger
  0 siblings, 0 replies; 2+ messages in thread
From: Larry Finger @ 2012-12-20 18:00 UTC (permalink / raw)
  To: Jussi Kivilinna; +Cc: linux-wireless, Chaoming Li, John W. Linville, stable

On 12/20/2012 08:24 AM, Jussi Kivilinna wrote:
> Incorrect use of usb_alloc_coherent memory as input buffer to usb_control_msg
> can cause problems in arch DMA code, for example kernel BUG at
> 'arch/arm/include/asm/dma-mapping.h:321' on ARM (linux-3.4).
>
> Change _usb_writeN_sync use kmalloc'd buffer instead.
>
> Cc: stable@vger.kernel.org
> Signed-off-by: Jussi Kivilinna <jussi.kivilinna@mbnet.fi>
> ---
>   drivers/net/wireless/rtlwifi/usb.c |    7 +++----
>   1 file changed, 3 insertions(+), 4 deletions(-)

Acked-by: Larry Finger <Larry.Finger@lwfinger.net>

Thanks. My only test platforms are X86 and PPC-32. Neither showed this problem.

Larry
>
> diff --git a/drivers/net/wireless/rtlwifi/usb.c b/drivers/net/wireless/rtlwifi/usb.c
> index 29f0969..a3312b7 100644
> --- a/drivers/net/wireless/rtlwifi/usb.c
> +++ b/drivers/net/wireless/rtlwifi/usb.c
> @@ -210,17 +210,16 @@ static void _usb_writeN_sync(struct rtl_priv *rtlpriv, u32 addr, void *data,
>   	u16 index = REALTEK_USB_VENQT_CMD_IDX;
>   	int pipe = usb_sndctrlpipe(udev, 0); /* write_out */
>   	u8 *buffer;
> -	dma_addr_t dma_addr;
>
> -	wvalue = (u16)(addr&0x0000ffff);
> -	buffer = usb_alloc_coherent(udev, (size_t)len, GFP_ATOMIC, &dma_addr);
> +	wvalue = (u16)(addr & 0x0000ffff);
> +	buffer = kmalloc(len, GFP_ATOMIC);
>   	if (!buffer)
>   		return;
>   	memcpy(buffer, data, len);
>   	usb_control_msg(udev, pipe, request, reqtype, wvalue,
>   			index, buffer, len, 50);
>
> -	usb_free_coherent(udev, (size_t)len, buffer, dma_addr);
> +	kfree(buffer);
>   }
>
>   static void _rtl_usb_io_handler_init(struct device *dev,
>
> --
> To unsubscribe from this list: send the line "unsubscribe linux-wireless" in
> the body of a message to majordomo@vger.kernel.org
> More majordomo info at  http://vger.kernel.org/majordomo-info.html
>


^ permalink raw reply	[flat|nested] 2+ messages in thread

end of thread, other threads:[~2012-12-20 18:08 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2012-12-20 14:24 [PATCH] rtlwifi: fix incorrect use of usb_alloc_coherent with usb_control_msg Jussi Kivilinna
2012-12-20 18:00 ` Larry Finger

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.