From: Chris Pascoe Date: Mon, 19 Nov 2007 09:33:16 +0000 (-0300) Subject: V4L/DVB (6640): xc2028: correctly select 8MHz firmware X-Git-Tag: firefly_0821_release~23728^2~333 X-Git-Url: http://demsky.eecs.uci.edu/git/?a=commitdiff_plain;h=ddf1c5f1d78c1ce30a7e6b2447670fc0e103bb62;p=firefly-linux-kernel-4.4.55.git V4L/DVB (6640): xc2028: correctly select 8MHz firmware We were using priv->bandwidth to select the base firmware to load, not the requested bandwidth value, oops. Also, 7MHz Digital TV needs 8MHz base firmware loaded. Signed-off-by: Chris Pascoe Signed-off-by: Mauro Carvalho Chehab --- diff --git a/drivers/media/video/tuner-xc2028.c b/drivers/media/video/tuner-xc2028.c index e85992f970f7..adef80e627b8 100644 --- a/drivers/media/video/tuner-xc2028.c +++ b/drivers/media/video/tuner-xc2028.c @@ -608,7 +608,8 @@ static int check_firmware(struct dvb_frontend *fe, enum tuner_mode new_mode, if (priv->ctrl.type == XC2028_FIRM_MTS) type0 |= MTS; - if (priv->bandwidth == 8) + if (bandwidth == BANDWIDTH_7_MHZ || + bandwidth == BANDWIDTH_8_MHZ) type0 |= F8MHZ; /* FIXME: How to load FM and FM|INPUT1 firmwares? */ @@ -814,7 +815,8 @@ static int xc2028_set_tv_freq(struct dvb_frontend *fe, tuner_dbg("%s called\n", __FUNCTION__); return generic_set_tv_freq(fe, 62500l * p->frequency, T_ANALOG_TV, - p->std, BANDWIDTH_8_MHZ /* NOT USED */); + p->std, BANDWIDTH_8_MHZ); + /* XXX Are some analog standards 6MHz? */ } static int xc2028_set_params(struct dvb_frontend *fe,