linux-input.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
* re: Input: atmel_mxt_ts - read and report bootloader version
@ 2014-05-21 12:26 Dan Carpenter
  2014-05-29 12:34 ` [PATCH] Input: atmel_mxt_ts - fix invalid return from mxt_get_bootloader_version nick.dyer
  0 siblings, 1 reply; 2+ messages in thread
From: Dan Carpenter @ 2014-05-21 12:26 UTC (permalink / raw)
  To: nick.dyer; +Cc: linux-input

Hello Nick Dyer,

The patch e57a66aa8534: "Input: atmel_mxt_ts - read and report
bootloader version" from May 18, 2014, leads to the following static
checker warning:

	drivers/input/touchscreen/atmel_mxt_ts.c:437 mxt_get_bootloader_version()
	warn: signedness bug returning '(-5)'

drivers/input/touchscreen/atmel_mxt_ts.c
   429  static u8 mxt_get_bootloader_version(struct mxt_data *data, u8 val)
   430  {
   431          struct device *dev = &data->client->dev;
   432          u8 buf[3];
   433  
   434          if (val & MXT_BOOT_EXTENDED_ID) {
   435                  if (mxt_bootloader_read(data, &buf[0], 3) != 0) {
   436                          dev_err(dev, "%s: i2c failure\n", __func__);
   437                          return -EIO;
                                       ^^^^
This gets truncated into a number from 0-255 and anyway the caller
doesn't check for errors.

   438                  }
   439  
   440                  dev_dbg(dev, "Bootloader ID:%d Version:%d\n", buf[1], buf[2]);
   441  
   442                  return buf[0];
   443          } else {
   444                  dev_dbg(dev, "Bootloader ID:%d\n", val & MXT_BOOT_ID_MASK);
   445  
   446                  return val;
   447          }
   448  }

regards,
dan carpenter

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

* [PATCH] Input: atmel_mxt_ts - fix invalid return from mxt_get_bootloader_version
  2014-05-21 12:26 Input: atmel_mxt_ts - read and report bootloader version Dan Carpenter
@ 2014-05-29 12:34 ` nick.dyer
  0 siblings, 0 replies; 2+ messages in thread
From: nick.dyer @ 2014-05-29 12:34 UTC (permalink / raw)
  To: Dmitry Torokhov; +Cc: Dan Carpenter, linux-input, Nick Dyer

From: Nick Dyer <nick.dyer@itdev.co.uk>

The patch e57a66aa8534: "Input: atmel_mxt_ts - read and report
bootloader version" from May 18, 2014, leads to the following static
checker warning:

	drivers/input/touchscreen/atmel_mxt_ts.c:437 mxt_get_bootloader_version()
	warn: signedness bug returning '(-5)'

drivers/input/touchscreen/atmel_mxt_ts.c
   429  static u8 mxt_get_bootloader_version(struct mxt_data *data, u8 val)
   430  {
   431          struct device *dev = &data->client->dev;
   432          u8 buf[3];
   433
   434          if (val & MXT_BOOT_EXTENDED_ID) {
   435                  if (mxt_bootloader_read(data, &buf[0], 3) != 0) {
   436                          dev_err(dev, "%s: i2c failure\n", __func__);
   437                          return -EIO;
                                       ^^^^
This gets truncated into a number from 0-255 and anyway the caller
doesn't check for errors.

(reported by Dan Carpenter)

Signed-off-by: Nick Dyer <nick.dyer@itdev.co.uk>
---
 drivers/input/touchscreen/atmel_mxt_ts.c | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/drivers/input/touchscreen/atmel_mxt_ts.c b/drivers/input/touchscreen/atmel_mxt_ts.c
index fb0e006..693b163 100644
--- a/drivers/input/touchscreen/atmel_mxt_ts.c
+++ b/drivers/input/touchscreen/atmel_mxt_ts.c
@@ -435,7 +435,7 @@ static u8 mxt_get_bootloader_version(struct mxt_data *data, u8 val)
 	if (val & MXT_BOOT_EXTENDED_ID) {
 		if (mxt_bootloader_read(data, &buf[0], 3) != 0) {
 			dev_err(dev, "%s: i2c failure\n", __func__);
-			return -EIO;
+			return val;
 		}
 
 		dev_dbg(dev, "Bootloader ID:%d Version:%d\n", buf[1], buf[2]);
-- 
1.8.3.2


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

end of thread, other threads:[~2014-05-29 12:39 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2014-05-21 12:26 Input: atmel_mxt_ts - read and report bootloader version Dan Carpenter
2014-05-29 12:34 ` [PATCH] Input: atmel_mxt_ts - fix invalid return from mxt_get_bootloader_version nick.dyer

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).