diff options
author | Mauro Carvalho Chehab <mchehab@infradead.org> | 2007-11-24 09:07:12 -0500 |
---|---|---|
committer | Mauro Carvalho Chehab <mchehab@infradead.org> | 2008-01-25 16:02:57 -0500 |
commit | b542dfdc9f6e6eaf3cc2ede27dbaf50425f8b4b5 (patch) | |
tree | a9f9c9c335c501af72f4d2a333cefb5160df8617 /drivers/media/video/tuner-xc2028.c | |
parent | d04aa54a27f7bc6f051e55c47abbc0a1db1718bc (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.c | 18 |
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 | ||
917 | static 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 | |||
917 | static int xc2028_set_params(struct dvb_frontend *fe, | 930 | static 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 | } |