Commit d2126326 authored by Johan Hovold's avatar Johan Hovold Committed by Greg Kroah-Hartman

USB: oti6858: fix DMA buffer on stack

Signed-off-by: default avatarJohan Hovold <jhovold@gmail.com>
Signed-off-by: default avatarGreg Kroah-Hartman <gregkh@suse.de>
parent 9e221a35
...@@ -302,7 +302,7 @@ void send_data(struct work_struct *work) ...@@ -302,7 +302,7 @@ void send_data(struct work_struct *work)
struct usb_serial_port *port = priv->port; struct usb_serial_port *port = priv->port;
int count = 0, result; int count = 0, result;
unsigned long flags; unsigned long flags;
unsigned char allow; u8 *allow;
dbg("%s(port = %d)", __func__, port->number); dbg("%s(port = %d)", __func__, port->number);
...@@ -321,13 +321,20 @@ void send_data(struct work_struct *work) ...@@ -321,13 +321,20 @@ void send_data(struct work_struct *work)
count = port->bulk_out_size; count = port->bulk_out_size;
if (count != 0) { if (count != 0) {
allow = kmalloc(1, GFP_KERNEL);
if (!allow) {
dev_err(&port->dev, "%s(): kmalloc failed\n",
__func__);
return;
}
result = usb_control_msg(port->serial->dev, result = usb_control_msg(port->serial->dev,
usb_rcvctrlpipe(port->serial->dev, 0), usb_rcvctrlpipe(port->serial->dev, 0),
OTI6858_REQ_T_CHECK_TXBUFF, OTI6858_REQ_T_CHECK_TXBUFF,
OTI6858_REQ_CHECK_TXBUFF, OTI6858_REQ_CHECK_TXBUFF,
count, 0, &allow, 1, 100); count, 0, allow, 1, 100);
if (result != 1 || allow != 0) if (result != 1 || *allow != 0)
count = 0; count = 0;
kfree(allow);
} }
if (count == 0) { if (count == 0) {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment