diff options
author | Andrew de Quincey <adq_dvb@lidskialf.net> | 2006-04-20 11:01:47 -0400 |
---|---|---|
committer | Mauro Carvalho Chehab <mchehab@infradead.org> | 2006-06-25 00:59:38 -0400 |
commit | 6b3ccab75ce082f7d63a43903ebd75da4266f77e (patch) | |
tree | 866d08667706310aaf7151a9802595fb44a7b63f /drivers/media/video/saa7134/saa7134-dvb.c | |
parent | 159f8a6eda8c2ee359bb87bf62be70da2da14918 (diff) |
V4L/DVB (3895): Additional frontend_init safety checks
Don't try and set the tuner ops if the demod was not detected.
Signed-off-by: Andrew de Quincey <adq_dvb@lidskialf.net>
Signed-off-by: Mauro Carvalho Chehab <mchehab@infradead.org>
Diffstat (limited to 'drivers/media/video/saa7134/saa7134-dvb.c')
-rw-r--r-- | drivers/media/video/saa7134/saa7134-dvb.c | 116 |
1 files changed, 74 insertions, 42 deletions
diff --git a/drivers/media/video/saa7134/saa7134-dvb.c b/drivers/media/video/saa7134/saa7134-dvb.c index d62e9a4f2a1c..a83db2abb449 100644 --- a/drivers/media/video/saa7134/saa7134-dvb.c +++ b/drivers/media/video/saa7134/saa7134-dvb.c | |||
@@ -1020,112 +1020,144 @@ static int dvb_init(struct saa7134_dev *dev) | |||
1020 | printk("%s: pinnacle 300i dvb setup\n",dev->name); | 1020 | printk("%s: pinnacle 300i dvb setup\n",dev->name); |
1021 | dev->dvb.frontend = mt352_attach(&pinnacle_300i, | 1021 | dev->dvb.frontend = mt352_attach(&pinnacle_300i, |
1022 | &dev->i2c_adap); | 1022 | &dev->i2c_adap); |
1023 | dev->dvb.frontend->ops->tuner_ops.calc_regs = mt352_pinnacle_tuner_calc_regs; | 1023 | if (dev->dvb.frontend) { |
1024 | dev->dvb.frontend->ops->tuner_ops.calc_regs = mt352_pinnacle_tuner_calc_regs; | ||
1025 | } | ||
1024 | break; | 1026 | break; |
1025 | 1027 | ||
1026 | case SAA7134_BOARD_AVERMEDIA_777: | 1028 | case SAA7134_BOARD_AVERMEDIA_777: |
1027 | printk("%s: avertv 777 dvb setup\n",dev->name); | 1029 | printk("%s: avertv 777 dvb setup\n",dev->name); |
1028 | dev->dvb.frontend = mt352_attach(&avermedia_777, | 1030 | dev->dvb.frontend = mt352_attach(&avermedia_777, |
1029 | &dev->i2c_adap); | 1031 | &dev->i2c_adap); |
1030 | dev->dvb.frontend->ops->tuner_ops.calc_regs = mt352_aver777_tuner_calc_regs; | 1032 | if (dev->dvb.frontend) { |
1033 | dev->dvb.frontend->ops->tuner_ops.calc_regs = mt352_aver777_tuner_calc_regs; | ||
1034 | } | ||
1031 | break; | 1035 | break; |
1032 | #endif | 1036 | #endif |
1033 | #ifdef HAVE_TDA1004X | 1037 | #ifdef HAVE_TDA1004X |
1034 | case SAA7134_BOARD_MD7134: | 1038 | case SAA7134_BOARD_MD7134: |
1035 | dev->dvb.frontend = tda10046_attach(&medion_cardbus, | 1039 | dev->dvb.frontend = tda10046_attach(&medion_cardbus, |
1036 | &dev->i2c_adap); | 1040 | &dev->i2c_adap); |
1037 | dev->dvb.frontend->ops->tuner_ops.init = philips_fmd1216_tuner_init; | 1041 | if (dev->dvb.frontend) { |
1038 | dev->dvb.frontend->ops->tuner_ops.sleep = philips_fmd1216_tuner_sleep; | 1042 | dev->dvb.frontend->ops->tuner_ops.init = philips_fmd1216_tuner_init; |
1039 | dev->dvb.frontend->ops->tuner_ops.set_params = philips_fmd1216_tuner_set_params; | 1043 | dev->dvb.frontend->ops->tuner_ops.sleep = philips_fmd1216_tuner_sleep; |
1044 | dev->dvb.frontend->ops->tuner_ops.set_params = philips_fmd1216_tuner_set_params; | ||
1045 | } | ||
1040 | break; | 1046 | break; |
1041 | case SAA7134_BOARD_PHILIPS_TOUGH: | 1047 | case SAA7134_BOARD_PHILIPS_TOUGH: |
1042 | dev->dvb.frontend = tda10046_attach(&philips_tu1216_60_config, | 1048 | dev->dvb.frontend = tda10046_attach(&philips_tu1216_60_config, |
1043 | &dev->i2c_adap); | 1049 | &dev->i2c_adap); |
1044 | dev->dvb.frontend->ops->tuner_ops.init = philips_tu1216_tuner_60_init; | 1050 | if (dev->dvb.frontend) { |
1045 | dev->dvb.frontend->ops->tuner_ops.set_params = philips_tu1216_tuner_60_set_params; | 1051 | dev->dvb.frontend->ops->tuner_ops.init = philips_tu1216_tuner_60_init; |
1052 | dev->dvb.frontend->ops->tuner_ops.set_params = philips_tu1216_tuner_60_set_params; | ||
1053 | } | ||
1046 | break; | 1054 | break; |
1047 | case SAA7134_BOARD_FLYDVBTDUO: | 1055 | case SAA7134_BOARD_FLYDVBTDUO: |
1048 | dev->dvb.frontend = tda10046_attach(&tda827x_lifeview_config, | 1056 | dev->dvb.frontend = tda10046_attach(&tda827x_lifeview_config, |
1049 | &dev->i2c_adap); | 1057 | &dev->i2c_adap); |
1050 | dev->dvb.frontend->ops->tuner_ops.init = philips_tda827x_tuner_init; | 1058 | if (dev->dvb.frontend) { |
1051 | dev->dvb.frontend->ops->tuner_ops.sleep = philips_tda827x_tuner_sleep; | 1059 | dev->dvb.frontend->ops->tuner_ops.init = philips_tda827x_tuner_init; |
1052 | dev->dvb.frontend->ops->tuner_ops.set_params = philips_tda827x_tuner_set_params; | 1060 | dev->dvb.frontend->ops->tuner_ops.sleep = philips_tda827x_tuner_sleep; |
1061 | dev->dvb.frontend->ops->tuner_ops.set_params = philips_tda827x_tuner_set_params; | ||
1062 | } | ||
1053 | break; | 1063 | break; |
1054 | case SAA7134_BOARD_FLYDVBT_DUO_CARDBUS: | 1064 | case SAA7134_BOARD_FLYDVBT_DUO_CARDBUS: |
1055 | dev->dvb.frontend = tda10046_attach(&tda827x_lifeview_config, | 1065 | dev->dvb.frontend = tda10046_attach(&tda827x_lifeview_config, |
1056 | &dev->i2c_adap); | 1066 | &dev->i2c_adap); |
1057 | dev->dvb.frontend->ops->tuner_ops.init = philips_tda827x_tuner_init; | 1067 | if (dev->dvb.frontend) { |
1058 | dev->dvb.frontend->ops->tuner_ops.sleep = philips_tda827x_tuner_sleep; | 1068 | dev->dvb.frontend->ops->tuner_ops.init = philips_tda827x_tuner_init; |
1059 | dev->dvb.frontend->ops->tuner_ops.set_params = philips_tda827x_tuner_set_params; | 1069 | dev->dvb.frontend->ops->tuner_ops.sleep = philips_tda827x_tuner_sleep; |
1070 | dev->dvb.frontend->ops->tuner_ops.set_params = philips_tda827x_tuner_set_params; | ||
1071 | } | ||
1060 | break; | 1072 | break; |
1061 | case SAA7134_BOARD_PHILIPS_EUROPA: | 1073 | case SAA7134_BOARD_PHILIPS_EUROPA: |
1062 | dev->dvb.frontend = tda10046_attach(&philips_europa_config, | 1074 | dev->dvb.frontend = tda10046_attach(&philips_europa_config, |
1063 | &dev->i2c_adap); | 1075 | &dev->i2c_adap); |
1064 | dev->original_demod_sleep = dev->dvb.frontend->ops->sleep; | 1076 | if (dev->dvb.frontend) { |
1065 | dev->dvb.frontend->ops->sleep = philips_europa_demod_sleep; | 1077 | dev->original_demod_sleep = dev->dvb.frontend->ops->sleep; |
1066 | dev->dvb.frontend->ops->tuner_ops.init = philips_europa_tuner_init; | 1078 | dev->dvb.frontend->ops->sleep = philips_europa_demod_sleep; |
1067 | dev->dvb.frontend->ops->tuner_ops.sleep = philips_europa_tuner_sleep; | 1079 | dev->dvb.frontend->ops->tuner_ops.init = philips_europa_tuner_init; |
1068 | dev->dvb.frontend->ops->tuner_ops.set_params = philips_td1316_tuner_set_params; | 1080 | dev->dvb.frontend->ops->tuner_ops.sleep = philips_europa_tuner_sleep; |
1081 | dev->dvb.frontend->ops->tuner_ops.set_params = philips_td1316_tuner_set_params; | ||
1082 | } | ||
1069 | break; | 1083 | break; |
1070 | case SAA7134_BOARD_VIDEOMATE_DVBT_300: | 1084 | case SAA7134_BOARD_VIDEOMATE_DVBT_300: |
1071 | dev->dvb.frontend = tda10046_attach(&philips_europa_config, | 1085 | dev->dvb.frontend = tda10046_attach(&philips_europa_config, |
1072 | &dev->i2c_adap); | 1086 | &dev->i2c_adap); |
1073 | dev->dvb.frontend->ops->tuner_ops.init = philips_europa_tuner_init; | 1087 | if (dev->dvb.frontend) { |
1074 | dev->dvb.frontend->ops->tuner_ops.sleep = philips_europa_tuner_sleep; | 1088 | dev->dvb.frontend->ops->tuner_ops.init = philips_europa_tuner_init; |
1075 | dev->dvb.frontend->ops->tuner_ops.set_params = philips_td1316_tuner_set_params; | 1089 | dev->dvb.frontend->ops->tuner_ops.sleep = philips_europa_tuner_sleep; |
1090 | dev->dvb.frontend->ops->tuner_ops.set_params = philips_td1316_tuner_set_params; | ||
1091 | } | ||
1076 | break; | 1092 | break; |
1077 | case SAA7134_BOARD_VIDEOMATE_DVBT_200: | 1093 | case SAA7134_BOARD_VIDEOMATE_DVBT_200: |
1078 | dev->dvb.frontend = tda10046_attach(&philips_tu1216_61_config, | 1094 | dev->dvb.frontend = tda10046_attach(&philips_tu1216_61_config, |
1079 | &dev->i2c_adap); | 1095 | &dev->i2c_adap); |
1080 | dev->dvb.frontend->ops->tuner_ops.init = philips_tu1216_tuner_61_init; | 1096 | if (dev->dvb.frontend) { |
1081 | dev->dvb.frontend->ops->tuner_ops.set_params = philips_tu1216_tuner_61_set_params; | 1097 | dev->dvb.frontend->ops->tuner_ops.init = philips_tu1216_tuner_61_init; |
1098 | dev->dvb.frontend->ops->tuner_ops.set_params = philips_tu1216_tuner_61_set_params; | ||
1099 | } | ||
1082 | break; | 1100 | break; |
1083 | case SAA7134_BOARD_PHILIPS_TIGER: | 1101 | case SAA7134_BOARD_PHILIPS_TIGER: |
1084 | dev->dvb.frontend = tda10046_attach(&philips_tiger_config, | 1102 | dev->dvb.frontend = tda10046_attach(&philips_tiger_config, |
1085 | &dev->i2c_adap); | 1103 | &dev->i2c_adap); |
1086 | dev->dvb.frontend->ops->tuner_ops.init = philips_tiger_tuner_init; | 1104 | if (dev->dvb.frontend) { |
1087 | dev->dvb.frontend->ops->tuner_ops.sleep = philips_tiger_tuner_sleep; | 1105 | dev->dvb.frontend->ops->tuner_ops.init = philips_tiger_tuner_init; |
1088 | dev->dvb.frontend->ops->tuner_ops.set_params = philips_tiger_tuner_set_params; | 1106 | dev->dvb.frontend->ops->tuner_ops.sleep = philips_tiger_tuner_sleep; |
1107 | dev->dvb.frontend->ops->tuner_ops.set_params = philips_tiger_tuner_set_params; | ||
1108 | } | ||
1089 | break; | 1109 | break; |
1090 | case SAA7134_BOARD_ASUSTeK_P7131_DUAL: | 1110 | case SAA7134_BOARD_ASUSTeK_P7131_DUAL: |
1091 | dev->dvb.frontend = tda10046_attach(&philips_tiger_config, | 1111 | dev->dvb.frontend = tda10046_attach(&philips_tiger_config, |
1092 | &dev->i2c_adap); | 1112 | &dev->i2c_adap); |
1093 | dev->dvb.frontend->ops->tuner_ops.init = philips_tiger_tuner_init; | 1113 | if (dev->dvb.frontend) { |
1094 | dev->dvb.frontend->ops->tuner_ops.sleep = philips_tiger_tuner_sleep; | 1114 | dev->dvb.frontend->ops->tuner_ops.init = philips_tiger_tuner_init; |
1095 | dev->dvb.frontend->ops->tuner_ops.set_params = philips_tiger_tuner_set_params; | 1115 | dev->dvb.frontend->ops->tuner_ops.sleep = philips_tiger_tuner_sleep; |
1116 | dev->dvb.frontend->ops->tuner_ops.set_params = philips_tiger_tuner_set_params; | ||
1117 | } | ||
1096 | break; | 1118 | break; |
1097 | case SAA7134_BOARD_FLYDVBT_LR301: | 1119 | case SAA7134_BOARD_FLYDVBT_LR301: |
1098 | dev->dvb.frontend = tda10046_attach(&tda827x_lifeview_config, | 1120 | dev->dvb.frontend = tda10046_attach(&tda827x_lifeview_config, |
1099 | &dev->i2c_adap); | 1121 | &dev->i2c_adap); |
1100 | dev->dvb.frontend->ops->tuner_ops.init = philips_tda827x_tuner_init; | 1122 | if (dev->dvb.frontend) { |
1101 | dev->dvb.frontend->ops->tuner_ops.sleep = philips_tda827x_tuner_sleep; | 1123 | dev->dvb.frontend->ops->tuner_ops.init = philips_tda827x_tuner_init; |
1102 | dev->dvb.frontend->ops->tuner_ops.set_params = philips_tda827x_tuner_set_params; | 1124 | dev->dvb.frontend->ops->tuner_ops.sleep = philips_tda827x_tuner_sleep; |
1125 | dev->dvb.frontend->ops->tuner_ops.set_params = philips_tda827x_tuner_set_params; | ||
1126 | } | ||
1103 | break; | 1127 | break; |
1104 | case SAA7134_BOARD_FLYDVB_TRIO: | 1128 | case SAA7134_BOARD_FLYDVB_TRIO: |
1105 | dev->dvb.frontend = tda10046_attach(&lifeview_trio_config, | 1129 | dev->dvb.frontend = tda10046_attach(&lifeview_trio_config, |
1106 | &dev->i2c_adap); | 1130 | &dev->i2c_adap); |
1107 | dev->dvb.frontend->ops->tuner_ops.sleep = lifeview_trio_tuner_sleep; | 1131 | if (dev->dvb.frontend) { |
1108 | dev->dvb.frontend->ops->tuner_ops.set_params = lifeview_trio_tuner_set_params; | 1132 | dev->dvb.frontend->ops->tuner_ops.sleep = lifeview_trio_tuner_sleep; |
1133 | dev->dvb.frontend->ops->tuner_ops.set_params = lifeview_trio_tuner_set_params; | ||
1134 | } | ||
1109 | break; | 1135 | break; |
1110 | case SAA7134_BOARD_ADS_DUO_CARDBUS_PTV331: | 1136 | case SAA7134_BOARD_ADS_DUO_CARDBUS_PTV331: |
1111 | dev->dvb.frontend = tda10046_attach(&ads_tech_duo_config, | 1137 | dev->dvb.frontend = tda10046_attach(&ads_tech_duo_config, |
1112 | &dev->i2c_adap); | 1138 | &dev->i2c_adap); |
1113 | dev->dvb.frontend->ops->tuner_ops.init = ads_duo_tuner_init; | 1139 | if (dev->dvb.frontend) { |
1114 | dev->dvb.frontend->ops->tuner_ops.sleep = ads_duo_tuner_sleep; | 1140 | dev->dvb.frontend->ops->tuner_ops.init = ads_duo_tuner_init; |
1115 | dev->dvb.frontend->ops->tuner_ops.set_params = ads_duo_tuner_set_params; | 1141 | dev->dvb.frontend->ops->tuner_ops.sleep = ads_duo_tuner_sleep; |
1142 | dev->dvb.frontend->ops->tuner_ops.set_params = ads_duo_tuner_set_params; | ||
1143 | } | ||
1116 | break; | 1144 | break; |
1117 | case SAA7134_BOARD_TEVION_DVBT_220RF: | 1145 | case SAA7134_BOARD_TEVION_DVBT_220RF: |
1118 | dev->dvb.frontend = tda10046_attach(&tevion_dvbt220rf_config, | 1146 | dev->dvb.frontend = tda10046_attach(&tevion_dvbt220rf_config, |
1119 | &dev->i2c_adap); | 1147 | &dev->i2c_adap); |
1120 | dev->dvb.frontend->ops->tuner_ops.sleep = tevion_dvb220rf_tuner_sleep; | 1148 | if (dev->dvb.frontend) { |
1121 | dev->dvb.frontend->ops->tuner_ops.set_params = tevion_dvb220rf_tuner_set_params; | 1149 | dev->dvb.frontend->ops->tuner_ops.sleep = tevion_dvb220rf_tuner_sleep; |
1150 | dev->dvb.frontend->ops->tuner_ops.set_params = tevion_dvb220rf_tuner_set_params; | ||
1151 | } | ||
1122 | break; | 1152 | break; |
1123 | case SAA7134_BOARD_FLYDVBT_HYBRID_CARDBUS: | 1153 | case SAA7134_BOARD_FLYDVBT_HYBRID_CARDBUS: |
1124 | dev->dvb.frontend = tda10046_attach(&ads_tech_duo_config, | 1154 | dev->dvb.frontend = tda10046_attach(&ads_tech_duo_config, |
1125 | &dev->i2c_adap); | 1155 | &dev->i2c_adap); |
1126 | dev->dvb.frontend->ops->tuner_ops.init = ads_duo_tuner_init; | 1156 | if (dev->dvb.frontend) { |
1127 | dev->dvb.frontend->ops->tuner_ops.sleep = ads_duo_tuner_sleep; | 1157 | dev->dvb.frontend->ops->tuner_ops.init = ads_duo_tuner_init; |
1128 | dev->dvb.frontend->ops->tuner_ops.set_params = ads_duo_tuner_set_params; | 1158 | dev->dvb.frontend->ops->tuner_ops.sleep = ads_duo_tuner_sleep; |
1159 | dev->dvb.frontend->ops->tuner_ops.set_params = ads_duo_tuner_set_params; | ||
1160 | } | ||
1129 | break; | 1161 | break; |
1130 | #endif | 1162 | #endif |
1131 | #ifdef HAVE_NXT200X | 1163 | #ifdef HAVE_NXT200X |