diff options
-rw-r--r-- | drivers/media/video/saa7134/saa7134-core.c | 42 | ||||
-rw-r--r-- | drivers/media/video/v4l2-common.c | 36 | ||||
-rw-r--r-- | include/media/v4l2-common.h | 13 |
3 files changed, 65 insertions, 26 deletions
diff --git a/drivers/media/video/saa7134/saa7134-core.c b/drivers/media/video/saa7134/saa7134-core.c index ac23ff53543d..829006ebdf34 100644 --- a/drivers/media/video/saa7134/saa7134-core.c +++ b/drivers/media/video/saa7134/saa7134-core.c | |||
@@ -980,35 +980,25 @@ static int __devinit saa7134_initdev(struct pci_dev *pci_dev, | |||
980 | 980 | ||
981 | /* initialize hardware #2 */ | 981 | /* initialize hardware #2 */ |
982 | if (TUNER_ABSENT != dev->tuner_type) { | 982 | if (TUNER_ABSENT != dev->tuner_type) { |
983 | if (dev->radio_type != UNSET) { | 983 | int has_demod = (dev->tda9887_conf & TDA9887_PRESENT); |
984 | v4l2_i2c_new_subdev(&dev->i2c_adap, "tuner", "tuner", | ||
985 | dev->radio_addr); | ||
986 | } | ||
987 | if (dev->tda9887_conf & TDA9887_PRESENT) { | ||
988 | unsigned short addrs[] = { 0x42, 0x43, 0x4a, 0x4b, | ||
989 | I2C_CLIENT_END }; | ||
990 | 984 | ||
991 | v4l2_i2c_new_probed_subdev(&dev->i2c_adap, | 985 | /* Note: radio tuner address is always filled in, |
992 | "tuner", "tuner", addrs); | 986 | so we do not need to probe for a radio tuner device. */ |
993 | } | 987 | if (dev->radio_type != UNSET) |
994 | if (dev->tuner_addr != ADDR_UNSET) { | ||
995 | v4l2_i2c_new_subdev(&dev->i2c_adap, | 988 | v4l2_i2c_new_subdev(&dev->i2c_adap, |
996 | "tuner", "tuner", dev->tuner_addr); | 989 | "tuner", "tuner", dev->radio_addr); |
990 | if (has_demod) | ||
991 | v4l2_i2c_new_probed_subdev(&dev->i2c_adap, "tuner", | ||
992 | "tuner", v4l2_i2c_tuner_addrs(ADDRS_DEMOD)); | ||
993 | if (dev->tuner_addr == ADDR_UNSET) { | ||
994 | enum v4l2_i2c_tuner_type type = | ||
995 | has_demod ? ADDRS_TV_WITH_DEMOD : ADDRS_TV; | ||
996 | |||
997 | v4l2_i2c_new_probed_subdev(&dev->i2c_adap, "tuner", | ||
998 | "tuner", v4l2_i2c_tuner_addrs(type)); | ||
997 | } else { | 999 | } else { |
998 | unsigned short addrs[] = { | 1000 | v4l2_i2c_new_subdev(&dev->i2c_adap, |
999 | 0x42, 0x43, 0x4a, 0x4b, /* tda8290 */ | 1001 | "tuner", "tuner", dev->tuner_addr); |
1000 | 0x60, 0x61, 0x62, 0x63, 0x64, 0x65, 0x66, 0x67, | ||
1001 | 0x68, 0x69, 0x6a, 0x6b, 0x6c, 0x6d, 0x6e, 0x6f, | ||
1002 | I2C_CLIENT_END | ||
1003 | }; | ||
1004 | |||
1005 | if (dev->tda9887_conf & TDA9887_PRESENT) { | ||
1006 | v4l2_i2c_new_probed_subdev(&dev->i2c_adap, | ||
1007 | "tuner", "tuner", addrs + 4); | ||
1008 | } else { | ||
1009 | v4l2_i2c_new_probed_subdev(&dev->i2c_adap, | ||
1010 | "tuner", "tuner", addrs); | ||
1011 | } | ||
1012 | } | 1002 | } |
1013 | } | 1003 | } |
1014 | saa7134_board_init2(dev); | 1004 | saa7134_board_init2(dev); |
diff --git a/drivers/media/video/v4l2-common.c b/drivers/media/video/v4l2-common.c index 0f450a73477a..26e162f13f7f 100644 --- a/drivers/media/video/v4l2-common.c +++ b/drivers/media/video/v4l2-common.c | |||
@@ -991,4 +991,40 @@ struct v4l2_subdev *v4l2_i2c_new_probed_subdev(struct i2c_adapter *adapter, | |||
991 | } | 991 | } |
992 | EXPORT_SYMBOL_GPL(v4l2_i2c_new_probed_subdev); | 992 | EXPORT_SYMBOL_GPL(v4l2_i2c_new_probed_subdev); |
993 | 993 | ||
994 | /* Return a list of I2C tuner addresses to probe. Use only if the tuner | ||
995 | addresses are unknown. */ | ||
996 | const unsigned short *v4l2_i2c_tuner_addrs(enum v4l2_i2c_tuner_type type) | ||
997 | { | ||
998 | static const unsigned short radio_addrs[] = { | ||
999 | #if defined(CONFIG_MEDIA_TUNER_TEA5761) || defined(CONFIG_MEDIA_TUNER_TEA5761_MODULE) | ||
1000 | 0x10, | ||
1001 | #endif | ||
1002 | 0x60, | ||
1003 | I2C_CLIENT_END | ||
1004 | }; | ||
1005 | static const unsigned short demod_addrs[] = { | ||
1006 | 0x42, 0x43, 0x4a, 0x4b, | ||
1007 | I2C_CLIENT_END | ||
1008 | }; | ||
1009 | static const unsigned short tv_addrs[] = { | ||
1010 | 0x42, 0x43, 0x4a, 0x4b, /* tda8290 */ | ||
1011 | 0x60, 0x61, 0x62, 0x63, 0x64, 0x65, 0x66, 0x67, | ||
1012 | 0x68, 0x69, 0x6a, 0x6b, 0x6c, 0x6d, 0x6e, 0x6f, | ||
1013 | I2C_CLIENT_END | ||
1014 | }; | ||
1015 | |||
1016 | switch (type) { | ||
1017 | case ADDRS_RADIO: | ||
1018 | return radio_addrs; | ||
1019 | case ADDRS_DEMOD: | ||
1020 | return demod_addrs; | ||
1021 | case ADDRS_TV: | ||
1022 | return tv_addrs; | ||
1023 | case ADDRS_TV_WITH_DEMOD: | ||
1024 | return tv_addrs + 4; | ||
1025 | } | ||
1026 | return NULL; | ||
1027 | } | ||
1028 | EXPORT_SYMBOL_GPL(v4l2_i2c_tuner_addrs); | ||
1029 | |||
994 | #endif | 1030 | #endif |
diff --git a/include/media/v4l2-common.h b/include/media/v4l2-common.h index 95e74f1874e1..0f864f8daaf2 100644 --- a/include/media/v4l2-common.h +++ b/include/media/v4l2-common.h | |||
@@ -150,6 +150,19 @@ struct v4l2_subdev *v4l2_i2c_new_probed_subdev(struct i2c_adapter *adapter, | |||
150 | void v4l2_i2c_subdev_init(struct v4l2_subdev *sd, struct i2c_client *client, | 150 | void v4l2_i2c_subdev_init(struct v4l2_subdev *sd, struct i2c_client *client, |
151 | const struct v4l2_subdev_ops *ops); | 151 | const struct v4l2_subdev_ops *ops); |
152 | 152 | ||
153 | enum v4l2_i2c_tuner_type { | ||
154 | ADDRS_RADIO, /* Radio tuner addresses */ | ||
155 | ADDRS_DEMOD, /* Demod tuner addresses */ | ||
156 | ADDRS_TV, /* TV tuner addresses */ | ||
157 | /* TV tuner addresses if demod is present, this excludes | ||
158 | addresses used by the demodulator from the list of | ||
159 | candidates. */ | ||
160 | ADDRS_TV_WITH_DEMOD, | ||
161 | }; | ||
162 | /* Return a list of I2C tuner addresses to probe. Use only if the tuner | ||
163 | addresses are unknown. */ | ||
164 | const unsigned short *v4l2_i2c_tuner_addrs(enum v4l2_i2c_tuner_type type); | ||
165 | |||
153 | /* ------------------------------------------------------------------------- */ | 166 | /* ------------------------------------------------------------------------- */ |
154 | 167 | ||
155 | /* Internal ioctls */ | 168 | /* Internal ioctls */ |