aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/media/video/cx231xx/cx231xx-dvb.c
diff options
context:
space:
mode:
authorMauro Carvalho Chehab <mchehab@redhat.com>2010-09-27 22:44:27 -0400
committerMauro Carvalho Chehab <mchehab@redhat.com>2010-12-29 05:16:27 -0500
commitede676c72d0b18f1c15300f7874370e771489a1c (patch)
treec7dfdd1d5cab37a8e73dc7d6079a8b94f176f23e /drivers/media/video/cx231xx/cx231xx-dvb.c
parent9417bc6dd9de85944501f8f4ce8dd0e64135ca82 (diff)
[media] add digital support for PV SBTVD hybrid
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
Diffstat (limited to 'drivers/media/video/cx231xx/cx231xx-dvb.c')
-rw-r--r--drivers/media/video/cx231xx/cx231xx-dvb.c39
1 files changed, 39 insertions, 0 deletions
diff --git a/drivers/media/video/cx231xx/cx231xx-dvb.c b/drivers/media/video/cx231xx/cx231xx-dvb.c
index 5feb3ee640d9..b55e7e0bc245 100644
--- a/drivers/media/video/cx231xx/cx231xx-dvb.c
+++ b/drivers/media/video/cx231xx/cx231xx-dvb.c
@@ -33,6 +33,7 @@
33#include "tda18271.h" 33#include "tda18271.h"
34#include "s5h1411.h" 34#include "s5h1411.h"
35#include "lgdt3305.h" 35#include "lgdt3305.h"
36#include "mb86a20s.h"
36 37
37MODULE_DESCRIPTION("driver for cx231xx based DVB cards"); 38MODULE_DESCRIPTION("driver for cx231xx based DVB cards");
38MODULE_AUTHOR("Srinivasa Deevi <srinivasa.deevi@conexant.com>"); 39MODULE_AUTHOR("Srinivasa Deevi <srinivasa.deevi@conexant.com>");
@@ -88,6 +89,11 @@ static struct tda18271_std_map cnxt_rde253s_tda18271_std_map = {
88 .if_lvl = 1, .rfagc_top = 0x37, }, 89 .if_lvl = 1, .rfagc_top = 0x37, },
89}; 90};
90 91
92static struct tda18271_std_map mb86a20s_tda18271_config = {
93 .dvbt_6 = { .if_freq = 3300, .agc_mode = 3, .std = 4,
94 .if_lvl = 7, .rfagc_top = 0x37, },
95};
96
91static struct tda18271_config cnxt_rde253s_tunerconfig = { 97static struct tda18271_config cnxt_rde253s_tunerconfig = {
92 .std_map = &cnxt_rde253s_tda18271_std_map, 98 .std_map = &cnxt_rde253s_tda18271_std_map,
93 .gate = TDA18271_GATE_ANALOG, 99 .gate = TDA18271_GATE_ANALOG,
@@ -135,6 +141,16 @@ static struct tda18271_config hcw_tda18271_config = {
135 .gate = TDA18271_GATE_DIGITAL, 141 .gate = TDA18271_GATE_DIGITAL,
136}; 142};
137 143
144static const struct mb86a20s_config pv_mb86a20s_config = {
145 .demod_address = 0x10,
146};
147
148static struct tda18271_config pv_tda18271_config = {
149 .std_map = &mb86a20s_tda18271_config,
150 .gate = TDA18271_GATE_DIGITAL,
151 .small_i2c = TDA18271_03_BYTE_CHUNK_INIT,
152};
153
138static inline void print_err_status(struct cx231xx *dev, int packet, int status) 154static inline void print_err_status(struct cx231xx *dev, int packet, int status)
139{ 155{
140 char *errmsg = "Unknown"; 156 char *errmsg = "Unknown";
@@ -687,6 +703,29 @@ static int dvb_init(struct cx231xx *dev)
687 &hcw_tda18271_config); 703 &hcw_tda18271_config);
688 break; 704 break;
689 705
706 case CX231XX_BOARD_PV_PLAYTV_USB_HYBRID:
707
708 printk(KERN_INFO "%s: looking for demod on i2c bus: %d\n",
709 __func__, i2c_adapter_id(&dev->i2c_bus[dev->board.tuner_i2c_master].i2c_adap));
710
711 dev->dvb->frontend = dvb_attach(mb86a20s_attach,
712 &pv_mb86a20s_config,
713 &dev->i2c_bus[dev->board.demod_i2c_master].i2c_adap);
714
715 if (dev->dvb->frontend == NULL) {
716 printk(DRIVER_NAME
717 ": Failed to attach mb86a20s demod\n");
718 result = -EINVAL;
719 goto out_free;
720 }
721
722 /* define general-purpose callback pointer */
723 dvb->frontend->callback = cx231xx_tuner_callback;
724
725 dvb_attach(tda18271_attach, dev->dvb->frontend,
726 0x60, &dev->i2c_bus[dev->board.tuner_i2c_master].i2c_adap,
727 &pv_tda18271_config);
728 break;
690 729
691 default: 730 default:
692 printk(KERN_ERR "%s/2: The frontend of your DVB/ATSC card" 731 printk(KERN_ERR "%s/2: The frontend of your DVB/ATSC card"