Fixes the following sparse warnings:
        drivers/media/dvb-frontends/af9033.c:295 af9033_init() error: buffer 
overflow 'clock_adc_lut' 11 <= 11
        drivers/media/dvb-frontends/af9033.c:300 af9033_init() error: buffer 
overflow 'clock_adc_lut' 11 <= 11
        drivers/media/dvb-frontends/af9033.c:584 af9033_set_frontend() error: 
buffer overflow 'coeff_lut' 3 <= 3
        drivers/media/dvb-frontends/af9033.c:595 af9033_set_frontend() error: 
buffer overflow 'clock_adc_lut' 11 <= 11

Signed-off-by: Mauro Carvalho Chehab <mche...@osg.samsung.com>

diff --git a/drivers/media/dvb-frontends/af9033.c 
b/drivers/media/dvb-frontends/af9033.c
index c17e34fd0fb4..82ce47bdf5dc 100644
--- a/drivers/media/dvb-frontends/af9033.c
+++ b/drivers/media/dvb-frontends/af9033.c
@@ -291,6 +291,12 @@ static int af9033_init(struct dvb_frontend *fe)
                if (clock_adc_lut[i].clock == dev->cfg.clock)
                        break;
        }
+       if (i == ARRAY_SIZE(clock_adc_lut)) {
+               dev_err(&dev->client->dev,
+                       "Couldn't find ADC config for clock=%d\n",
+                       dev->cfg.clock);
+               goto err;
+       }
 
        adc_cw = af9033_div(dev, clock_adc_lut[i].adc, 1000000ul, 19ul);
        buf[0] = (adc_cw >>  0) & 0xff;
@@ -580,7 +586,15 @@ static int af9033_set_frontend(struct dvb_frontend *fe)
                                break;
                        }
                }
-               ret =  af9033_wr_regs(dev, 0x800001,
+               if (i == ARRAY_SIZE(coeff_lut)) {
+                       dev_err(&dev->client->dev,
+                               "Couldn't find LUT config for clock=%d\n",
+                               dev->cfg.clock);
+                       ret = -EINVAL;
+                       goto err;
+               }
+
+               ret = af9033_wr_regs(dev, 0x800001,
                                coeff_lut[i].val, sizeof(coeff_lut[i].val));
        }
 
@@ -592,6 +606,13 @@ static int af9033_set_frontend(struct dvb_frontend *fe)
                        if (clock_adc_lut[i].clock == dev->cfg.clock)
                                break;
                }
+               if (i == ARRAY_SIZE(clock_adc_lut)) {
+                       dev_err(&dev->client->dev,
+                               "Couldn't find ADC clock for clock=%d\n",
+                               dev->cfg.clock);
+                       ret = -EINVAL;
+                       goto err;
+               }
                adc_freq = clock_adc_lut[i].adc;
 
                /* get used IF frequency */
-- 
1.9.3

--
To unsubscribe from this list: send the line "unsubscribe linux-media" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to