From: Axel Lin Date: Mon, 16 May 2011 14:19:01 +0000 (+0800) Subject: mfd: Fix off-by-one value range checking for tps65910_i2c_write X-Git-Tag: firefly_0821_release~7613^2~1038^2~14 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=0514e9acd7655c708fbf12a659ea43d835bc688a;p=firefly-linux-kernel-4.4.55.git 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 Acked-by: Samuel Ortiz Signed-off-by: Liam Girdwood --- diff --git a/drivers/mfd/tps65910.c b/drivers/mfd/tps65910.c index bf649cf6a0ae..e31824870b9f 100644 --- a/drivers/mfd/tps65910.c +++ b/drivers/mfd/tps65910.c @@ -71,7 +71,7 @@ static int tps65910_i2c_write(struct tps65910 *tps65910, u8 reg, u8 msg[TPS65910_MAX_REGISTER + 1]; int ret; - if (bytes > (TPS65910_MAX_REGISTER + 1)) + if (bytes > TPS65910_MAX_REGISTER) return -EINVAL; msg[0] = reg;