From: John de la Garza Date: Thu, 6 Mar 2014 18:36:34 +0000 (-0800) Subject: staging: usbip: vhci_sysfs.c: check return value of sscanf X-Git-Url: https://git.karo-electronics.de/?a=commitdiff_plain;h=88fa1ebfa21b5deaaad2dc88ecd9f6af91796cf7;p=linux-beck.git staging: usbip: vhci_sysfs.c: check return value of sscanf Added code to check return value of sscanf. Signed-off-by: John de la Garza Signed-off-by: Greg Kroah-Hartman --- diff --git a/drivers/staging/usbip/vhci_sysfs.c b/drivers/staging/usbip/vhci_sysfs.c index 03e6edf46e7c..82dd49f7df9e 100644 --- a/drivers/staging/usbip/vhci_sysfs.c +++ b/drivers/staging/usbip/vhci_sysfs.c @@ -114,7 +114,8 @@ static ssize_t store_detach(struct device *dev, struct device_attribute *attr, int err; __u32 rhport = 0; - sscanf(buf, "%u", &rhport); + if (sscanf(buf, "%u", &rhport) != 1) + return -EINVAL; /* check rhport */ if (rhport >= VHCI_NPORTS) { @@ -182,7 +183,8 @@ static ssize_t store_attach(struct device *dev, struct device_attribute *attr, * @devid: unique device identifier in a remote host * @speed: usb device speed in a remote host */ - sscanf(buf, "%u %u %u %u", &rhport, &sockfd, &devid, &speed); + if (sscanf(buf, "%u %u %u %u", &rhport, &sockfd, &devid, &speed) != 1) + return -EINVAL; usbip_dbg_vhci_sysfs("rhport(%u) sockfd(%u) devid(%u) speed(%u)\n", rhport, sockfd, devid, speed);