V4L/DVB (3305): Added support for the ADS Instant TV DUO Cardbus PTV331
Analog and DVB-T are working, Remote not yet. This card is based on the new LifeView design, there should be many variants. Signed-off-by: Hartmut Hackmann <hartmut.hackmann@t-online.de> Signed-off-by: Mauro Carvalho Chehab <mchehab@infradead.org>
This commit is contained in:
parent
0eb3de20a1
commit
df42eaf2b2
4 changed files with 80 additions and 1 deletions
|
@ -85,3 +85,4 @@
|
||||||
84 -> LifeView FlyDVB Trio [5168:0319]
|
84 -> LifeView FlyDVB Trio [5168:0319]
|
||||||
85 -> AverTV DVB-T 777 [1461:2c05]
|
85 -> AverTV DVB-T 777 [1461:2c05]
|
||||||
86 -> LifeView FlyDVB-T [5168:0301]
|
86 -> LifeView FlyDVB-T [5168:0301]
|
||||||
|
87 -> ADS Instant TV Duo Cardbus PTV331 [0331:1421]
|
||||||
|
|
|
@ -2657,7 +2657,23 @@ struct saa7134_board saa7134_boards[] = {
|
||||||
.amux = LINE2,
|
.amux = LINE2,
|
||||||
}},
|
}},
|
||||||
},
|
},
|
||||||
|
[SAA7134_BOARD_ADS_DUO_CARDBUS_PTV331] = {
|
||||||
|
.name = "ADS Instant TV Duo Cardbus PTV331",
|
||||||
|
.audio_clock = 0x00200000,
|
||||||
|
.tuner_type = TUNER_PHILIPS_TDA8290,
|
||||||
|
.radio_type = UNSET,
|
||||||
|
.tuner_addr = ADDR_UNSET,
|
||||||
|
.radio_addr = ADDR_UNSET,
|
||||||
|
.mpeg = SAA7134_MPEG_DVB,
|
||||||
|
.gpiomask = 0x00600000, /* Bit 21 0=Radio, Bit 22 0=TV */
|
||||||
|
.inputs = {{
|
||||||
|
.name = name_tv,
|
||||||
|
.vmux = 1,
|
||||||
|
.amux = TV,
|
||||||
|
.tv = 1,
|
||||||
|
.gpio = 0x00200000,
|
||||||
|
}},
|
||||||
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
const unsigned int saa7134_bcount = ARRAY_SIZE(saa7134_boards);
|
const unsigned int saa7134_bcount = ARRAY_SIZE(saa7134_boards);
|
||||||
|
@ -3140,6 +3156,12 @@ struct pci_device_id saa7134_pci_tbl[] = {
|
||||||
.subvendor = 0x5168,
|
.subvendor = 0x5168,
|
||||||
.subdevice = 0x0301,
|
.subdevice = 0x0301,
|
||||||
.driver_data = SAA7134_BOARD_FLYDVBT_LR301,
|
.driver_data = SAA7134_BOARD_FLYDVBT_LR301,
|
||||||
|
},{
|
||||||
|
.vendor = PCI_VENDOR_ID_PHILIPS,
|
||||||
|
.device = PCI_DEVICE_ID_PHILIPS_SAA7133,
|
||||||
|
.subvendor = 0x0331,
|
||||||
|
.subdevice = 0x1421,
|
||||||
|
.driver_data = SAA7134_BOARD_ADS_DUO_CARDBUS_PTV331,
|
||||||
},{
|
},{
|
||||||
/* --- boards without eeprom + subsystem ID --- */
|
/* --- boards without eeprom + subsystem ID --- */
|
||||||
.vendor = PCI_VENDOR_ID_PHILIPS,
|
.vendor = PCI_VENDOR_ID_PHILIPS,
|
||||||
|
@ -3263,6 +3285,10 @@ int saa7134_board_init1(struct saa7134_dev *dev)
|
||||||
saa_writeb(SAA7134_GPIO_GPMODE3, 0x08);
|
saa_writeb(SAA7134_GPIO_GPMODE3, 0x08);
|
||||||
saa_writeb(SAA7134_GPIO_GPSTATUS3, 0x06);
|
saa_writeb(SAA7134_GPIO_GPSTATUS3, 0x06);
|
||||||
break;
|
break;
|
||||||
|
case SAA7134_BOARD_ADS_DUO_CARDBUS_PTV331:
|
||||||
|
saa_writeb(SAA7134_GPIO_GPMODE3, 0x08);
|
||||||
|
saa_writeb(SAA7134_GPIO_GPSTATUS3, 0x00);
|
||||||
|
break;
|
||||||
case SAA7134_BOARD_AVERMEDIA_CARDBUS:
|
case SAA7134_BOARD_AVERMEDIA_CARDBUS:
|
||||||
/* power-up tuner chip */
|
/* power-up tuner chip */
|
||||||
saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, 0xffffffff, 0xffffffff);
|
saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, 0xffffffff, 0xffffffff);
|
||||||
|
@ -3413,6 +3439,14 @@ int saa7134_board_init2(struct saa7134_dev *dev)
|
||||||
i2c_transfer(&dev->i2c_adap, &msg, 1);
|
i2c_transfer(&dev->i2c_adap, &msg, 1);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
case SAA7134_BOARD_ADS_DUO_CARDBUS_PTV331:
|
||||||
|
/* make the tda10046 find its eeprom */
|
||||||
|
{
|
||||||
|
u8 data[] = { 0x3c, 0x33, 0x62};
|
||||||
|
struct i2c_msg msg = {.addr=0x08, .flags=0, .buf=data, .len = sizeof(data)};
|
||||||
|
i2c_transfer(&dev->i2c_adap, &msg, 1);
|
||||||
|
}
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
|
@ -846,6 +846,45 @@ static struct tda1004x_config philips_tiger_config = {
|
||||||
.request_firmware = NULL,
|
.request_firmware = NULL,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/* ------------------------------------------------------------------ */
|
||||||
|
|
||||||
|
static int ads_duo_pll_set(struct dvb_frontend *fe, struct dvb_frontend_parameters *params)
|
||||||
|
{
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
ret = philips_tda827xa_pll_set(0x61, fe, params);
|
||||||
|
return ret;
|
||||||
|
};
|
||||||
|
|
||||||
|
static int ads_duo_dvb_mode(struct dvb_frontend *fe)
|
||||||
|
{
|
||||||
|
struct saa7134_dev *dev = fe->dvb->priv;
|
||||||
|
/* route TDA8275a AGC input to the channel decoder */
|
||||||
|
saa_writeb(SAA7134_GPIO_GPSTATUS2, 0x60);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void ads_duo_analog_mode(struct dvb_frontend *fe)
|
||||||
|
{
|
||||||
|
struct saa7134_dev *dev = fe->dvb->priv;
|
||||||
|
/* route TDA8275a AGC input to the analog IF chip*/
|
||||||
|
saa_writeb(SAA7134_GPIO_GPSTATUS2, 0x20);
|
||||||
|
philips_tda827xa_pll_sleep( 0x61, fe);
|
||||||
|
}
|
||||||
|
|
||||||
|
static struct tda1004x_config ads_tech_duo_config = {
|
||||||
|
.demod_address = 0x08,
|
||||||
|
.invert = 1,
|
||||||
|
.invert_oclk = 0,
|
||||||
|
.xtal_freq = TDA10046_XTAL_16M,
|
||||||
|
.agc_config = TDA10046_AGC_TDA827X_GPL,
|
||||||
|
.if_freq = TDA10046_FREQ_045,
|
||||||
|
.pll_init = ads_duo_dvb_mode,
|
||||||
|
.pll_set = ads_duo_pll_set,
|
||||||
|
.pll_sleep = ads_duo_analog_mode,
|
||||||
|
.request_firmware = NULL,
|
||||||
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
/* ------------------------------------------------------------------ */
|
/* ------------------------------------------------------------------ */
|
||||||
|
@ -928,6 +967,10 @@ static int dvb_init(struct saa7134_dev *dev)
|
||||||
dev->dvb.frontend = tda10046_attach(&tda827x_lifeview_config,
|
dev->dvb.frontend = tda10046_attach(&tda827x_lifeview_config,
|
||||||
&dev->i2c_adap);
|
&dev->i2c_adap);
|
||||||
break;
|
break;
|
||||||
|
case SAA7134_BOARD_ADS_DUO_CARDBUS_PTV331:
|
||||||
|
dev->dvb.frontend = tda10046_attach(&ads_tech_duo_config,
|
||||||
|
&dev->i2c_adap);
|
||||||
|
break;
|
||||||
#endif
|
#endif
|
||||||
#ifdef HAVE_NXT200X
|
#ifdef HAVE_NXT200X
|
||||||
case SAA7134_BOARD_AVERMEDIA_AVERTVHD_A180:
|
case SAA7134_BOARD_AVERMEDIA_AVERTVHD_A180:
|
||||||
|
|
|
@ -213,6 +213,7 @@ struct saa7134_format {
|
||||||
#define SAA7134_BOARD_FLYDVB_TRIO 84
|
#define SAA7134_BOARD_FLYDVB_TRIO 84
|
||||||
#define SAA7134_BOARD_AVERMEDIA_777 85
|
#define SAA7134_BOARD_AVERMEDIA_777 85
|
||||||
#define SAA7134_BOARD_FLYDVBT_LR301 86
|
#define SAA7134_BOARD_FLYDVBT_LR301 86
|
||||||
|
#define SAA7134_BOARD_ADS_DUO_CARDBUS_PTV331 87
|
||||||
|
|
||||||
#define SAA7134_MAXBOARDS 8
|
#define SAA7134_MAXBOARDS 8
|
||||||
#define SAA7134_INPUT_MAX 8
|
#define SAA7134_INPUT_MAX 8
|
||||||
|
|
Loading…
Add table
Reference in a new issue