mfd: Fix off-by-one value range checking for tps65910_i2c_write
If bytes == (TPS65910_MAX_REGISTER + 1), we have a buffer overflow when doing memcpy(&msg[1], src, bytes). Signed-off-by: Axel Lin <axel.lin@gmail.com> Acked-by: Samuel Ortiz <sameo@linux.intel.com> Signed-off-by: Liam Girdwood <lrg@slimlogic.co.uk>
This commit is contained in:
@@ -71,7 +71,7 @@ static int tps65910_i2c_write(struct tps65910 *tps65910, u8 reg,
|
|||||||
u8 msg[TPS65910_MAX_REGISTER + 1];
|
u8 msg[TPS65910_MAX_REGISTER + 1];
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
if (bytes > (TPS65910_MAX_REGISTER + 1))
|
if (bytes > TPS65910_MAX_REGISTER)
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
|
|
||||||
msg[0] = reg;
|
msg[0] = reg;
|
||||||
|
Reference in New Issue
Block a user