On Fri, Nov 18, 2016 at 02:51:54PM +0300, Dan Carpenter wrote: > The value[] array has "max_ints" elements so this should be >= instead > of >. > > Fixes: ac4f6eee8fe8 ("staging: iio: TAOS tsl258x: Device driver") > Signed-off-by: Dan Carpenter <dan.carpenter@xxxxxxxxxx> > > diff --git a/drivers/iio/light/tsl2583.c b/drivers/iio/light/tsl2583.c > index 0b87f6a..faef6bd 100644 > --- a/drivers/iio/light/tsl2583.c > +++ b/drivers/iio/light/tsl2583.c > @@ -580,7 +580,7 @@ static ssize_t in_illuminance_lux_table_store(struct device *dev, > * and the last table entry is all 0. > */ > n = value[0]; > - if ((n % 3) || n < 6 || n > max_ints) { > + if ((n % 3) || n < 6 || n >= max_ints) { > dev_err(dev, > "%s: The number of entries in the lux table must be a multiple of 3 and within the range [6, %d]\n", > __func__, max_ints); Hi Dan, Good catch! I believe that this should use a different fix though. The definition of value in in_illuminance_lux_table_store() should be changed from: int value[TSL2583_MAX_LUX_TABLE_ENTRIES * 3]; to: int value[(TSL2583_MAX_LUX_TABLE_ENTRIES * 3) + 1]; This will allow storing the extra integer from get_options() containing the integer count. Otherwise, with your propsed change, someone would only be able to use 9 entries in the device lux table rather than the 10 that are set aside. Also, this may be (well is) nit picking, but I had [6, 33] in the error message to mark the range as inclusive on both ends. If it was exclusive on the upper end, then the error message should have also been changed to be [6, 33). Brian -- To unsubscribe from this list: send the line "unsubscribe linux-iio" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html