Commit 82932d4c authored by Antti Palosaari's avatar Antti Palosaari Committed by Mauro Carvalho Chehab

[media] msi001: fix possible integer overflow

Coverity CID 1196502: Unintentional integer overflow
(OVERFLOW_BEFORE_WIDEN)

Potentially overflowing expression "(f_rf + f_if + f_if1) * lo_div"
with type "unsigned int" (32 bits, unsigned) is evaluated using 32-bit
arithmetic before being used in a context which expects an expression
of type "u64" (64 bits, unsigned). To avoid overflow, cast either
operand to "u64" before performing the multiplication.

Reported-by: <scan-admin@coverity.com>
Signed-off-by: default avatarAntti Palosaari <crope@iki.fi>
Signed-off-by: default avatarMauro Carvalho Chehab <m.chehab@samsung.com>
parent 773bcf8c
...@@ -201,7 +201,7 @@ static int msi001_set_tuner(struct msi001 *s) ...@@ -201,7 +201,7 @@ static int msi001_set_tuner(struct msi001 *s)
dev_dbg(&s->spi->dev, "%s: bandwidth selected=%d\n", dev_dbg(&s->spi->dev, "%s: bandwidth selected=%d\n",
__func__, bandwidth_lut[i].freq); __func__, bandwidth_lut[i].freq);
f_vco = (f_rf + f_if + f_if1) * lo_div; f_vco = (u64) (f_rf + f_if + f_if1) * lo_div;
tmp64 = f_vco; tmp64 = f_vco;
m = do_div(tmp64, F_REF * R_REF); m = do_div(tmp64, F_REF * R_REF);
n = (unsigned int) tmp64; n = (unsigned int) tmp64;
......
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