From: Lars Poeschel <poesc...@lemonage.de>

The query for the viperboard version was done with memory buffer
on the stack but usb transfers need dma capable memory buffer.
This is fixed now.

Signed-off-by: Lars Poeschel <poesc...@lemonage.de>
---
 drivers/mfd/viperboard.c |    9 ++++-----
 1 file changed, 4 insertions(+), 5 deletions(-)

diff --git a/drivers/mfd/viperboard.c b/drivers/mfd/viperboard.c
index 276122b..af2a670 100644
--- a/drivers/mfd/viperboard.c
+++ b/drivers/mfd/viperboard.c
@@ -56,7 +56,6 @@ static int vprbrd_probe(struct usb_interface *interface,
 
        u16 version = 0;
        int pipe, ret;
-       unsigned char buf[1];
 
        /* allocate memory for our device state and initialize it */
        vb = kzalloc(sizeof(*vb), GFP_KERNEL);
@@ -76,17 +75,17 @@ static int vprbrd_probe(struct usb_interface *interface,
        /* get version information, major first, minor then */
        pipe = usb_rcvctrlpipe(vb->usb_dev, 0);
        ret = usb_control_msg(vb->usb_dev, pipe, VPRBRD_USB_REQUEST_MAJOR,
-               VPRBRD_USB_TYPE_IN, 0x0000, 0x0000, buf, 1,
+               VPRBRD_USB_TYPE_IN, 0x0000, 0x0000, vb->buf, 1,
                VPRBRD_USB_TIMEOUT_MS);
        if (ret == 1)
-               version = buf[0];
+               version = vb->buf[0];
 
        ret = usb_control_msg(vb->usb_dev, pipe, VPRBRD_USB_REQUEST_MINOR,
-               VPRBRD_USB_TYPE_IN, 0x0000, 0x0000, buf, 1,
+               VPRBRD_USB_TYPE_IN, 0x0000, 0x0000, vb->buf, 1,
                VPRBRD_USB_TIMEOUT_MS);
        if (ret == 1) {
                version <<= 8;
-               version = version | buf[0];
+               version = version | vb->buf[0];
        }
 
        dev_info(&interface->dev,
-- 
1.7.10.4

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to