Commit dd6230ba authored by Colin Ian King's avatar Colin Ian King Committed by Jonathan Cameron

iio: dac: ad5770r: fix off-by-one check on maximum number of channels

Currently there is an off-by-one check on the number of channels that
will cause an arry overrun in array st->output_mode when calling the
function d5770r_store_output_range. Fix this by using >= rather than >
to check for maximum number of channels.

Addresses-Coverity: ("Out-of-bounds access")
Fixes: cbbb8198 ("iio: dac: ad5770r: Add AD5770R support")
Signed-off-by: default avatarColin Ian King <colin.king@canonical.com>
Reviewed-by: default avatarAlexandru Ardelean <alexandru.ardelean@analog.com>
Signed-off-by: default avatarJonathan Cameron <Jonathan.Cameron@huawei.com>
parent 3a63da26
...@@ -525,7 +525,7 @@ static int ad5770r_channel_config(struct ad5770r_state *st) ...@@ -525,7 +525,7 @@ static int ad5770r_channel_config(struct ad5770r_state *st)
ret = fwnode_property_read_u32(child, "num", &num); ret = fwnode_property_read_u32(child, "num", &num);
if (ret) if (ret)
return ret; return ret;
if (num > AD5770R_MAX_CHANNELS) if (num >= AD5770R_MAX_CHANNELS)
return -EINVAL; return -EINVAL;
ret = fwnode_property_read_u32_array(child, ret = fwnode_property_read_u32_array(child,
......
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