aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/media/video/tuner-xc2028.c
diff options
context:
space:
mode:
authorMauro Carvalho Chehab <mchehab@infradead.org>2007-11-24 09:07:12 -0500
committerMauro Carvalho Chehab <mchehab@infradead.org>2008-01-25 16:02:57 -0500
commitb542dfdc9f6e6eaf3cc2ede27dbaf50425f8b4b5 (patch)
treea9f9c9c335c501af72f4d2a333cefb5160df8617 /drivers/media/video/tuner-xc2028.c
parentd04aa54a27f7bc6f051e55c47abbc0a1db1718bc (diff)
V4L/DVB (6675): Allow selecting the proper SCode table for DTV
Signed-off-by: Mauro Carvalho Chehab <mchehab@infradead.org>
Diffstat (limited to 'drivers/media/video/tuner-xc2028.c')
-rw-r--r--drivers/media/video/tuner-xc2028.c18
1 files changed, 18 insertions, 0 deletions
diff --git a/drivers/media/video/tuner-xc2028.c b/drivers/media/video/tuner-xc2028.c
index 42fb141fc386..9743331c895c 100644
--- a/drivers/media/video/tuner-xc2028.c
+++ b/drivers/media/video/tuner-xc2028.c
@@ -914,6 +914,19 @@ static int xc2028_set_analog_freq(struct dvb_frontend *fe,
914 T_ANALOG_TV, type, p->std); 914 T_ANALOG_TV, type, p->std);
915} 915}
916 916
917static unsigned int demod_type [] = {
918 [XC3028_FE_DEFAULT] = 0,
919 [XC3028_FE_LG60] = LG60,
920 [XC3028_FE_ATI638] = ATI638,
921 [XC3028_FE_OREN538] = OREN538,
922 [XC3028_FE_OREN36] = OREN36,
923 [XC3028_FE_TOYOTA388] = TOYOTA388,
924 [XC3028_FE_TOYOTA794] = TOYOTA794,
925 [XC3028_FE_DIBCOM52] = DIBCOM52,
926 [XC3028_FE_ZARLINK456] = ZARLINK456,
927 [XC3028_FE_CHINA] = CHINA,
928};
929
917static int xc2028_set_params(struct dvb_frontend *fe, 930static int xc2028_set_params(struct dvb_frontend *fe,
918 struct dvb_frontend_parameters *p) 931 struct dvb_frontend_parameters *p)
919{ 932{
@@ -965,6 +978,11 @@ static int xc2028_set_params(struct dvb_frontend *fe,
965 tuner_err("error: bandwidth not supported.\n"); 978 tuner_err("error: bandwidth not supported.\n");
966 }; 979 };
967 980
981 if (priv->ctrl.demod < 0 || priv->ctrl.demod > ARRAY_SIZE(demod_type))
982 tuner_err("error: demod type invalid. Assuming default.\n");
983 else
984 type |= demod_type[priv->ctrl.demod];
985
968 return generic_set_freq(fe, p->frequency, 986 return generic_set_freq(fe, p->frequency,
969 T_DIGITAL_TV, type, 0); 987 T_DIGITAL_TV, type, 0);
970} 988}