summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAlan <gnomes@lxorguk.ukuu.org.uk>2016-02-15 20:09:46 +0100
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>2016-02-21 05:15:57 +0100
commit3c724888d2b1e085cd45343dee5f233aec705439 (patch)
tree9ee72b54c823162edfe0f0b5cbbe107532d9c190
parentusb/misc/chaoskey: introduce an URB for asynchronous reads (diff)
downloadlinux-3c724888d2b1e085cd45343dee5f233aec705439.tar.xz
linux-3c724888d2b1e085cd45343dee5f233aec705439.zip
chipidea: error on overflow for port_test_write
The write value is 8bit, but currently writing a larger number (eg a doubled digit) is not errored but instead gets cast and sets off an action probably undesired. Signed-off-by: Alan Cox <alan@linux.intel.com> Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
-rw-r--r--drivers/usb/chipidea/debug.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/drivers/usb/chipidea/debug.c b/drivers/usb/chipidea/debug.c
index de5c5092d078..6d23eede4d8c 100644
--- a/drivers/usb/chipidea/debug.c
+++ b/drivers/usb/chipidea/debug.c
@@ -100,6 +100,9 @@ static ssize_t ci_port_test_write(struct file *file, const char __user *ubuf,
if (sscanf(buf, "%u", &mode) != 1)
return -EINVAL;
+ if (mode > 255)
+ return -EBADRQC;
+
pm_runtime_get_sync(ci->dev);
spin_lock_irqsave(&ci->lock, flags);
ret = hw_port_test_set(ci, mode);