If those callbacks fail, it should return zero, and not a random
value. The previous code assumed that all drivers would only change
signal strength if it succeeds, but this may not be true.
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
static int fe_has_signal(struct dvb_frontend *fe)
{
- u16 strength = 0;
+ u16 strength;
- fe->ops.tuner_ops.get_rf_strength(fe, &strength);
+ if (fe->ops.tuner_ops.get_rf_strength(fe, &strength) < 0)
+ return 0;
return strength;
}
static int fe_get_afc(struct dvb_frontend *fe)
{
- s32 afc = 0;
+ s32 afc;
- fe->ops.tuner_ops.get_afc(fe, &afc);
+ if (fe->ops.tuner_ops.get_afc(fe, &afc) < 0)
+ return 0;
return afc;
}