2005-04-17 06:20:36 +08:00
|
|
|
/*
|
|
|
|
*
|
|
|
|
* device driver for Conexant 2388x based TV cards
|
|
|
|
* MPEG Transport Stream (DVB) routines
|
|
|
|
*
|
2006-01-10 01:25:35 +08:00
|
|
|
* (c) 2004, 2005 Chris Pascoe <c.pascoe@itee.uq.edu.au>
|
2005-04-17 06:20:36 +08:00
|
|
|
* (c) 2004 Gerd Knorr <kraxel@bytesex.org> [SuSE Labs]
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation; either version 2 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include <linux/module.h>
|
|
|
|
#include <linux/init.h>
|
|
|
|
#include <linux/device.h>
|
|
|
|
#include <linux/fs.h>
|
|
|
|
#include <linux/kthread.h>
|
|
|
|
#include <linux/file.h>
|
|
|
|
#include <linux/suspend.h>
|
|
|
|
|
|
|
|
#include "cx88.h"
|
|
|
|
#include "dvb-pll.h"
|
2006-01-10 01:32:31 +08:00
|
|
|
#include <media/v4l2-common.h>
|
2005-07-13 04:58:44 +08:00
|
|
|
|
2006-08-08 20:10:09 +08:00
|
|
|
#include "mt352.h"
|
|
|
|
#include "mt352_priv.h"
|
2007-05-06 07:11:32 +08:00
|
|
|
#include "cx88-vp3054-i2c.h"
|
2006-08-08 20:10:09 +08:00
|
|
|
#include "zl10353.h"
|
|
|
|
#include "cx22702.h"
|
|
|
|
#include "or51132.h"
|
|
|
|
#include "lgdt330x.h"
|
2008-01-06 03:53:01 +08:00
|
|
|
#include "s5h1409.h"
|
|
|
|
#include "xc5000.h"
|
2006-08-08 20:10:09 +08:00
|
|
|
#include "nxt200x.h"
|
|
|
|
#include "cx24123.h"
|
2006-05-13 07:31:51 +08:00
|
|
|
#include "isl6421.h"
|
2008-04-23 01:46:13 +08:00
|
|
|
#include "tuner-simple.h"
|
2008-04-23 01:46:16 +08:00
|
|
|
#include "tda9887.h"
|
2008-04-25 14:46:43 +08:00
|
|
|
#include "s5h1411.h"
|
2008-09-24 02:43:57 +08:00
|
|
|
#include "stv0299.h"
|
|
|
|
#include "z0194a.h"
|
|
|
|
#include "stv0288.h"
|
|
|
|
#include "stb6000.h"
|
2008-09-04 12:17:33 +08:00
|
|
|
#include "cx24116.h"
|
2005-04-17 06:20:36 +08:00
|
|
|
|
|
|
|
MODULE_DESCRIPTION("driver for cx2388x based DVB cards");
|
|
|
|
MODULE_AUTHOR("Chris Pascoe <c.pascoe@itee.uq.edu.au>");
|
|
|
|
MODULE_AUTHOR("Gerd Knorr <kraxel@bytesex.org> [SuSE Labs]");
|
|
|
|
MODULE_LICENSE("GPL");
|
|
|
|
|
2008-04-23 01:41:48 +08:00
|
|
|
static unsigned int debug;
|
2005-04-17 06:20:36 +08:00
|
|
|
module_param(debug, int, 0644);
|
|
|
|
MODULE_PARM_DESC(debug,"enable debug messages [dvb]");
|
|
|
|
|
2008-04-10 06:13:13 +08:00
|
|
|
DVB_DEFINE_MOD_OPT_ADAPTER_NR(adapter_nr);
|
|
|
|
|
2005-04-17 06:20:36 +08:00
|
|
|
#define dprintk(level,fmt, arg...) if (debug >= level) \
|
2006-12-03 07:15:51 +08:00
|
|
|
printk(KERN_DEBUG "%s/2-dvb: " fmt, core->name, ## arg)
|
2005-04-17 06:20:36 +08:00
|
|
|
|
|
|
|
/* ------------------------------------------------------------------ */
|
|
|
|
|
|
|
|
static int dvb_buf_setup(struct videobuf_queue *q,
|
|
|
|
unsigned int *count, unsigned int *size)
|
|
|
|
{
|
|
|
|
struct cx8802_dev *dev = q->priv_data;
|
|
|
|
|
|
|
|
dev->ts_packet_size = 188 * 4;
|
|
|
|
dev->ts_packet_count = 32;
|
|
|
|
|
|
|
|
*size = dev->ts_packet_size * dev->ts_packet_count;
|
|
|
|
*count = 32;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2006-12-05 13:00:53 +08:00
|
|
|
static int dvb_buf_prepare(struct videobuf_queue *q,
|
|
|
|
struct videobuf_buffer *vb, enum v4l2_field field)
|
2005-04-17 06:20:36 +08:00
|
|
|
{
|
|
|
|
struct cx8802_dev *dev = q->priv_data;
|
2006-03-10 23:29:15 +08:00
|
|
|
return cx8802_buf_prepare(q, dev, (struct cx88_buffer*)vb,field);
|
2005-04-17 06:20:36 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
static void dvb_buf_queue(struct videobuf_queue *q, struct videobuf_buffer *vb)
|
|
|
|
{
|
|
|
|
struct cx8802_dev *dev = q->priv_data;
|
|
|
|
cx8802_buf_queue(dev, (struct cx88_buffer*)vb);
|
|
|
|
}
|
|
|
|
|
2006-12-05 13:00:53 +08:00
|
|
|
static void dvb_buf_release(struct videobuf_queue *q,
|
|
|
|
struct videobuf_buffer *vb)
|
2005-04-17 06:20:36 +08:00
|
|
|
{
|
2006-03-10 23:29:15 +08:00
|
|
|
cx88_free_buffer(q, (struct cx88_buffer*)vb);
|
2005-04-17 06:20:36 +08:00
|
|
|
}
|
|
|
|
|
2005-05-01 23:59:29 +08:00
|
|
|
static struct videobuf_queue_ops dvb_qops = {
|
2005-04-17 06:20:36 +08:00
|
|
|
.buf_setup = dvb_buf_setup,
|
|
|
|
.buf_prepare = dvb_buf_prepare,
|
|
|
|
.buf_queue = dvb_buf_queue,
|
|
|
|
.buf_release = dvb_buf_release,
|
|
|
|
};
|
|
|
|
|
|
|
|
/* ------------------------------------------------------------------ */
|
2006-12-05 12:38:58 +08:00
|
|
|
|
|
|
|
static int cx88_dvb_bus_ctrl(struct dvb_frontend* fe, int acquire)
|
|
|
|
{
|
|
|
|
struct cx8802_dev *dev= fe->dvb->priv;
|
|
|
|
struct cx8802_driver *drv = NULL;
|
|
|
|
int ret = 0;
|
2008-10-11 22:05:50 +08:00
|
|
|
int fe_id;
|
|
|
|
|
|
|
|
fe_id = videobuf_dvb_find_frontend(&dev->frontends, fe);
|
|
|
|
if (!fe_id) {
|
2008-10-17 07:17:31 +08:00
|
|
|
printk(KERN_ERR "%s() No frontend found\n", __func__);
|
2008-10-11 22:05:50 +08:00
|
|
|
return -EINVAL;
|
|
|
|
}
|
|
|
|
|
2006-12-05 12:38:58 +08:00
|
|
|
drv = cx8802_get_driver(dev, CX88_MPEG_DVB);
|
|
|
|
if (drv) {
|
2008-10-11 22:05:50 +08:00
|
|
|
if (acquire){
|
|
|
|
dev->frontends.active_fe_id = fe_id;
|
2006-12-05 12:38:58 +08:00
|
|
|
ret = drv->request_acquire(drv);
|
2008-10-11 22:05:50 +08:00
|
|
|
} else {
|
2006-12-05 12:38:58 +08:00
|
|
|
ret = drv->request_release(drv);
|
2008-10-11 22:05:50 +08:00
|
|
|
dev->frontends.active_fe_id = 0;
|
|
|
|
}
|
2006-12-05 12:38:58 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* ------------------------------------------------------------------ */
|
|
|
|
|
2006-01-10 04:21:31 +08:00
|
|
|
static int dvico_fusionhdtv_demod_init(struct dvb_frontend* fe)
|
2005-04-17 06:20:36 +08:00
|
|
|
{
|
|
|
|
static u8 clock_config [] = { CLOCK_CTL, 0x38, 0x39 };
|
|
|
|
static u8 reset [] = { RESET, 0x80 };
|
|
|
|
static u8 adc_ctl_1_cfg [] = { ADC_CTL_1, 0x40 };
|
|
|
|
static u8 agc_cfg [] = { AGC_TARGET, 0x24, 0x20 };
|
|
|
|
static u8 gpp_ctl_cfg [] = { GPP_CTL, 0x33 };
|
|
|
|
static u8 capt_range_cfg[] = { CAPT_RANGE, 0x32 };
|
|
|
|
|
|
|
|
mt352_write(fe, clock_config, sizeof(clock_config));
|
|
|
|
udelay(200);
|
|
|
|
mt352_write(fe, reset, sizeof(reset));
|
|
|
|
mt352_write(fe, adc_ctl_1_cfg, sizeof(adc_ctl_1_cfg));
|
|
|
|
|
|
|
|
mt352_write(fe, agc_cfg, sizeof(agc_cfg));
|
|
|
|
mt352_write(fe, gpp_ctl_cfg, sizeof(gpp_ctl_cfg));
|
|
|
|
mt352_write(fe, capt_range_cfg, sizeof(capt_range_cfg));
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2006-01-10 04:21:28 +08:00
|
|
|
static int dvico_dual_demod_init(struct dvb_frontend *fe)
|
|
|
|
{
|
|
|
|
static u8 clock_config [] = { CLOCK_CTL, 0x38, 0x38 };
|
|
|
|
static u8 reset [] = { RESET, 0x80 };
|
|
|
|
static u8 adc_ctl_1_cfg [] = { ADC_CTL_1, 0x40 };
|
|
|
|
static u8 agc_cfg [] = { AGC_TARGET, 0x28, 0x20 };
|
|
|
|
static u8 gpp_ctl_cfg [] = { GPP_CTL, 0x33 };
|
|
|
|
static u8 capt_range_cfg[] = { CAPT_RANGE, 0x32 };
|
|
|
|
|
|
|
|
mt352_write(fe, clock_config, sizeof(clock_config));
|
|
|
|
udelay(200);
|
|
|
|
mt352_write(fe, reset, sizeof(reset));
|
|
|
|
mt352_write(fe, adc_ctl_1_cfg, sizeof(adc_ctl_1_cfg));
|
|
|
|
|
|
|
|
mt352_write(fe, agc_cfg, sizeof(agc_cfg));
|
|
|
|
mt352_write(fe, gpp_ctl_cfg, sizeof(gpp_ctl_cfg));
|
|
|
|
mt352_write(fe, capt_range_cfg, sizeof(capt_range_cfg));
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2005-04-17 06:20:36 +08:00
|
|
|
static int dntv_live_dvbt_demod_init(struct dvb_frontend* fe)
|
|
|
|
{
|
|
|
|
static u8 clock_config [] = { 0x89, 0x38, 0x39 };
|
|
|
|
static u8 reset [] = { 0x50, 0x80 };
|
|
|
|
static u8 adc_ctl_1_cfg [] = { 0x8E, 0x40 };
|
|
|
|
static u8 agc_cfg [] = { 0x67, 0x10, 0x23, 0x00, 0xFF, 0xFF,
|
2005-11-09 13:37:45 +08:00
|
|
|
0x00, 0xFF, 0x00, 0x40, 0x40 };
|
2005-04-17 06:20:36 +08:00
|
|
|
static u8 dntv_extra[] = { 0xB5, 0x7A };
|
|
|
|
static u8 capt_range_cfg[] = { 0x75, 0x32 };
|
|
|
|
|
|
|
|
mt352_write(fe, clock_config, sizeof(clock_config));
|
|
|
|
udelay(2000);
|
|
|
|
mt352_write(fe, reset, sizeof(reset));
|
|
|
|
mt352_write(fe, adc_ctl_1_cfg, sizeof(adc_ctl_1_cfg));
|
|
|
|
|
|
|
|
mt352_write(fe, agc_cfg, sizeof(agc_cfg));
|
|
|
|
udelay(2000);
|
|
|
|
mt352_write(fe, dntv_extra, sizeof(dntv_extra));
|
|
|
|
mt352_write(fe, capt_range_cfg, sizeof(capt_range_cfg));
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static struct mt352_config dvico_fusionhdtv = {
|
2006-08-09 02:48:08 +08:00
|
|
|
.demod_address = 0x0f,
|
2006-01-10 04:21:31 +08:00
|
|
|
.demod_init = dvico_fusionhdtv_demod_init,
|
2005-04-17 06:20:36 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
static struct mt352_config dntv_live_dvbt_config = {
|
|
|
|
.demod_address = 0x0f,
|
|
|
|
.demod_init = dntv_live_dvbt_demod_init,
|
|
|
|
};
|
2006-01-10 01:25:35 +08:00
|
|
|
|
2006-01-10 04:21:28 +08:00
|
|
|
static struct mt352_config dvico_fusionhdtv_dual = {
|
2006-08-09 02:48:08 +08:00
|
|
|
.demod_address = 0x0f,
|
2006-01-10 04:21:28 +08:00
|
|
|
.demod_init = dvico_dual_demod_init,
|
|
|
|
};
|
|
|
|
|
2007-05-06 07:11:32 +08:00
|
|
|
#if defined(CONFIG_VIDEO_CX88_VP3054) || (defined(CONFIG_VIDEO_CX88_VP3054_MODULE) && defined(MODULE))
|
2006-01-10 04:21:31 +08:00
|
|
|
static int dntv_live_dvbt_pro_demod_init(struct dvb_frontend* fe)
|
|
|
|
{
|
|
|
|
static u8 clock_config [] = { 0x89, 0x38, 0x38 };
|
|
|
|
static u8 reset [] = { 0x50, 0x80 };
|
|
|
|
static u8 adc_ctl_1_cfg [] = { 0x8E, 0x40 };
|
|
|
|
static u8 agc_cfg [] = { 0x67, 0x10, 0x20, 0x00, 0xFF, 0xFF,
|
|
|
|
0x00, 0xFF, 0x00, 0x40, 0x40 };
|
|
|
|
static u8 dntv_extra[] = { 0xB5, 0x7A };
|
|
|
|
static u8 capt_range_cfg[] = { 0x75, 0x32 };
|
|
|
|
|
|
|
|
mt352_write(fe, clock_config, sizeof(clock_config));
|
|
|
|
udelay(2000);
|
|
|
|
mt352_write(fe, reset, sizeof(reset));
|
|
|
|
mt352_write(fe, adc_ctl_1_cfg, sizeof(adc_ctl_1_cfg));
|
|
|
|
|
|
|
|
mt352_write(fe, agc_cfg, sizeof(agc_cfg));
|
|
|
|
udelay(2000);
|
|
|
|
mt352_write(fe, dntv_extra, sizeof(dntv_extra));
|
|
|
|
mt352_write(fe, capt_range_cfg, sizeof(capt_range_cfg));
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2006-01-10 01:25:35 +08:00
|
|
|
static struct mt352_config dntv_live_dvbt_pro_config = {
|
|
|
|
.demod_address = 0x0f,
|
|
|
|
.no_tuner = 1,
|
2006-01-10 04:21:31 +08:00
|
|
|
.demod_init = dntv_live_dvbt_pro_demod_init,
|
2006-01-10 01:25:35 +08:00
|
|
|
};
|
|
|
|
#endif
|
2005-04-17 06:20:36 +08:00
|
|
|
|
2006-02-28 19:34:59 +08:00
|
|
|
static struct zl10353_config dvico_fusionhdtv_hybrid = {
|
2006-08-09 02:48:08 +08:00
|
|
|
.demod_address = 0x0f,
|
2006-04-19 04:56:10 +08:00
|
|
|
.no_tuner = 1,
|
2006-02-28 19:34:59 +08:00
|
|
|
};
|
|
|
|
|
2008-04-23 01:45:15 +08:00
|
|
|
static struct zl10353_config dvico_fusionhdtv_xc3028 = {
|
|
|
|
.demod_address = 0x0f,
|
|
|
|
.if2 = 45600,
|
|
|
|
.no_tuner = 1,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct mt352_config dvico_fusionhdtv_mt352_xc3028 = {
|
|
|
|
.demod_address = 0x0f,
|
|
|
|
.if2 = 4560,
|
|
|
|
.no_tuner = 1,
|
|
|
|
.demod_init = dvico_fusionhdtv_demod_init,
|
|
|
|
};
|
|
|
|
|
2006-02-28 19:34:59 +08:00
|
|
|
static struct zl10353_config dvico_fusionhdtv_plus_v1_1 = {
|
2006-08-09 02:48:08 +08:00
|
|
|
.demod_address = 0x0f,
|
2006-02-28 19:34:59 +08:00
|
|
|
};
|
|
|
|
|
2005-04-17 06:20:36 +08:00
|
|
|
static struct cx22702_config connexant_refboard_config = {
|
|
|
|
.demod_address = 0x43,
|
2005-07-16 03:20:26 +08:00
|
|
|
.output_mode = CX22702_SERIAL_OUTPUT,
|
2005-04-17 06:20:36 +08:00
|
|
|
};
|
|
|
|
|
2006-12-05 12:34:56 +08:00
|
|
|
static struct cx22702_config hauppauge_hvr_config = {
|
2006-09-15 02:41:13 +08:00
|
|
|
.demod_address = 0x63,
|
|
|
|
.output_mode = CX22702_SERIAL_OUTPUT,
|
|
|
|
};
|
2005-04-17 06:20:36 +08:00
|
|
|
|
2006-12-05 13:00:53 +08:00
|
|
|
static int or51132_set_ts_param(struct dvb_frontend* fe, int is_punctured)
|
2005-04-17 06:20:36 +08:00
|
|
|
{
|
|
|
|
struct cx8802_dev *dev= fe->dvb->priv;
|
|
|
|
dev->ts_gen_cntrl = is_punctured ? 0x04 : 0x00;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2005-05-01 23:59:29 +08:00
|
|
|
static struct or51132_config pchdtv_hd3000 = {
|
2006-08-09 02:48:08 +08:00
|
|
|
.demod_address = 0x15,
|
|
|
|
.set_ts_params = or51132_set_ts_param,
|
2005-04-17 06:20:36 +08:00
|
|
|
};
|
|
|
|
|
2005-07-28 02:46:00 +08:00
|
|
|
static int lgdt330x_pll_rf_set(struct dvb_frontend* fe, int index)
|
2005-07-28 02:45:55 +08:00
|
|
|
{
|
|
|
|
struct cx8802_dev *dev= fe->dvb->priv;
|
|
|
|
struct cx88_core *core = dev->core;
|
|
|
|
|
2008-04-09 10:20:00 +08:00
|
|
|
dprintk(1, "%s: index = %d\n", __func__, index);
|
2005-07-28 02:45:55 +08:00
|
|
|
if (index == 0)
|
|
|
|
cx_clear(MO_GP0_IO, 8);
|
|
|
|
else
|
|
|
|
cx_set(MO_GP0_IO, 8);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2005-07-28 02:46:00 +08:00
|
|
|
static int lgdt330x_set_ts_param(struct dvb_frontend* fe, int is_punctured)
|
2005-07-08 08:58:39 +08:00
|
|
|
{
|
|
|
|
struct cx8802_dev *dev= fe->dvb->priv;
|
|
|
|
if (is_punctured)
|
|
|
|
dev->ts_gen_cntrl |= 0x04;
|
|
|
|
else
|
|
|
|
dev->ts_gen_cntrl &= ~0x04;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2005-07-28 02:46:00 +08:00
|
|
|
static struct lgdt330x_config fusionhdtv_3_gold = {
|
2006-08-09 02:48:08 +08:00
|
|
|
.demod_address = 0x0e,
|
|
|
|
.demod_chip = LGDT3302,
|
|
|
|
.serial_mpeg = 0x04, /* TPSERIAL for 3302 in TOP_CONTROL */
|
|
|
|
.set_ts_params = lgdt330x_set_ts_param,
|
2005-07-08 08:58:42 +08:00
|
|
|
};
|
2005-09-10 04:03:41 +08:00
|
|
|
|
|
|
|
static struct lgdt330x_config fusionhdtv_5_gold = {
|
2006-08-09 02:48:08 +08:00
|
|
|
.demod_address = 0x0e,
|
|
|
|
.demod_chip = LGDT3303,
|
|
|
|
.serial_mpeg = 0x40, /* TPSERIAL for 3303 in TOP_CONTROL */
|
|
|
|
.set_ts_params = lgdt330x_set_ts_param,
|
2005-09-10 04:03:41 +08:00
|
|
|
};
|
2006-04-07 13:21:31 +08:00
|
|
|
|
|
|
|
static struct lgdt330x_config pchdtv_hd5500 = {
|
2006-08-09 02:48:08 +08:00
|
|
|
.demod_address = 0x59,
|
|
|
|
.demod_chip = LGDT3303,
|
|
|
|
.serial_mpeg = 0x40, /* TPSERIAL for 3303 in TOP_CONTROL */
|
|
|
|
.set_ts_params = lgdt330x_set_ts_param,
|
2006-04-07 13:21:31 +08:00
|
|
|
};
|
2005-07-08 08:58:39 +08:00
|
|
|
|
2006-12-05 13:00:53 +08:00
|
|
|
static int nxt200x_set_ts_param(struct dvb_frontend* fe, int is_punctured)
|
2005-11-09 13:38:18 +08:00
|
|
|
{
|
|
|
|
struct cx8802_dev *dev= fe->dvb->priv;
|
|
|
|
dev->ts_gen_cntrl = is_punctured ? 0x04 : 0x00;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static struct nxt200x_config ati_hdtvwonder = {
|
2006-08-09 02:48:08 +08:00
|
|
|
.demod_address = 0x0a,
|
|
|
|
.set_ts_params = nxt200x_set_ts_param,
|
2005-11-09 13:38:18 +08:00
|
|
|
};
|
|
|
|
|
2006-01-10 01:25:02 +08:00
|
|
|
static int cx24123_set_ts_param(struct dvb_frontend* fe,
|
|
|
|
int is_punctured)
|
|
|
|
{
|
|
|
|
struct cx8802_dev *dev= fe->dvb->priv;
|
2006-08-09 02:48:08 +08:00
|
|
|
dev->ts_gen_cntrl = 0x02;
|
2006-01-10 01:25:02 +08:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2006-08-09 02:48:08 +08:00
|
|
|
static int kworld_dvbs_100_set_voltage(struct dvb_frontend* fe,
|
|
|
|
fe_sec_voltage_t voltage)
|
2006-01-10 01:25:02 +08:00
|
|
|
{
|
|
|
|
struct cx8802_dev *dev= fe->dvb->priv;
|
|
|
|
struct cx88_core *core = dev->core;
|
|
|
|
|
2006-12-05 13:00:53 +08:00
|
|
|
if (voltage == SEC_VOLTAGE_OFF)
|
2006-08-09 02:48:08 +08:00
|
|
|
cx_write(MO_GP0_IO, 0x000006fb);
|
2006-12-05 13:00:53 +08:00
|
|
|
else
|
2006-05-13 07:31:51 +08:00
|
|
|
cx_write(MO_GP0_IO, 0x000006f9);
|
|
|
|
|
|
|
|
if (core->prev_set_voltage)
|
|
|
|
return core->prev_set_voltage(fe, voltage);
|
|
|
|
return 0;
|
2006-01-10 01:25:02 +08:00
|
|
|
}
|
|
|
|
|
2006-08-09 02:48:08 +08:00
|
|
|
static int geniatech_dvbs_set_voltage(struct dvb_frontend *fe,
|
|
|
|
fe_sec_voltage_t voltage)
|
2006-06-30 07:29:33 +08:00
|
|
|
{
|
|
|
|
struct cx8802_dev *dev= fe->dvb->priv;
|
|
|
|
struct cx88_core *core = dev->core;
|
|
|
|
|
|
|
|
if (voltage == SEC_VOLTAGE_OFF) {
|
|
|
|
dprintk(1,"LNB Voltage OFF\n");
|
|
|
|
cx_write(MO_GP0_IO, 0x0000efff);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (core->prev_set_voltage)
|
|
|
|
return core->prev_set_voltage(fe, voltage);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2008-09-05 04:24:14 +08:00
|
|
|
static int tevii_dvbs_set_voltage(struct dvb_frontend *fe,
|
|
|
|
fe_sec_voltage_t voltage)
|
|
|
|
{
|
|
|
|
struct cx8802_dev *dev= fe->dvb->priv;
|
|
|
|
struct cx88_core *core = dev->core;
|
|
|
|
|
|
|
|
switch (voltage) {
|
|
|
|
case SEC_VOLTAGE_13:
|
|
|
|
printk("LNB Voltage SEC_VOLTAGE_13\n");
|
|
|
|
cx_write(MO_GP0_IO, 0x00006040);
|
|
|
|
break;
|
|
|
|
case SEC_VOLTAGE_18:
|
|
|
|
printk("LNB Voltage SEC_VOLTAGE_18\n");
|
|
|
|
cx_write(MO_GP0_IO, 0x00006060);
|
|
|
|
break;
|
|
|
|
case SEC_VOLTAGE_OFF:
|
2008-11-11 09:35:00 +08:00
|
|
|
printk("LNB Voltage SEC_VOLTAGE_off\n");
|
2008-09-05 04:24:14 +08:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (core->prev_set_voltage)
|
|
|
|
return core->prev_set_voltage(fe, voltage);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2006-06-30 07:29:33 +08:00
|
|
|
static struct cx24123_config geniatech_dvbs_config = {
|
2006-08-09 02:48:08 +08:00
|
|
|
.demod_address = 0x55,
|
|
|
|
.set_ts_params = cx24123_set_ts_param,
|
2006-06-30 07:29:33 +08:00
|
|
|
};
|
|
|
|
|
2006-01-10 01:25:02 +08:00
|
|
|
static struct cx24123_config hauppauge_novas_config = {
|
2006-08-09 02:48:08 +08:00
|
|
|
.demod_address = 0x55,
|
|
|
|
.set_ts_params = cx24123_set_ts_param,
|
2006-01-10 01:25:02 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
static struct cx24123_config kworld_dvbs_100_config = {
|
2006-08-09 02:48:08 +08:00
|
|
|
.demod_address = 0x15,
|
|
|
|
.set_ts_params = cx24123_set_ts_param,
|
2006-09-26 23:30:14 +08:00
|
|
|
.lnb_polarity = 1,
|
2006-01-10 01:25:02 +08:00
|
|
|
};
|
|
|
|
|
2008-01-06 03:53:01 +08:00
|
|
|
static struct s5h1409_config pinnacle_pctv_hd_800i_config = {
|
|
|
|
.demod_address = 0x32 >> 1,
|
|
|
|
.output_mode = S5H1409_PARALLEL_OUTPUT,
|
|
|
|
.gpio = S5H1409_GPIO_ON,
|
|
|
|
.qam_if = 44000,
|
|
|
|
.inversion = S5H1409_INVERSION_OFF,
|
|
|
|
.status_mode = S5H1409_DEMODLOCKING,
|
2008-01-16 08:57:14 +08:00
|
|
|
.mpeg_timing = S5H1409_MPEGTIMING_NONCONTINOUS_NONINVERTING_CLOCK,
|
2008-01-06 03:53:01 +08:00
|
|
|
};
|
|
|
|
|
2008-04-23 01:45:14 +08:00
|
|
|
static struct s5h1409_config dvico_hdtv5_pci_nano_config = {
|
|
|
|
.demod_address = 0x32 >> 1,
|
|
|
|
.output_mode = S5H1409_SERIAL_OUTPUT,
|
|
|
|
.gpio = S5H1409_GPIO_OFF,
|
|
|
|
.inversion = S5H1409_INVERSION_OFF,
|
|
|
|
.status_mode = S5H1409_DEMODLOCKING,
|
|
|
|
.mpeg_timing = S5H1409_MPEGTIMING_CONTINOUS_NONINVERTING_CLOCK,
|
|
|
|
};
|
|
|
|
|
V4L/DVB (7448): Add support for Kworld ATSC 120
This board has a s5h1409 demod, plus a xc30x8 tuner (probably, xc3018).
This patch adds proper support for radio, video, s-video, composite and ATSC.
However, support for radio and video depends on having s5h1409 i2c gate open,
otherwise, xc30x8 chip won't be visible.
For a better support, some rework is needed on cx88 driver, to allow adding
xc30x8 to i2c bus without sending i2c 0 byte reading to 0xc2 address.
Thanks to Vanessa Ezekowitz <vanessaezekowitz@gmail.com> for helping to figure
out the proper parameters for s5h1409 and the GPIO pins used by each
configuration.
Signed-off-by: Mauro Carvalho Chehab <mchehab@infradead.org>
2008-03-28 10:18:30 +08:00
|
|
|
static struct s5h1409_config kworld_atsc_120_config = {
|
|
|
|
.demod_address = 0x32 >> 1,
|
|
|
|
.output_mode = S5H1409_SERIAL_OUTPUT,
|
|
|
|
.gpio = S5H1409_GPIO_OFF,
|
|
|
|
.inversion = S5H1409_INVERSION_OFF,
|
|
|
|
.status_mode = S5H1409_DEMODLOCKING,
|
|
|
|
.mpeg_timing = S5H1409_MPEGTIMING_CONTINOUS_NONINVERTING_CLOCK,
|
|
|
|
};
|
|
|
|
|
2008-01-06 03:53:01 +08:00
|
|
|
static struct xc5000_config pinnacle_pctv_hd_800i_tuner_config = {
|
|
|
|
.i2c_address = 0x64,
|
|
|
|
.if_khz = 5380,
|
|
|
|
};
|
|
|
|
|
2008-09-06 01:33:54 +08:00
|
|
|
static struct zl10353_config cx88_pinnacle_hybrid_pctv = {
|
|
|
|
.demod_address = (0x1e >> 1),
|
|
|
|
.no_tuner = 1,
|
|
|
|
.if2 = 45600,
|
|
|
|
};
|
|
|
|
|
2008-04-23 01:45:15 +08:00
|
|
|
static struct zl10353_config cx88_geniatech_x8000_mt = {
|
|
|
|
.demod_address = (0x1e >> 1),
|
|
|
|
.no_tuner = 1,
|
|
|
|
};
|
|
|
|
|
2008-04-25 14:46:43 +08:00
|
|
|
static struct s5h1411_config dvico_fusionhdtv7_config = {
|
|
|
|
.output_mode = S5H1411_SERIAL_OUTPUT,
|
|
|
|
.gpio = S5H1411_GPIO_ON,
|
|
|
|
.mpeg_timing = S5H1411_MPEGTIMING_CONTINOUS_NONINVERTING_CLOCK,
|
|
|
|
.qam_if = S5H1411_IF_44000,
|
|
|
|
.vsb_if = S5H1411_IF_44000,
|
|
|
|
.inversion = S5H1411_INVERSION_OFF,
|
|
|
|
.status_mode = S5H1411_DEMODLOCKING
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct xc5000_config dvico_fusionhdtv7_tuner_config = {
|
|
|
|
.i2c_address = 0xc2 >> 1,
|
|
|
|
.if_khz = 5380,
|
|
|
|
};
|
|
|
|
|
2008-04-23 01:45:30 +08:00
|
|
|
static int attach_xc3028(u8 addr, struct cx8802_dev *dev)
|
|
|
|
{
|
|
|
|
struct dvb_frontend *fe;
|
2008-10-11 22:05:50 +08:00
|
|
|
struct videobuf_dvb_frontend *fe0 = NULL;
|
V4L/DVB (7448): Add support for Kworld ATSC 120
This board has a s5h1409 demod, plus a xc30x8 tuner (probably, xc3018).
This patch adds proper support for radio, video, s-video, composite and ATSC.
However, support for radio and video depends on having s5h1409 i2c gate open,
otherwise, xc30x8 chip won't be visible.
For a better support, some rework is needed on cx88 driver, to allow adding
xc30x8 to i2c bus without sending i2c 0 byte reading to 0xc2 address.
Thanks to Vanessa Ezekowitz <vanessaezekowitz@gmail.com> for helping to figure
out the proper parameters for s5h1409 and the GPIO pins used by each
configuration.
Signed-off-by: Mauro Carvalho Chehab <mchehab@infradead.org>
2008-03-28 10:18:30 +08:00
|
|
|
struct xc2028_ctrl ctl;
|
2008-04-23 01:45:30 +08:00
|
|
|
struct xc2028_config cfg = {
|
|
|
|
.i2c_adap = &dev->core->i2c_adap,
|
|
|
|
.i2c_addr = addr,
|
V4L/DVB (7448): Add support for Kworld ATSC 120
This board has a s5h1409 demod, plus a xc30x8 tuner (probably, xc3018).
This patch adds proper support for radio, video, s-video, composite and ATSC.
However, support for radio and video depends on having s5h1409 i2c gate open,
otherwise, xc30x8 chip won't be visible.
For a better support, some rework is needed on cx88 driver, to allow adding
xc30x8 to i2c bus without sending i2c 0 byte reading to 0xc2 address.
Thanks to Vanessa Ezekowitz <vanessaezekowitz@gmail.com> for helping to figure
out the proper parameters for s5h1409 and the GPIO pins used by each
configuration.
Signed-off-by: Mauro Carvalho Chehab <mchehab@infradead.org>
2008-03-28 10:18:30 +08:00
|
|
|
.ctrl = &ctl,
|
2008-04-23 01:45:30 +08:00
|
|
|
};
|
|
|
|
|
2008-10-11 22:18:53 +08:00
|
|
|
/* Get the first frontend */
|
2008-10-11 22:05:50 +08:00
|
|
|
fe0 = videobuf_dvb_get_frontend(&dev->frontends, 1);
|
|
|
|
if (!fe0)
|
|
|
|
return -EINVAL;
|
|
|
|
|
|
|
|
if (!fe0->dvb.frontend) {
|
2008-04-23 01:45:46 +08:00
|
|
|
printk(KERN_ERR "%s/2: dvb frontend not attached. "
|
|
|
|
"Can't attach xc3028\n",
|
|
|
|
dev->core->name);
|
|
|
|
return -EINVAL;
|
|
|
|
}
|
|
|
|
|
V4L/DVB (7448): Add support for Kworld ATSC 120
This board has a s5h1409 demod, plus a xc30x8 tuner (probably, xc3018).
This patch adds proper support for radio, video, s-video, composite and ATSC.
However, support for radio and video depends on having s5h1409 i2c gate open,
otherwise, xc30x8 chip won't be visible.
For a better support, some rework is needed on cx88 driver, to allow adding
xc30x8 to i2c bus without sending i2c 0 byte reading to 0xc2 address.
Thanks to Vanessa Ezekowitz <vanessaezekowitz@gmail.com> for helping to figure
out the proper parameters for s5h1409 and the GPIO pins used by each
configuration.
Signed-off-by: Mauro Carvalho Chehab <mchehab@infradead.org>
2008-03-28 10:18:30 +08:00
|
|
|
/*
|
|
|
|
* Some xc3028 devices may be hidden by an I2C gate. This is known
|
|
|
|
* to happen with some s5h1409-based devices.
|
|
|
|
* Now that I2C gate is open, sets up xc3028 configuration
|
|
|
|
*/
|
|
|
|
cx88_setup_xc3028(dev->core, &ctl);
|
|
|
|
|
2008-10-11 22:05:50 +08:00
|
|
|
fe = dvb_attach(xc2028_attach, fe0->dvb.frontend, &cfg);
|
2008-04-23 01:45:30 +08:00
|
|
|
if (!fe) {
|
|
|
|
printk(KERN_ERR "%s/2: xc3028 attach failed\n",
|
|
|
|
dev->core->name);
|
2008-10-11 22:05:50 +08:00
|
|
|
dvb_frontend_detach(fe0->dvb.frontend);
|
|
|
|
dvb_unregister_frontend(fe0->dvb.frontend);
|
|
|
|
fe0->dvb.frontend = NULL;
|
2008-04-23 01:45:30 +08:00
|
|
|
return -EINVAL;
|
|
|
|
}
|
|
|
|
|
|
|
|
printk(KERN_INFO "%s/2: xc3028 attached\n",
|
|
|
|
dev->core->name);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
2008-04-23 01:45:15 +08:00
|
|
|
|
2008-09-04 12:17:33 +08:00
|
|
|
static int cx24116_set_ts_param(struct dvb_frontend *fe,
|
|
|
|
int is_punctured)
|
|
|
|
{
|
|
|
|
struct cx8802_dev *dev = fe->dvb->priv;
|
|
|
|
dev->ts_gen_cntrl = 0x2;
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int cx24116_reset_device(struct dvb_frontend *fe)
|
|
|
|
{
|
|
|
|
struct cx8802_dev *dev = fe->dvb->priv;
|
|
|
|
struct cx88_core *core = dev->core;
|
|
|
|
|
|
|
|
/* Reset the part */
|
2008-10-11 22:05:50 +08:00
|
|
|
/* Put the cx24116 into reset */
|
2008-09-04 12:17:33 +08:00
|
|
|
cx_write(MO_SRST_IO, 0);
|
|
|
|
msleep(10);
|
2008-10-11 22:05:50 +08:00
|
|
|
/* Take the cx24116 out of reset */
|
2008-09-04 12:17:33 +08:00
|
|
|
cx_write(MO_SRST_IO, 1);
|
|
|
|
msleep(10);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static struct cx24116_config hauppauge_hvr4000_config = {
|
|
|
|
.demod_address = 0x05,
|
|
|
|
.set_ts_params = cx24116_set_ts_param,
|
|
|
|
.reset_device = cx24116_reset_device,
|
|
|
|
};
|
|
|
|
|
2008-09-05 04:24:14 +08:00
|
|
|
static struct cx24116_config tevii_s460_config = {
|
|
|
|
.demod_address = 0x55,
|
|
|
|
.set_ts_params = cx24116_set_ts_param,
|
|
|
|
.reset_device = cx24116_reset_device,
|
|
|
|
};
|
|
|
|
|
2008-09-24 02:43:57 +08:00
|
|
|
static struct stv0299_config tevii_tuner_sharp_config = {
|
|
|
|
.demod_address = 0x68,
|
2008-10-18 00:45:55 +08:00
|
|
|
.inittab = sharp_z0194a_inittab,
|
2008-09-24 02:43:57 +08:00
|
|
|
.mclk = 88000000UL,
|
|
|
|
.invert = 1,
|
|
|
|
.skip_reinit = 0,
|
|
|
|
.lock_output = 1,
|
|
|
|
.volt13_op0_op1 = STV0299_VOLT13_OP1,
|
|
|
|
.min_delay_ms = 100,
|
2008-10-18 00:45:55 +08:00
|
|
|
.set_symbol_rate = sharp_z0194a_set_symbol_rate,
|
2008-09-24 02:43:57 +08:00
|
|
|
.set_ts_params = cx24116_set_ts_param,
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct stv0288_config tevii_tuner_earda_config = {
|
|
|
|
.demod_address = 0x68,
|
|
|
|
.min_delay_ms = 100,
|
|
|
|
.set_ts_params = cx24116_set_ts_param,
|
|
|
|
};
|
|
|
|
|
2005-04-17 06:20:36 +08:00
|
|
|
static int dvb_register(struct cx8802_dev *dev)
|
|
|
|
{
|
2008-05-01 05:14:36 +08:00
|
|
|
struct cx88_core *core = dev->core;
|
2008-10-11 22:05:50 +08:00
|
|
|
struct videobuf_dvb_frontend *fe0, *fe1 = NULL;
|
2008-10-11 22:44:05 +08:00
|
|
|
int mfe_shared = 0; /* bus not shared by default */
|
2008-05-01 05:14:36 +08:00
|
|
|
|
V4L/DVB (9357): cx88-dvb: Fix Oops in case i2c bus failed to register
There already is an report at kernel bugzilla about this issue:
http://bugzilla.kernel.org/show_bug.cgi?id=9455
When enabling extra checks for the i2c-bus of cx88 based cards by
loading i2c_algo_bit with bit_test=1 this may trigger an oops
when loading cx88_dvb.
This is caused by the extra check code that detects that the
sda-line is stuck high and thus does not register the i2c-bus.
cx88-dvb however does not check if the i2c-bus is valid and just
uses core->i2c_adap to attach dvb frontend modules.
This leads to an oops at the first call to i2c_transfer:
$ modprobe i2c_algo_bit bit_test=1
$ modprobe cx8802
cx88/2: cx2388x MPEG-TS Driver Manager version 0.0.6 loaded
cx88[0]: quirk: PCIPCI_NATOMA -- set TBFX
cx88[0]: subsystem: 0070:9202, board: Hauppauge Nova-S-Plus DVB-S [card=37,autodetected], frontend(s): 1
cx88[0]: TV tuner type 4, Radio tuner type -1
cx88[0]: SDA stuck high!
cx88[0]: i2c register FAILED
input: cx88 IR (Hauppauge Nova-S-Plus as /class/input/input5
cx88[0]/2: cx2388x 8802 Driver Manager
cx88-mpeg driver manager 0000:00:10.2: enabling device (0154 -> 0156)
cx88-mpeg driver manager 0000:00:10.2: PCI INT A -> Link[LNKD] -> GSI 9 (level, low) -> IRQ 9
cx88[0]/2: found at 0000:00:10.2, rev: 5, irq: 9, latency: 64, mmio: 0xfb000000
cx8802_probe() allocating 1 frontend(s)
cx88/2: cx2388x dvb driver version 0.0.6 loaded
cx88/2: registering cx8802 driver, type: dvb access: shared
cx88[0]/2: subsystem: 0070:9202, board: Hauppauge Nova-S-Plus DVB-S [card=37]
cx88[0]/2: cx2388x based DVB/ATSC card
BUG: unable to handle kernel NULL pointer dereference at 00000000
IP: [<e084d4ef>] :i2c_core:i2c_transfer+0x1f/0x80
*pde = 00000000
Modules linked in: cx88_dvb(+) cx8802 cx88xx ir_common i2c_algo_bit tveeprom videobuf_dvb btcx_risc
mga drm ipv6 fscpos eeprom nfsd exportfs stv0299 b2c2_flexcop_pci b2c2_flexcop cx24123 s5h1420 ves1x93
dvb_ttpci dvb_core saa7146_vv saa7146 videobuf_dma_sg videobuf_core videodev v4l1_compat ttpci_eeprom
lirc_serial lirc_dev usbhid rtc uhci_hcd 8139too i2c_piix4 i2c_core usbcore evdev
Pid: 4249, comm: modprobe Not tainted (2.6.27-gentoo #3)
EIP: 0060:[<e084d4ef>] EFLAGS: 00010296 CPU: 0
EIP is at i2c_transfer+0x1f/0x80 [i2c_core]
EAX: 00000000 EBX: ffffffa1 ECX: 00000002 EDX: d6c71e3c
ESI: d80cd050 EDI: d8093c00 EBP: d6c71e20 ESP: d6c71e0c
DS: 007b ES: 007b FS: 0000 GS: 0033 SS: 0068
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
2008-10-24 21:47:07 +08:00
|
|
|
if (0 != core->i2c_rc) {
|
|
|
|
printk(KERN_ERR "%s/2: no i2c-bus available, cannot attach dvb drivers\n", core->name);
|
|
|
|
goto frontend_detach;
|
|
|
|
}
|
|
|
|
|
2008-10-11 22:05:50 +08:00
|
|
|
/* Get the first frontend */
|
|
|
|
fe0 = videobuf_dvb_get_frontend(&dev->frontends, 1);
|
|
|
|
if (!fe0)
|
2008-11-11 19:48:27 +08:00
|
|
|
goto frontend_detach;
|
2005-04-17 06:20:36 +08:00
|
|
|
|
2008-10-11 22:31:41 +08:00
|
|
|
/* multi-frontend gate control is undefined or defaults to fe0 */
|
|
|
|
dev->frontends.gate = 0;
|
|
|
|
|
|
|
|
/* init frontend(s) */
|
2008-05-01 05:14:36 +08:00
|
|
|
switch (core->boardnr) {
|
2005-04-17 06:20:36 +08:00
|
|
|
case CX88_BOARD_HAUPPAUGE_DVB_T1:
|
2008-10-11 22:05:50 +08:00
|
|
|
fe0->dvb.frontend = dvb_attach(cx22702_attach,
|
2006-12-05 12:34:56 +08:00
|
|
|
&connexant_refboard_config,
|
2008-05-01 05:14:36 +08:00
|
|
|
&core->i2c_adap);
|
2008-10-11 22:05:50 +08:00
|
|
|
if (fe0->dvb.frontend != NULL) {
|
|
|
|
if (!dvb_attach(dvb_pll_attach, fe0->dvb.frontend,
|
2008-05-01 05:14:36 +08:00
|
|
|
0x61, &core->i2c_adap,
|
|
|
|
DVB_PLL_THOMSON_DTT759X))
|
|
|
|
goto frontend_detach;
|
2006-04-19 04:56:10 +08:00
|
|
|
}
|
2005-04-17 06:20:36 +08:00
|
|
|
break;
|
2005-07-08 08:58:40 +08:00
|
|
|
case CX88_BOARD_TERRATEC_CINERGY_1400_DVB_T1:
|
2005-04-17 06:20:36 +08:00
|
|
|
case CX88_BOARD_CONEXANT_DVB_T1:
|
2006-01-10 01:32:45 +08:00
|
|
|
case CX88_BOARD_KWORLD_DVB_T_CX22702:
|
2005-11-09 13:37:22 +08:00
|
|
|
case CX88_BOARD_WINFAST_DTV1000:
|
2008-10-11 22:05:50 +08:00
|
|
|
fe0->dvb.frontend = dvb_attach(cx22702_attach,
|
2006-08-09 02:48:08 +08:00
|
|
|
&connexant_refboard_config,
|
2008-05-01 05:14:36 +08:00
|
|
|
&core->i2c_adap);
|
2008-10-11 22:05:50 +08:00
|
|
|
if (fe0->dvb.frontend != NULL) {
|
|
|
|
if (!dvb_attach(dvb_pll_attach, fe0->dvb.frontend,
|
2008-05-01 05:14:36 +08:00
|
|
|
0x60, &core->i2c_adap,
|
|
|
|
DVB_PLL_THOMSON_DTT7579))
|
|
|
|
goto frontend_detach;
|
2006-04-19 04:56:10 +08:00
|
|
|
}
|
2005-04-17 06:20:36 +08:00
|
|
|
break;
|
2006-05-30 00:51:59 +08:00
|
|
|
case CX88_BOARD_WINFAST_DTV2000H:
|
2006-01-10 01:25:12 +08:00
|
|
|
case CX88_BOARD_HAUPPAUGE_HVR1100:
|
|
|
|
case CX88_BOARD_HAUPPAUGE_HVR1100LP:
|
2007-03-10 02:07:07 +08:00
|
|
|
case CX88_BOARD_HAUPPAUGE_HVR1300:
|
2008-10-11 22:05:50 +08:00
|
|
|
fe0->dvb.frontend = dvb_attach(cx22702_attach,
|
2006-12-05 12:34:56 +08:00
|
|
|
&hauppauge_hvr_config,
|
2008-05-01 05:14:36 +08:00
|
|
|
&core->i2c_adap);
|
2008-10-11 22:05:50 +08:00
|
|
|
if (fe0->dvb.frontend != NULL) {
|
|
|
|
if (!dvb_attach(simple_tuner_attach, fe0->dvb.frontend,
|
2008-05-01 05:14:36 +08:00
|
|
|
&core->i2c_adap, 0x61,
|
|
|
|
TUNER_PHILIPS_FMD1216ME_MK3))
|
|
|
|
goto frontend_detach;
|
2006-04-19 04:56:10 +08:00
|
|
|
}
|
2006-01-10 01:25:12 +08:00
|
|
|
break;
|
2008-10-11 22:05:50 +08:00
|
|
|
case CX88_BOARD_HAUPPAUGE_HVR3000:
|
2008-11-11 19:48:27 +08:00
|
|
|
/* MFE frontend 1 */
|
|
|
|
mfe_shared = 1;
|
|
|
|
dev->frontends.gate = 2;
|
2008-10-11 22:05:50 +08:00
|
|
|
/* DVB-S init */
|
|
|
|
fe0->dvb.frontend = dvb_attach(cx24123_attach,
|
2008-11-11 19:48:27 +08:00
|
|
|
&hauppauge_novas_config,
|
|
|
|
&dev->core->i2c_adap);
|
2008-10-11 22:05:50 +08:00
|
|
|
if (fe0->dvb.frontend) {
|
2008-11-11 19:48:27 +08:00
|
|
|
if (!dvb_attach(isl6421_attach,
|
|
|
|
fe0->dvb.frontend,
|
|
|
|
&dev->core->i2c_adap,
|
|
|
|
0x08, ISL6421_DCL, 0x00))
|
|
|
|
goto frontend_detach;
|
2008-10-11 22:05:50 +08:00
|
|
|
}
|
2008-11-11 19:48:27 +08:00
|
|
|
/* MFE frontend 2 */
|
2008-10-11 22:05:50 +08:00
|
|
|
fe1 = videobuf_dvb_get_frontend(&dev->frontends, 2);
|
2008-11-11 19:48:27 +08:00
|
|
|
if (!fe1)
|
|
|
|
goto frontend_detach;
|
|
|
|
/* DVB-T init */
|
|
|
|
fe1->dvb.frontend = dvb_attach(cx22702_attach,
|
|
|
|
&hauppauge_hvr_config,
|
|
|
|
&dev->core->i2c_adap);
|
|
|
|
if (fe1->dvb.frontend) {
|
|
|
|
fe1->dvb.frontend->id = 1;
|
|
|
|
if (!dvb_attach(simple_tuner_attach,
|
|
|
|
fe1->dvb.frontend,
|
|
|
|
&dev->core->i2c_adap,
|
|
|
|
0x61, TUNER_PHILIPS_FMD1216ME_MK3))
|
|
|
|
goto frontend_detach;
|
2008-10-11 22:05:50 +08:00
|
|
|
}
|
|
|
|
break;
|
2006-02-28 19:34:59 +08:00
|
|
|
case CX88_BOARD_DVICO_FUSIONHDTV_DVB_T_PLUS:
|
2008-10-11 22:05:50 +08:00
|
|
|
fe0->dvb.frontend = dvb_attach(mt352_attach,
|
2006-08-09 02:48:08 +08:00
|
|
|
&dvico_fusionhdtv,
|
2008-05-01 05:14:36 +08:00
|
|
|
&core->i2c_adap);
|
2008-10-11 22:05:50 +08:00
|
|
|
if (fe0->dvb.frontend != NULL) {
|
|
|
|
if (!dvb_attach(dvb_pll_attach, fe0->dvb.frontend,
|
2008-05-01 05:14:36 +08:00
|
|
|
0x60, NULL, DVB_PLL_THOMSON_DTT7579))
|
|
|
|
goto frontend_detach;
|
2006-02-28 19:34:59 +08:00
|
|
|
break;
|
2006-04-19 04:56:10 +08:00
|
|
|
}
|
2006-02-28 19:34:59 +08:00
|
|
|
/* ZL10353 replaces MT352 on later cards */
|
2008-10-11 22:05:50 +08:00
|
|
|
fe0->dvb.frontend = dvb_attach(zl10353_attach,
|
2006-08-09 02:48:08 +08:00
|
|
|
&dvico_fusionhdtv_plus_v1_1,
|
2008-05-01 05:14:36 +08:00
|
|
|
&core->i2c_adap);
|
2008-10-11 22:05:50 +08:00
|
|
|
if (fe0->dvb.frontend != NULL) {
|
|
|
|
if (!dvb_attach(dvb_pll_attach, fe0->dvb.frontend,
|
2008-05-01 05:14:36 +08:00
|
|
|
0x60, NULL, DVB_PLL_THOMSON_DTT7579))
|
|
|
|
goto frontend_detach;
|
2006-04-19 04:56:10 +08:00
|
|
|
}
|
2006-06-13 01:06:22 +08:00
|
|
|
break;
|
|
|
|
case CX88_BOARD_DVICO_FUSIONHDTV_DVB_T_DUAL:
|
|
|
|
/* The tin box says DEE1601, but it seems to be DTT7579
|
|
|
|
* compatible, with a slightly different MT352 AGC gain. */
|
2008-10-11 22:05:50 +08:00
|
|
|
fe0->dvb.frontend = dvb_attach(mt352_attach,
|
2006-08-09 02:48:08 +08:00
|
|
|
&dvico_fusionhdtv_dual,
|
2008-05-01 05:14:36 +08:00
|
|
|
&core->i2c_adap);
|
2008-10-11 22:05:50 +08:00
|
|
|
if (fe0->dvb.frontend != NULL) {
|
|
|
|
if (!dvb_attach(dvb_pll_attach, fe0->dvb.frontend,
|
2008-05-01 05:14:36 +08:00
|
|
|
0x61, NULL, DVB_PLL_THOMSON_DTT7579))
|
|
|
|
goto frontend_detach;
|
2006-06-13 01:06:22 +08:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
/* ZL10353 replaces MT352 on later cards */
|
2008-10-11 22:05:50 +08:00
|
|
|
fe0->dvb.frontend = dvb_attach(zl10353_attach,
|
2006-08-09 02:48:08 +08:00
|
|
|
&dvico_fusionhdtv_plus_v1_1,
|
2008-05-01 05:14:36 +08:00
|
|
|
&core->i2c_adap);
|
2008-10-11 22:05:50 +08:00
|
|
|
if (fe0->dvb.frontend != NULL) {
|
|
|
|
if (!dvb_attach(dvb_pll_attach, fe0->dvb.frontend,
|
2008-05-01 05:14:36 +08:00
|
|
|
0x61, NULL, DVB_PLL_THOMSON_DTT7579))
|
|
|
|
goto frontend_detach;
|
2006-06-13 01:06:22 +08:00
|
|
|
}
|
2005-04-17 06:20:36 +08:00
|
|
|
break;
|
2006-02-28 19:34:59 +08:00
|
|
|
case CX88_BOARD_DVICO_FUSIONHDTV_DVB_T1:
|
2008-10-11 22:05:50 +08:00
|
|
|
fe0->dvb.frontend = dvb_attach(mt352_attach,
|
2006-08-09 02:48:08 +08:00
|
|
|
&dvico_fusionhdtv,
|
2008-05-01 05:14:36 +08:00
|
|
|
&core->i2c_adap);
|
2008-10-11 22:05:50 +08:00
|
|
|
if (fe0->dvb.frontend != NULL) {
|
|
|
|
if (!dvb_attach(dvb_pll_attach, fe0->dvb.frontend,
|
2008-05-01 05:14:36 +08:00
|
|
|
0x61, NULL, DVB_PLL_LG_Z201))
|
|
|
|
goto frontend_detach;
|
2006-04-19 04:56:10 +08:00
|
|
|
}
|
2005-04-17 06:20:36 +08:00
|
|
|
break;
|
|
|
|
case CX88_BOARD_KWORLD_DVB_T:
|
|
|
|
case CX88_BOARD_DNTV_LIVE_DVB_T:
|
2005-07-08 08:58:36 +08:00
|
|
|
case CX88_BOARD_ADSTECH_DVB_T_PCI:
|
2008-10-11 22:05:50 +08:00
|
|
|
fe0->dvb.frontend = dvb_attach(mt352_attach,
|
2006-08-09 02:48:08 +08:00
|
|
|
&dntv_live_dvbt_config,
|
2008-05-01 05:14:36 +08:00
|
|
|
&core->i2c_adap);
|
2008-10-11 22:05:50 +08:00
|
|
|
if (fe0->dvb.frontend != NULL) {
|
|
|
|
if (!dvb_attach(dvb_pll_attach, fe0->dvb.frontend,
|
2008-05-01 05:14:36 +08:00
|
|
|
0x61, NULL, DVB_PLL_UNKNOWN_1))
|
|
|
|
goto frontend_detach;
|
2006-04-19 04:56:10 +08:00
|
|
|
}
|
2005-04-17 06:20:36 +08:00
|
|
|
break;
|
2006-01-10 01:25:35 +08:00
|
|
|
case CX88_BOARD_DNTV_LIVE_DVB_T_PRO:
|
2007-05-06 07:11:32 +08:00
|
|
|
#if defined(CONFIG_VIDEO_CX88_VP3054) || (defined(CONFIG_VIDEO_CX88_VP3054_MODULE) && defined(MODULE))
|
2007-10-14 13:52:16 +08:00
|
|
|
/* MT352 is on a secondary I2C bus made from some GPIO lines */
|
2008-10-11 22:05:50 +08:00
|
|
|
fe0->dvb.frontend = dvb_attach(mt352_attach, &dntv_live_dvbt_pro_config,
|
2007-10-14 13:52:16 +08:00
|
|
|
&dev->vp3054->adap);
|
2008-10-11 22:05:50 +08:00
|
|
|
if (fe0->dvb.frontend != NULL) {
|
|
|
|
if (!dvb_attach(simple_tuner_attach, fe0->dvb.frontend,
|
2008-05-01 05:14:36 +08:00
|
|
|
&core->i2c_adap, 0x61,
|
|
|
|
TUNER_PHILIPS_FMD1216ME_MK3))
|
|
|
|
goto frontend_detach;
|
2006-04-19 04:56:10 +08:00
|
|
|
}
|
2006-01-10 01:25:35 +08:00
|
|
|
#else
|
2008-05-01 05:14:36 +08:00
|
|
|
printk(KERN_ERR "%s/2: built without vp3054 support\n",
|
|
|
|
core->name);
|
2006-01-10 01:25:35 +08:00
|
|
|
#endif
|
|
|
|
break;
|
2006-02-28 19:34:59 +08:00
|
|
|
case CX88_BOARD_DVICO_FUSIONHDTV_DVB_T_HYBRID:
|
2008-10-11 22:05:50 +08:00
|
|
|
fe0->dvb.frontend = dvb_attach(zl10353_attach,
|
2006-08-09 02:48:08 +08:00
|
|
|
&dvico_fusionhdtv_hybrid,
|
2008-05-01 05:14:36 +08:00
|
|
|
&core->i2c_adap);
|
2008-10-11 22:05:50 +08:00
|
|
|
if (fe0->dvb.frontend != NULL) {
|
|
|
|
if (!dvb_attach(simple_tuner_attach, fe0->dvb.frontend,
|
2008-05-01 05:14:36 +08:00
|
|
|
&core->i2c_adap, 0x61,
|
|
|
|
TUNER_THOMSON_FE6600))
|
|
|
|
goto frontend_detach;
|
2006-04-19 04:56:10 +08:00
|
|
|
}
|
2006-02-28 19:34:59 +08:00
|
|
|
break;
|
2008-04-23 01:45:15 +08:00
|
|
|
case CX88_BOARD_DVICO_FUSIONHDTV_DVB_T_PRO:
|
2008-10-11 22:05:50 +08:00
|
|
|
fe0->dvb.frontend = dvb_attach(zl10353_attach,
|
2008-04-23 01:45:15 +08:00
|
|
|
&dvico_fusionhdtv_xc3028,
|
2008-05-01 05:14:36 +08:00
|
|
|
&core->i2c_adap);
|
2008-10-11 22:05:50 +08:00
|
|
|
if (fe0->dvb.frontend == NULL)
|
|
|
|
fe0->dvb.frontend = dvb_attach(mt352_attach,
|
2008-04-23 01:45:15 +08:00
|
|
|
&dvico_fusionhdtv_mt352_xc3028,
|
2008-05-01 05:14:36 +08:00
|
|
|
&core->i2c_adap);
|
2008-04-23 01:45:15 +08:00
|
|
|
/*
|
|
|
|
* On this board, the demod provides the I2C bus pullup.
|
|
|
|
* We must not permit gate_ctrl to be performed, or
|
|
|
|
* the xc3028 cannot communicate on the bus.
|
|
|
|
*/
|
2008-10-11 22:05:50 +08:00
|
|
|
if (fe0->dvb.frontend)
|
|
|
|
fe0->dvb.frontend->ops.i2c_gate_ctrl = NULL;
|
2008-04-23 01:45:30 +08:00
|
|
|
if (attach_xc3028(0x61, dev) < 0)
|
2008-10-21 22:47:50 +08:00
|
|
|
goto frontend_detach;
|
2008-04-23 01:45:15 +08:00
|
|
|
break;
|
2005-04-17 06:20:36 +08:00
|
|
|
case CX88_BOARD_PCHDTV_HD3000:
|
2008-10-11 22:05:50 +08:00
|
|
|
fe0->dvb.frontend = dvb_attach(or51132_attach, &pchdtv_hd3000,
|
2008-05-01 05:14:36 +08:00
|
|
|
&core->i2c_adap);
|
2008-10-11 22:05:50 +08:00
|
|
|
if (fe0->dvb.frontend != NULL) {
|
|
|
|
if (!dvb_attach(simple_tuner_attach, fe0->dvb.frontend,
|
2008-05-01 05:14:36 +08:00
|
|
|
&core->i2c_adap, 0x61,
|
|
|
|
TUNER_THOMSON_DTT761X))
|
|
|
|
goto frontend_detach;
|
2006-04-19 04:56:10 +08:00
|
|
|
}
|
2005-04-17 06:20:36 +08:00
|
|
|
break;
|
2005-07-08 08:58:39 +08:00
|
|
|
case CX88_BOARD_DVICO_FUSIONHDTV_3_GOLD_Q:
|
|
|
|
dev->ts_gen_cntrl = 0x08;
|
|
|
|
|
2008-05-01 05:14:36 +08:00
|
|
|
/* Do a hardware reset of chip before using it. */
|
2005-07-08 08:58:39 +08:00
|
|
|
cx_clear(MO_GP0_IO, 1);
|
|
|
|
mdelay(100);
|
2005-07-28 02:45:55 +08:00
|
|
|
cx_set(MO_GP0_IO, 1);
|
2005-07-08 08:58:39 +08:00
|
|
|
mdelay(200);
|
2005-07-28 02:45:55 +08:00
|
|
|
|
|
|
|
/* Select RF connector callback */
|
2005-07-28 02:46:00 +08:00
|
|
|
fusionhdtv_3_gold.pll_rf_set = lgdt330x_pll_rf_set;
|
2008-10-11 22:05:50 +08:00
|
|
|
fe0->dvb.frontend = dvb_attach(lgdt330x_attach,
|
2006-08-09 02:48:08 +08:00
|
|
|
&fusionhdtv_3_gold,
|
2008-05-01 05:14:36 +08:00
|
|
|
&core->i2c_adap);
|
2008-10-11 22:05:50 +08:00
|
|
|
if (fe0->dvb.frontend != NULL) {
|
|
|
|
if (!dvb_attach(simple_tuner_attach, fe0->dvb.frontend,
|
2008-05-01 05:14:36 +08:00
|
|
|
&core->i2c_adap, 0x61,
|
|
|
|
TUNER_MICROTUNE_4042FI5))
|
|
|
|
goto frontend_detach;
|
2005-07-08 08:58:39 +08:00
|
|
|
}
|
|
|
|
break;
|
2005-07-08 08:58:42 +08:00
|
|
|
case CX88_BOARD_DVICO_FUSIONHDTV_3_GOLD_T:
|
|
|
|
dev->ts_gen_cntrl = 0x08;
|
|
|
|
|
2008-05-01 05:14:36 +08:00
|
|
|
/* Do a hardware reset of chip before using it. */
|
2005-07-08 08:58:42 +08:00
|
|
|
cx_clear(MO_GP0_IO, 1);
|
|
|
|
mdelay(100);
|
2005-07-28 02:45:56 +08:00
|
|
|
cx_set(MO_GP0_IO, 9);
|
2005-07-08 08:58:42 +08:00
|
|
|
mdelay(200);
|
2008-10-11 22:05:50 +08:00
|
|
|
fe0->dvb.frontend = dvb_attach(lgdt330x_attach,
|
2006-08-09 02:48:08 +08:00
|
|
|
&fusionhdtv_3_gold,
|
2008-05-01 05:14:36 +08:00
|
|
|
&core->i2c_adap);
|
2008-10-11 22:05:50 +08:00
|
|
|
if (fe0->dvb.frontend != NULL) {
|
|
|
|
if (!dvb_attach(simple_tuner_attach, fe0->dvb.frontend,
|
2008-05-01 05:14:36 +08:00
|
|
|
&core->i2c_adap, 0x61,
|
|
|
|
TUNER_THOMSON_DTT761X))
|
|
|
|
goto frontend_detach;
|
2005-07-08 08:58:42 +08:00
|
|
|
}
|
|
|
|
break;
|
2005-09-10 04:03:41 +08:00
|
|
|
case CX88_BOARD_DVICO_FUSIONHDTV_5_GOLD:
|
|
|
|
dev->ts_gen_cntrl = 0x08;
|
|
|
|
|
2008-05-01 05:14:36 +08:00
|
|
|
/* Do a hardware reset of chip before using it. */
|
2005-09-10 04:03:41 +08:00
|
|
|
cx_clear(MO_GP0_IO, 1);
|
|
|
|
mdelay(100);
|
|
|
|
cx_set(MO_GP0_IO, 1);
|
|
|
|
mdelay(200);
|
2008-10-11 22:05:50 +08:00
|
|
|
fe0->dvb.frontend = dvb_attach(lgdt330x_attach,
|
2006-08-09 02:48:08 +08:00
|
|
|
&fusionhdtv_5_gold,
|
2008-05-01 05:14:36 +08:00
|
|
|
&core->i2c_adap);
|
2008-10-11 22:05:50 +08:00
|
|
|
if (fe0->dvb.frontend != NULL) {
|
|
|
|
if (!dvb_attach(simple_tuner_attach, fe0->dvb.frontend,
|
2008-05-01 05:14:36 +08:00
|
|
|
&core->i2c_adap, 0x61,
|
|
|
|
TUNER_LG_TDVS_H06XF))
|
|
|
|
goto frontend_detach;
|
2008-10-11 22:05:50 +08:00
|
|
|
if (!dvb_attach(tda9887_attach, fe0->dvb.frontend,
|
2008-05-01 05:14:36 +08:00
|
|
|
&core->i2c_adap, 0x43))
|
|
|
|
goto frontend_detach;
|
2005-09-10 04:03:41 +08:00
|
|
|
}
|
|
|
|
break;
|
2006-04-07 13:21:31 +08:00
|
|
|
case CX88_BOARD_PCHDTV_HD5500:
|
|
|
|
dev->ts_gen_cntrl = 0x08;
|
|
|
|
|
2008-05-01 05:14:36 +08:00
|
|
|
/* Do a hardware reset of chip before using it. */
|
2006-04-07 13:21:31 +08:00
|
|
|
cx_clear(MO_GP0_IO, 1);
|
|
|
|
mdelay(100);
|
|
|
|
cx_set(MO_GP0_IO, 1);
|
|
|
|
mdelay(200);
|
2008-10-11 22:05:50 +08:00
|
|
|
fe0->dvb.frontend = dvb_attach(lgdt330x_attach,
|
2006-08-09 02:48:08 +08:00
|
|
|
&pchdtv_hd5500,
|
2008-05-01 05:14:36 +08:00
|
|
|
&core->i2c_adap);
|
2008-10-11 22:05:50 +08:00
|
|
|
if (fe0->dvb.frontend != NULL) {
|
|
|
|
if (!dvb_attach(simple_tuner_attach, fe0->dvb.frontend,
|
2008-05-01 05:14:36 +08:00
|
|
|
&core->i2c_adap, 0x61,
|
|
|
|
TUNER_LG_TDVS_H06XF))
|
|
|
|
goto frontend_detach;
|
2008-10-11 22:05:50 +08:00
|
|
|
if (!dvb_attach(tda9887_attach, fe0->dvb.frontend,
|
2008-05-01 05:14:36 +08:00
|
|
|
&core->i2c_adap, 0x43))
|
|
|
|
goto frontend_detach;
|
2006-04-07 13:21:31 +08:00
|
|
|
}
|
|
|
|
break;
|
2005-11-09 13:38:18 +08:00
|
|
|
case CX88_BOARD_ATI_HDTVWONDER:
|
2008-10-11 22:05:50 +08:00
|
|
|
fe0->dvb.frontend = dvb_attach(nxt200x_attach,
|
2006-08-09 02:48:08 +08:00
|
|
|
&ati_hdtvwonder,
|
2008-05-01 05:14:36 +08:00
|
|
|
&core->i2c_adap);
|
2008-10-11 22:05:50 +08:00
|
|
|
if (fe0->dvb.frontend != NULL) {
|
|
|
|
if (!dvb_attach(simple_tuner_attach, fe0->dvb.frontend,
|
2008-05-01 05:14:36 +08:00
|
|
|
&core->i2c_adap, 0x61,
|
|
|
|
TUNER_PHILIPS_TUV1236D))
|
|
|
|
goto frontend_detach;
|
2006-04-19 04:56:10 +08:00
|
|
|
}
|
2006-01-10 01:25:02 +08:00
|
|
|
break;
|
|
|
|
case CX88_BOARD_HAUPPAUGE_NOVASPLUS_S1:
|
|
|
|
case CX88_BOARD_HAUPPAUGE_NOVASE2_S1:
|
2008-10-11 22:05:50 +08:00
|
|
|
fe0->dvb.frontend = dvb_attach(cx24123_attach,
|
2006-08-09 02:48:08 +08:00
|
|
|
&hauppauge_novas_config,
|
2008-05-01 05:14:36 +08:00
|
|
|
&core->i2c_adap);
|
2008-10-11 22:05:50 +08:00
|
|
|
if (fe0->dvb.frontend) {
|
|
|
|
if (!dvb_attach(isl6421_attach, fe0->dvb.frontend,
|
2008-09-14 06:22:15 +08:00
|
|
|
&core->i2c_adap, 0x08, ISL6421_DCL, 0x00))
|
2008-05-01 05:14:36 +08:00
|
|
|
goto frontend_detach;
|
2006-05-13 07:31:51 +08:00
|
|
|
}
|
2006-01-10 01:25:02 +08:00
|
|
|
break;
|
|
|
|
case CX88_BOARD_KWORLD_DVBS_100:
|
2008-10-11 22:05:50 +08:00
|
|
|
fe0->dvb.frontend = dvb_attach(cx24123_attach,
|
2006-08-09 02:48:08 +08:00
|
|
|
&kworld_dvbs_100_config,
|
2008-05-01 05:14:36 +08:00
|
|
|
&core->i2c_adap);
|
2008-10-11 22:05:50 +08:00
|
|
|
if (fe0->dvb.frontend) {
|
|
|
|
core->prev_set_voltage = fe0->dvb.frontend->ops.set_voltage;
|
|
|
|
fe0->dvb.frontend->ops.set_voltage = kworld_dvbs_100_set_voltage;
|
2006-05-13 07:31:51 +08:00
|
|
|
}
|
2005-11-09 13:38:18 +08:00
|
|
|
break;
|
2006-06-30 07:29:33 +08:00
|
|
|
case CX88_BOARD_GENIATECH_DVBS:
|
2008-10-11 22:05:50 +08:00
|
|
|
fe0->dvb.frontend = dvb_attach(cx24123_attach,
|
2006-08-09 02:48:08 +08:00
|
|
|
&geniatech_dvbs_config,
|
2008-05-01 05:14:36 +08:00
|
|
|
&core->i2c_adap);
|
2008-10-11 22:05:50 +08:00
|
|
|
if (fe0->dvb.frontend) {
|
|
|
|
core->prev_set_voltage = fe0->dvb.frontend->ops.set_voltage;
|
|
|
|
fe0->dvb.frontend->ops.set_voltage = geniatech_dvbs_set_voltage;
|
2006-06-30 07:29:33 +08:00
|
|
|
}
|
|
|
|
break;
|
2008-01-06 03:53:01 +08:00
|
|
|
case CX88_BOARD_PINNACLE_PCTV_HD_800i:
|
2008-10-11 22:05:50 +08:00
|
|
|
fe0->dvb.frontend = dvb_attach(s5h1409_attach,
|
2008-01-06 03:53:01 +08:00
|
|
|
&pinnacle_pctv_hd_800i_config,
|
2008-05-01 05:14:36 +08:00
|
|
|
&core->i2c_adap);
|
2008-10-11 22:05:50 +08:00
|
|
|
if (fe0->dvb.frontend != NULL) {
|
|
|
|
if (!dvb_attach(xc5000_attach, fe0->dvb.frontend,
|
2008-05-01 05:14:36 +08:00
|
|
|
&core->i2c_adap,
|
2008-09-07 01:56:58 +08:00
|
|
|
&pinnacle_pctv_hd_800i_tuner_config))
|
2008-05-01 05:14:36 +08:00
|
|
|
goto frontend_detach;
|
2008-01-06 03:53:01 +08:00
|
|
|
}
|
|
|
|
break;
|
2008-04-23 01:45:14 +08:00
|
|
|
case CX88_BOARD_DVICO_FUSIONHDTV_5_PCI_NANO:
|
2008-10-11 22:05:50 +08:00
|
|
|
fe0->dvb.frontend = dvb_attach(s5h1409_attach,
|
2008-04-23 01:45:14 +08:00
|
|
|
&dvico_hdtv5_pci_nano_config,
|
2008-05-01 05:14:36 +08:00
|
|
|
&core->i2c_adap);
|
2008-10-11 22:05:50 +08:00
|
|
|
if (fe0->dvb.frontend != NULL) {
|
2008-04-23 01:45:14 +08:00
|
|
|
struct dvb_frontend *fe;
|
|
|
|
struct xc2028_config cfg = {
|
2008-05-01 05:14:36 +08:00
|
|
|
.i2c_adap = &core->i2c_adap,
|
2008-04-23 01:45:14 +08:00
|
|
|
.i2c_addr = 0x61,
|
|
|
|
};
|
|
|
|
static struct xc2028_ctrl ctl = {
|
2008-09-16 13:15:30 +08:00
|
|
|
.fname = XC2028_DEFAULT_FIRMWARE,
|
2008-04-23 01:45:14 +08:00
|
|
|
.max_len = 64,
|
2008-04-21 17:58:48 +08:00
|
|
|
.scode_table = XC3028_FE_OREN538,
|
2008-04-23 01:45:14 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
fe = dvb_attach(xc2028_attach,
|
2008-10-11 22:05:50 +08:00
|
|
|
fe0->dvb.frontend, &cfg);
|
2008-04-23 01:45:14 +08:00
|
|
|
if (fe != NULL && fe->ops.tuner_ops.set_config != NULL)
|
|
|
|
fe->ops.tuner_ops.set_config(fe, &ctl);
|
|
|
|
}
|
|
|
|
break;
|
2008-04-23 01:45:15 +08:00
|
|
|
case CX88_BOARD_PINNACLE_HYBRID_PCTV:
|
2008-10-11 22:05:50 +08:00
|
|
|
fe0->dvb.frontend = dvb_attach(zl10353_attach,
|
2008-09-06 01:33:54 +08:00
|
|
|
&cx88_pinnacle_hybrid_pctv,
|
2008-05-01 05:14:36 +08:00
|
|
|
&core->i2c_adap);
|
2008-10-11 22:05:50 +08:00
|
|
|
if (fe0->dvb.frontend) {
|
|
|
|
fe0->dvb.frontend->ops.i2c_gate_ctrl = NULL;
|
2008-09-06 01:33:54 +08:00
|
|
|
if (attach_xc3028(0x61, dev) < 0)
|
|
|
|
goto frontend_detach;
|
|
|
|
}
|
2008-04-23 01:45:15 +08:00
|
|
|
break;
|
|
|
|
case CX88_BOARD_GENIATECH_X8000_MT:
|
V4L/DVB (7448): Add support for Kworld ATSC 120
This board has a s5h1409 demod, plus a xc30x8 tuner (probably, xc3018).
This patch adds proper support for radio, video, s-video, composite and ATSC.
However, support for radio and video depends on having s5h1409 i2c gate open,
otherwise, xc30x8 chip won't be visible.
For a better support, some rework is needed on cx88 driver, to allow adding
xc30x8 to i2c bus without sending i2c 0 byte reading to 0xc2 address.
Thanks to Vanessa Ezekowitz <vanessaezekowitz@gmail.com> for helping to figure
out the proper parameters for s5h1409 and the GPIO pins used by each
configuration.
Signed-off-by: Mauro Carvalho Chehab <mchehab@infradead.org>
2008-03-28 10:18:30 +08:00
|
|
|
dev->ts_gen_cntrl = 0x00;
|
2008-04-23 01:45:15 +08:00
|
|
|
|
2008-10-11 22:05:50 +08:00
|
|
|
fe0->dvb.frontend = dvb_attach(zl10353_attach,
|
2008-04-23 01:45:15 +08:00
|
|
|
&cx88_geniatech_x8000_mt,
|
2008-05-01 05:14:36 +08:00
|
|
|
&core->i2c_adap);
|
2008-04-23 01:45:30 +08:00
|
|
|
if (attach_xc3028(0x61, dev) < 0)
|
2008-05-01 05:14:36 +08:00
|
|
|
goto frontend_detach;
|
2008-04-23 01:45:15 +08:00
|
|
|
break;
|
V4L/DVB (7448): Add support for Kworld ATSC 120
This board has a s5h1409 demod, plus a xc30x8 tuner (probably, xc3018).
This patch adds proper support for radio, video, s-video, composite and ATSC.
However, support for radio and video depends on having s5h1409 i2c gate open,
otherwise, xc30x8 chip won't be visible.
For a better support, some rework is needed on cx88 driver, to allow adding
xc30x8 to i2c bus without sending i2c 0 byte reading to 0xc2 address.
Thanks to Vanessa Ezekowitz <vanessaezekowitz@gmail.com> for helping to figure
out the proper parameters for s5h1409 and the GPIO pins used by each
configuration.
Signed-off-by: Mauro Carvalho Chehab <mchehab@infradead.org>
2008-03-28 10:18:30 +08:00
|
|
|
case CX88_BOARD_KWORLD_ATSC_120:
|
2008-10-11 22:05:50 +08:00
|
|
|
fe0->dvb.frontend = dvb_attach(s5h1409_attach,
|
V4L/DVB (7448): Add support for Kworld ATSC 120
This board has a s5h1409 demod, plus a xc30x8 tuner (probably, xc3018).
This patch adds proper support for radio, video, s-video, composite and ATSC.
However, support for radio and video depends on having s5h1409 i2c gate open,
otherwise, xc30x8 chip won't be visible.
For a better support, some rework is needed on cx88 driver, to allow adding
xc30x8 to i2c bus without sending i2c 0 byte reading to 0xc2 address.
Thanks to Vanessa Ezekowitz <vanessaezekowitz@gmail.com> for helping to figure
out the proper parameters for s5h1409 and the GPIO pins used by each
configuration.
Signed-off-by: Mauro Carvalho Chehab <mchehab@infradead.org>
2008-03-28 10:18:30 +08:00
|
|
|
&kworld_atsc_120_config,
|
2008-05-01 05:14:36 +08:00
|
|
|
&core->i2c_adap);
|
V4L/DVB (7448): Add support for Kworld ATSC 120
This board has a s5h1409 demod, plus a xc30x8 tuner (probably, xc3018).
This patch adds proper support for radio, video, s-video, composite and ATSC.
However, support for radio and video depends on having s5h1409 i2c gate open,
otherwise, xc30x8 chip won't be visible.
For a better support, some rework is needed on cx88 driver, to allow adding
xc30x8 to i2c bus without sending i2c 0 byte reading to 0xc2 address.
Thanks to Vanessa Ezekowitz <vanessaezekowitz@gmail.com> for helping to figure
out the proper parameters for s5h1409 and the GPIO pins used by each
configuration.
Signed-off-by: Mauro Carvalho Chehab <mchehab@infradead.org>
2008-03-28 10:18:30 +08:00
|
|
|
if (attach_xc3028(0x61, dev) < 0)
|
2008-05-01 05:14:36 +08:00
|
|
|
goto frontend_detach;
|
V4L/DVB (7448): Add support for Kworld ATSC 120
This board has a s5h1409 demod, plus a xc30x8 tuner (probably, xc3018).
This patch adds proper support for radio, video, s-video, composite and ATSC.
However, support for radio and video depends on having s5h1409 i2c gate open,
otherwise, xc30x8 chip won't be visible.
For a better support, some rework is needed on cx88 driver, to allow adding
xc30x8 to i2c bus without sending i2c 0 byte reading to 0xc2 address.
Thanks to Vanessa Ezekowitz <vanessaezekowitz@gmail.com> for helping to figure
out the proper parameters for s5h1409 and the GPIO pins used by each
configuration.
Signed-off-by: Mauro Carvalho Chehab <mchehab@infradead.org>
2008-03-28 10:18:30 +08:00
|
|
|
break;
|
2008-04-25 14:46:43 +08:00
|
|
|
case CX88_BOARD_DVICO_FUSIONHDTV_7_GOLD:
|
2008-10-11 22:05:50 +08:00
|
|
|
fe0->dvb.frontend = dvb_attach(s5h1411_attach,
|
2008-04-25 14:46:43 +08:00
|
|
|
&dvico_fusionhdtv7_config,
|
2008-05-01 05:14:36 +08:00
|
|
|
&core->i2c_adap);
|
2008-10-11 22:05:50 +08:00
|
|
|
if (fe0->dvb.frontend != NULL) {
|
|
|
|
if (!dvb_attach(xc5000_attach, fe0->dvb.frontend,
|
2008-05-01 05:14:36 +08:00
|
|
|
&core->i2c_adap,
|
2008-09-07 01:56:58 +08:00
|
|
|
&dvico_fusionhdtv7_tuner_config))
|
2008-05-01 05:14:36 +08:00
|
|
|
goto frontend_detach;
|
2008-04-25 14:46:43 +08:00
|
|
|
}
|
|
|
|
break;
|
2008-09-04 12:17:33 +08:00
|
|
|
case CX88_BOARD_HAUPPAUGE_HVR4000:
|
2008-11-11 19:48:27 +08:00
|
|
|
/* MFE frontend 1 */
|
|
|
|
mfe_shared = 1;
|
|
|
|
dev->frontends.gate = 2;
|
2008-10-11 22:05:50 +08:00
|
|
|
/* DVB-S/S2 Init */
|
|
|
|
fe0->dvb.frontend = dvb_attach(cx24116_attach,
|
2008-11-11 19:48:27 +08:00
|
|
|
&hauppauge_hvr4000_config,
|
|
|
|
&dev->core->i2c_adap);
|
2008-10-11 22:05:50 +08:00
|
|
|
if (fe0->dvb.frontend) {
|
2008-11-11 19:48:27 +08:00
|
|
|
if (!dvb_attach(isl6421_attach,
|
|
|
|
fe0->dvb.frontend,
|
|
|
|
&dev->core->i2c_adap,
|
|
|
|
0x08, ISL6421_DCL, 0x00))
|
|
|
|
goto frontend_detach;
|
2008-10-11 22:05:50 +08:00
|
|
|
}
|
2008-11-11 19:48:27 +08:00
|
|
|
/* MFE frontend 2 */
|
2008-10-11 22:05:50 +08:00
|
|
|
fe1 = videobuf_dvb_get_frontend(&dev->frontends, 2);
|
2008-11-11 19:48:27 +08:00
|
|
|
if (!fe1)
|
|
|
|
goto frontend_detach;
|
|
|
|
/* DVB-T Init */
|
|
|
|
fe1->dvb.frontend = dvb_attach(cx22702_attach,
|
|
|
|
&hauppauge_hvr_config,
|
|
|
|
&dev->core->i2c_adap);
|
|
|
|
if (fe1->dvb.frontend) {
|
|
|
|
fe1->dvb.frontend->id = 1;
|
|
|
|
if (!dvb_attach(simple_tuner_attach,
|
|
|
|
fe1->dvb.frontend,
|
|
|
|
&dev->core->i2c_adap,
|
|
|
|
0x61, TUNER_PHILIPS_FMD1216ME_MK3))
|
|
|
|
goto frontend_detach;
|
2008-10-11 22:05:50 +08:00
|
|
|
}
|
|
|
|
break;
|
2008-09-04 12:17:33 +08:00
|
|
|
case CX88_BOARD_HAUPPAUGE_HVR4000LITE:
|
2008-10-11 22:05:50 +08:00
|
|
|
fe0->dvb.frontend = dvb_attach(cx24116_attach,
|
2008-11-11 19:48:27 +08:00
|
|
|
&hauppauge_hvr4000_config,
|
|
|
|
&dev->core->i2c_adap);
|
2008-10-11 22:05:50 +08:00
|
|
|
if (fe0->dvb.frontend) {
|
2008-11-11 19:48:27 +08:00
|
|
|
if (!dvb_attach(isl6421_attach,
|
|
|
|
fe0->dvb.frontend,
|
|
|
|
&dev->core->i2c_adap,
|
|
|
|
0x08, ISL6421_DCL, 0x00))
|
|
|
|
goto frontend_detach;
|
2008-09-04 12:17:33 +08:00
|
|
|
}
|
|
|
|
break;
|
2008-11-10 02:26:25 +08:00
|
|
|
case CX88_BOARD_PROF_6200:
|
2008-11-10 02:25:31 +08:00
|
|
|
case CX88_BOARD_TBS_8910:
|
2008-09-24 02:43:57 +08:00
|
|
|
case CX88_BOARD_TEVII_S420:
|
2008-10-11 22:05:50 +08:00
|
|
|
fe0->dvb.frontend = dvb_attach(stv0299_attach,
|
2008-09-24 02:43:57 +08:00
|
|
|
&tevii_tuner_sharp_config,
|
|
|
|
&core->i2c_adap);
|
2008-10-11 22:05:50 +08:00
|
|
|
if (fe0->dvb.frontend != NULL) {
|
|
|
|
if (!dvb_attach(dvb_pll_attach, fe0->dvb.frontend, 0x60,
|
2008-09-24 02:43:57 +08:00
|
|
|
&core->i2c_adap, DVB_PLL_OPERA1))
|
|
|
|
goto frontend_detach;
|
2008-10-11 22:05:50 +08:00
|
|
|
core->prev_set_voltage = fe0->dvb.frontend->ops.set_voltage;
|
|
|
|
fe0->dvb.frontend->ops.set_voltage = tevii_dvbs_set_voltage;
|
2008-09-24 02:43:57 +08:00
|
|
|
|
|
|
|
} else {
|
2008-10-11 22:05:50 +08:00
|
|
|
fe0->dvb.frontend = dvb_attach(stv0288_attach,
|
2008-09-24 02:43:57 +08:00
|
|
|
&tevii_tuner_earda_config,
|
|
|
|
&core->i2c_adap);
|
2008-10-11 22:05:50 +08:00
|
|
|
if (fe0->dvb.frontend != NULL) {
|
|
|
|
if (!dvb_attach(stb6000_attach, fe0->dvb.frontend, 0x61,
|
2008-09-24 02:43:57 +08:00
|
|
|
&core->i2c_adap))
|
|
|
|
goto frontend_detach;
|
2008-10-11 22:05:50 +08:00
|
|
|
core->prev_set_voltage = fe0->dvb.frontend->ops.set_voltage;
|
|
|
|
fe0->dvb.frontend->ops.set_voltage = tevii_dvbs_set_voltage;
|
2008-09-24 02:43:57 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
break;
|
2008-09-05 04:24:14 +08:00
|
|
|
case CX88_BOARD_TEVII_S460:
|
2008-10-11 22:05:50 +08:00
|
|
|
fe0->dvb.frontend = dvb_attach(cx24116_attach,
|
2008-09-05 04:24:14 +08:00
|
|
|
&tevii_s460_config,
|
|
|
|
&core->i2c_adap);
|
2008-11-10 01:59:33 +08:00
|
|
|
if (fe0->dvb.frontend != NULL)
|
2008-10-11 22:05:50 +08:00
|
|
|
fe0->dvb.frontend->ops.set_voltage = tevii_dvbs_set_voltage;
|
2008-09-17 22:30:21 +08:00
|
|
|
break;
|
|
|
|
case CX88_BOARD_OMICOM_SS4_PCI:
|
2008-09-17 22:58:33 +08:00
|
|
|
case CX88_BOARD_TBS_8920:
|
2008-10-08 17:48:08 +08:00
|
|
|
case CX88_BOARD_PROF_7300:
|
2008-11-10 02:25:31 +08:00
|
|
|
case CX88_BOARD_SATTRADE_ST4200:
|
2008-10-11 22:05:50 +08:00
|
|
|
fe0->dvb.frontend = dvb_attach(cx24116_attach,
|
2008-09-17 22:58:33 +08:00
|
|
|
&hauppauge_hvr4000_config,
|
|
|
|
&core->i2c_adap);
|
2008-11-10 01:59:33 +08:00
|
|
|
if (fe0->dvb.frontend != NULL)
|
2008-10-11 22:05:50 +08:00
|
|
|
fe0->dvb.frontend->ops.set_voltage = tevii_dvbs_set_voltage;
|
2008-09-05 04:24:14 +08:00
|
|
|
break;
|
2005-04-17 06:20:36 +08:00
|
|
|
default:
|
V4L/DVB (6023): cx88: Clean up some ugly and inconsistent printk()s
Get rid of the "CORE" prefix from cx88 printks. It was only used a few times,
and it makes it look like they're coming from the kernel core or something.
Fix the message, "TV tuner 60 at 0x1fe, Radio tuner -1 at 0x1fe", by adding a
"cx88[0]" prefix to be consistent, and to keep people who grep their dmesg
output for cx88 from missing it. Get rid of the addresses, which are always
wrong. The addresses are always set to -1, but because it's an unsigned 8-bit
value, the left shift converts it to the nonsense address 0x1fe.
In the cx8802 driver, some cut and pasted code prefixed lines with "CORE
cx88[0]:", which has been changed to "cx88[0]/2:" like the other printks from
the cx8802 driver.
Also fix some ugly printks in the cx8802 driver that used __FUNCTION__ for
KERN_INFO and KERN_ERR messages.
The changed printks in cx88-mpeg.c also needed lots of whitespace and
80-column fixes.
A bunch of misc changes in cx88-dvb.c and cx88-video.c to add message levels
or a consistent "cx88[?]/2" or "cx88[?]/0" prefix.
Signed-off-by: Trent Piepho <xyzzy@speakeasy.org>
Signed-off-by: Mauro Carvalho Chehab <mchehab@infradead.org>
2007-08-16 01:41:59 +08:00
|
|
|
printk(KERN_ERR "%s/2: The frontend of your DVB/ATSC card isn't supported yet\n",
|
2008-05-01 05:14:36 +08:00
|
|
|
core->name);
|
2005-04-17 06:20:36 +08:00
|
|
|
break;
|
|
|
|
}
|
2008-10-11 22:05:50 +08:00
|
|
|
|
2008-11-11 09:35:00 +08:00
|
|
|
if ( (NULL == fe0->dvb.frontend) || (fe1 && NULL == fe1->dvb.frontend) ) {
|
2008-04-23 01:45:15 +08:00
|
|
|
printk(KERN_ERR
|
|
|
|
"%s/2: frontend initialization failed\n",
|
2008-05-01 05:14:36 +08:00
|
|
|
core->name);
|
2008-11-11 19:48:27 +08:00
|
|
|
goto frontend_detach;
|
2008-04-23 01:45:15 +08:00
|
|
|
}
|
2008-09-13 00:31:45 +08:00
|
|
|
/* define general-purpose callback pointer */
|
2008-10-11 22:05:50 +08:00
|
|
|
fe0->dvb.frontend->callback = cx88_tuner_callback;
|
2008-04-23 01:45:15 +08:00
|
|
|
|
2006-12-03 07:15:51 +08:00
|
|
|
/* Ensure all frontends negotiate bus access */
|
2008-10-11 22:05:50 +08:00
|
|
|
fe0->dvb.frontend->ops.ts_bus_ctrl = cx88_dvb_bus_ctrl;
|
|
|
|
if (fe1)
|
|
|
|
fe1->dvb.frontend->ops.ts_bus_ctrl = cx88_dvb_bus_ctrl;
|
2005-04-17 06:20:36 +08:00
|
|
|
|
2005-09-13 16:25:42 +08:00
|
|
|
/* Put the analog decoder in standby to keep it quiet */
|
2008-05-01 05:14:36 +08:00
|
|
|
cx88_call_i2c_clients(core, TUNER_SET_STANDBY, NULL);
|
2005-09-13 16:25:42 +08:00
|
|
|
|
2005-04-17 06:20:36 +08:00
|
|
|
/* register everything */
|
2008-10-11 22:05:50 +08:00
|
|
|
return videobuf_dvb_register_bus(&dev->frontends, THIS_MODULE, dev,
|
2008-10-11 22:44:05 +08:00
|
|
|
&dev->pci->dev, adapter_nr, mfe_shared);
|
2008-05-01 05:14:36 +08:00
|
|
|
|
|
|
|
frontend_detach:
|
2008-10-21 22:47:50 +08:00
|
|
|
videobuf_dvb_dealloc_frontends(&dev->frontends);
|
2008-05-01 05:14:36 +08:00
|
|
|
return -EINVAL;
|
2005-04-17 06:20:36 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
/* ----------------------------------------------------------- */
|
|
|
|
|
2006-12-03 07:15:51 +08:00
|
|
|
/* CX8802 MPEG -> mini driver - We have been given the hardware */
|
|
|
|
static int cx8802_dvb_advise_acquire(struct cx8802_driver *drv)
|
2005-04-17 06:20:36 +08:00
|
|
|
{
|
2006-12-03 07:15:51 +08:00
|
|
|
struct cx88_core *core = drv->core;
|
|
|
|
int err = 0;
|
2008-04-09 10:20:00 +08:00
|
|
|
dprintk( 1, "%s\n", __func__);
|
2006-12-03 07:15:51 +08:00
|
|
|
|
2007-08-16 01:41:57 +08:00
|
|
|
switch (core->boardnr) {
|
2006-12-03 07:15:51 +08:00
|
|
|
case CX88_BOARD_HAUPPAUGE_HVR1300:
|
|
|
|
/* We arrive here with either the cx23416 or the cx22702
|
|
|
|
* on the bus. Take the bus from the cx23416 and enable the
|
|
|
|
* cx22702 demod
|
|
|
|
*/
|
|
|
|
cx_set(MO_GP0_IO, 0x00000080); /* cx22702 out of reset and enable */
|
|
|
|
cx_clear(MO_GP0_IO, 0x00000004);
|
|
|
|
udelay(1000);
|
|
|
|
break;
|
2008-10-11 22:05:50 +08:00
|
|
|
|
2008-10-11 22:18:53 +08:00
|
|
|
case CX88_BOARD_HAUPPAUGE_HVR3000:
|
2008-10-11 22:05:50 +08:00
|
|
|
case CX88_BOARD_HAUPPAUGE_HVR4000:
|
|
|
|
if(core->dvbdev->frontends.active_fe_id == 1) {
|
|
|
|
/* DVB-S/S2 Enabled */
|
|
|
|
|
|
|
|
/* Toggle reset on cx22702 leaving i2c active */
|
|
|
|
cx_write(MO_GP0_IO, (core->board.input[0].gpio0 & 0x0000ff00) | 0x00000080);
|
|
|
|
udelay(1000);
|
|
|
|
cx_clear(MO_GP0_IO, 0x00000080);
|
|
|
|
udelay(50);
|
|
|
|
cx_set(MO_GP0_IO, 0x00000080); /* cx22702 out of reset */
|
|
|
|
cx_set(MO_GP0_IO, 0x00000004); /* tri-state the cx22702 pins */
|
|
|
|
udelay(1000);
|
|
|
|
|
|
|
|
cx_write(MO_SRST_IO, 1); /* Take the cx24116/cx24123 out of reset */
|
|
|
|
core->dvbdev->ts_gen_cntrl = 0x02; /* Parallel IO */
|
|
|
|
} else
|
|
|
|
if (core->dvbdev->frontends.active_fe_id == 2) {
|
|
|
|
/* DVB-T Enabled */
|
|
|
|
|
|
|
|
/* Put the cx24116/cx24123 into reset */
|
|
|
|
cx_write(MO_SRST_IO, 0);
|
|
|
|
|
|
|
|
/* cx22702 out of reset and enable it */
|
|
|
|
cx_set(MO_GP0_IO, 0x00000080);
|
|
|
|
cx_clear(MO_GP0_IO, 0x00000004);
|
|
|
|
core->dvbdev->ts_gen_cntrl = 0x0c; /* Serial IO */
|
|
|
|
udelay(1000);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
|
2006-12-03 07:15:51 +08:00
|
|
|
default:
|
|
|
|
err = -ENODEV;
|
|
|
|
}
|
|
|
|
return err;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* CX8802 MPEG -> mini driver - We no longer have the hardware */
|
|
|
|
static int cx8802_dvb_advise_release(struct cx8802_driver *drv)
|
|
|
|
{
|
|
|
|
struct cx88_core *core = drv->core;
|
|
|
|
int err = 0;
|
2008-04-09 10:20:00 +08:00
|
|
|
dprintk( 1, "%s\n", __func__);
|
2006-12-03 07:15:51 +08:00
|
|
|
|
2007-08-16 01:41:57 +08:00
|
|
|
switch (core->boardnr) {
|
2006-12-03 07:15:51 +08:00
|
|
|
case CX88_BOARD_HAUPPAUGE_HVR1300:
|
|
|
|
/* Do Nothing, leave the cx22702 on the bus. */
|
|
|
|
break;
|
2008-10-11 22:05:50 +08:00
|
|
|
case CX88_BOARD_HAUPPAUGE_HVR3000:
|
|
|
|
case CX88_BOARD_HAUPPAUGE_HVR4000:
|
|
|
|
break;
|
2006-12-03 07:15:51 +08:00
|
|
|
default:
|
|
|
|
err = -ENODEV;
|
|
|
|
}
|
|
|
|
return err;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int cx8802_dvb_probe(struct cx8802_driver *drv)
|
|
|
|
{
|
|
|
|
struct cx88_core *core = drv->core;
|
|
|
|
struct cx8802_dev *dev = drv->core->dvbdev;
|
2008-10-30 16:07:44 +08:00
|
|
|
int err;
|
2005-04-17 06:20:36 +08:00
|
|
|
|
2008-04-09 10:20:00 +08:00
|
|
|
dprintk( 1, "%s\n", __func__);
|
2006-12-03 07:15:51 +08:00
|
|
|
dprintk( 1, " ->being probed by Card=%d Name=%s, PCI %02x:%02x\n",
|
2007-08-16 01:41:57 +08:00
|
|
|
core->boardnr,
|
2006-12-03 07:15:51 +08:00
|
|
|
core->name,
|
|
|
|
core->pci_bus,
|
|
|
|
core->pci_slot);
|
2005-04-17 06:20:36 +08:00
|
|
|
|
|
|
|
err = -ENODEV;
|
2007-08-16 01:41:57 +08:00
|
|
|
if (!(core->board.mpeg & CX88_MPEG_DVB))
|
2005-04-17 06:20:36 +08:00
|
|
|
goto fail_core;
|
|
|
|
|
2007-05-06 07:11:32 +08:00
|
|
|
/* If vp3054 isn't enabled, a stub will just return 0 */
|
2006-01-10 01:25:35 +08:00
|
|
|
err = vp3054_i2c_probe(dev);
|
|
|
|
if (0 != err)
|
2008-10-30 16:07:44 +08:00
|
|
|
goto fail_probe;
|
2006-01-10 01:25:35 +08:00
|
|
|
|
2005-04-17 06:20:36 +08:00
|
|
|
/* dvb stuff */
|
V4L/DVB (6023): cx88: Clean up some ugly and inconsistent printk()s
Get rid of the "CORE" prefix from cx88 printks. It was only used a few times,
and it makes it look like they're coming from the kernel core or something.
Fix the message, "TV tuner 60 at 0x1fe, Radio tuner -1 at 0x1fe", by adding a
"cx88[0]" prefix to be consistent, and to keep people who grep their dmesg
output for cx88 from missing it. Get rid of the addresses, which are always
wrong. The addresses are always set to -1, but because it's an unsigned 8-bit
value, the left shift converts it to the nonsense address 0x1fe.
In the cx8802 driver, some cut and pasted code prefixed lines with "CORE
cx88[0]:", which has been changed to "cx88[0]/2:" like the other printks from
the cx8802 driver.
Also fix some ugly printks in the cx8802 driver that used __FUNCTION__ for
KERN_INFO and KERN_ERR messages.
The changed printks in cx88-mpeg.c also needed lots of whitespace and
80-column fixes.
A bunch of misc changes in cx88-dvb.c and cx88-video.c to add message levels
or a consistent "cx88[?]/2" or "cx88[?]/0" prefix.
Signed-off-by: Trent Piepho <xyzzy@speakeasy.org>
Signed-off-by: Mauro Carvalho Chehab <mchehab@infradead.org>
2007-08-16 01:41:59 +08:00
|
|
|
printk(KERN_INFO "%s/2: cx2388x based DVB/ATSC card\n", core->name);
|
2008-10-11 22:05:50 +08:00
|
|
|
dev->ts_gen_cntrl = 0x0c;
|
|
|
|
|
2008-10-30 16:07:44 +08:00
|
|
|
err = -ENODEV;
|
|
|
|
if (core->board.num_frontends) {
|
|
|
|
struct videobuf_dvb_frontend *fe;
|
|
|
|
int i;
|
|
|
|
|
|
|
|
for (i = 1; i <= core->board.num_frontends; i++) {
|
|
|
|
fe = videobuf_dvb_get_frontend(&core->dvbdev->frontends, i);
|
|
|
|
if (fe == NULL) {
|
|
|
|
printk(KERN_ERR "%s() failed to get frontend(%d)\n",
|
|
|
|
__func__, i);
|
|
|
|
goto fail_probe;
|
|
|
|
}
|
|
|
|
videobuf_queue_sg_init(&fe->dvb.dvbq, &dvb_qops,
|
|
|
|
&dev->pci->dev, &dev->slock,
|
|
|
|
V4L2_BUF_TYPE_VIDEO_CAPTURE,
|
|
|
|
V4L2_FIELD_TOP,
|
|
|
|
sizeof(struct cx88_buffer),
|
|
|
|
dev);
|
|
|
|
/* init struct videobuf_dvb */
|
|
|
|
fe->dvb.name = dev->core->name;
|
2008-10-11 22:05:50 +08:00
|
|
|
}
|
2008-10-30 16:07:44 +08:00
|
|
|
} else {
|
|
|
|
/* no frontends allocated */
|
|
|
|
printk(KERN_ERR "%s/2 .num_frontends should be non-zero\n",
|
|
|
|
core->name);
|
|
|
|
goto fail_core;
|
2008-10-11 22:05:50 +08:00
|
|
|
}
|
2005-04-17 06:20:36 +08:00
|
|
|
err = dvb_register(dev);
|
2008-10-30 16:07:44 +08:00
|
|
|
if (err)
|
|
|
|
/* frontends/adapter de-allocated in dvb_register */
|
V4L/DVB (6023): cx88: Clean up some ugly and inconsistent printk()s
Get rid of the "CORE" prefix from cx88 printks. It was only used a few times,
and it makes it look like they're coming from the kernel core or something.
Fix the message, "TV tuner 60 at 0x1fe, Radio tuner -1 at 0x1fe", by adding a
"cx88[0]" prefix to be consistent, and to keep people who grep their dmesg
output for cx88 from missing it. Get rid of the addresses, which are always
wrong. The addresses are always set to -1, but because it's an unsigned 8-bit
value, the left shift converts it to the nonsense address 0x1fe.
In the cx8802 driver, some cut and pasted code prefixed lines with "CORE
cx88[0]:", which has been changed to "cx88[0]/2:" like the other printks from
the cx8802 driver.
Also fix some ugly printks in the cx8802 driver that used __FUNCTION__ for
KERN_INFO and KERN_ERR messages.
The changed printks in cx88-mpeg.c also needed lots of whitespace and
80-column fixes.
A bunch of misc changes in cx88-dvb.c and cx88-video.c to add message levels
or a consistent "cx88[?]/2" or "cx88[?]/0" prefix.
Signed-off-by: Trent Piepho <xyzzy@speakeasy.org>
Signed-off-by: Mauro Carvalho Chehab <mchehab@infradead.org>
2007-08-16 01:41:59 +08:00
|
|
|
printk(KERN_ERR "%s/2: dvb_register failed (err = %d)\n",
|
|
|
|
core->name, err);
|
2008-10-30 16:07:44 +08:00
|
|
|
return err;
|
|
|
|
fail_probe:
|
|
|
|
videobuf_dvb_dealloc_frontends(&core->dvbdev->frontends);
|
2008-10-11 22:18:53 +08:00
|
|
|
fail_core:
|
2005-04-17 06:20:36 +08:00
|
|
|
return err;
|
|
|
|
}
|
|
|
|
|
2006-12-03 07:15:51 +08:00
|
|
|
static int cx8802_dvb_remove(struct cx8802_driver *drv)
|
2005-04-17 06:20:36 +08:00
|
|
|
{
|
2008-10-21 22:18:47 +08:00
|
|
|
struct cx88_core *core = drv->core;
|
2006-12-03 07:15:51 +08:00
|
|
|
struct cx8802_dev *dev = drv->core->dvbdev;
|
2006-01-10 01:25:12 +08:00
|
|
|
|
2008-10-21 22:18:47 +08:00
|
|
|
dprintk( 1, "%s\n", __func__);
|
|
|
|
|
2008-10-11 22:05:50 +08:00
|
|
|
videobuf_dvb_unregister_bus(&dev->frontends);
|
2005-04-17 06:20:36 +08:00
|
|
|
|
2006-01-10 01:25:35 +08:00
|
|
|
vp3054_i2c_remove(dev);
|
|
|
|
|
2006-12-03 07:15:51 +08:00
|
|
|
return 0;
|
2005-04-17 06:20:36 +08:00
|
|
|
}
|
|
|
|
|
2006-12-03 07:15:51 +08:00
|
|
|
static struct cx8802_driver cx8802_dvb_driver = {
|
|
|
|
.type_id = CX88_MPEG_DVB,
|
|
|
|
.hw_access = CX8802_DRVCTL_SHARED,
|
|
|
|
.probe = cx8802_dvb_probe,
|
|
|
|
.remove = cx8802_dvb_remove,
|
|
|
|
.advise_acquire = cx8802_dvb_advise_acquire,
|
|
|
|
.advise_release = cx8802_dvb_advise_release,
|
2005-04-17 06:20:36 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
static int dvb_init(void)
|
|
|
|
{
|
V4L/DVB (6023): cx88: Clean up some ugly and inconsistent printk()s
Get rid of the "CORE" prefix from cx88 printks. It was only used a few times,
and it makes it look like they're coming from the kernel core or something.
Fix the message, "TV tuner 60 at 0x1fe, Radio tuner -1 at 0x1fe", by adding a
"cx88[0]" prefix to be consistent, and to keep people who grep their dmesg
output for cx88 from missing it. Get rid of the addresses, which are always
wrong. The addresses are always set to -1, but because it's an unsigned 8-bit
value, the left shift converts it to the nonsense address 0x1fe.
In the cx8802 driver, some cut and pasted code prefixed lines with "CORE
cx88[0]:", which has been changed to "cx88[0]/2:" like the other printks from
the cx8802 driver.
Also fix some ugly printks in the cx8802 driver that used __FUNCTION__ for
KERN_INFO and KERN_ERR messages.
The changed printks in cx88-mpeg.c also needed lots of whitespace and
80-column fixes.
A bunch of misc changes in cx88-dvb.c and cx88-video.c to add message levels
or a consistent "cx88[?]/2" or "cx88[?]/0" prefix.
Signed-off-by: Trent Piepho <xyzzy@speakeasy.org>
Signed-off-by: Mauro Carvalho Chehab <mchehab@infradead.org>
2007-08-16 01:41:59 +08:00
|
|
|
printk(KERN_INFO "cx88/2: cx2388x dvb driver version %d.%d.%d loaded\n",
|
2005-04-17 06:20:36 +08:00
|
|
|
(CX88_VERSION_CODE >> 16) & 0xff,
|
|
|
|
(CX88_VERSION_CODE >> 8) & 0xff,
|
|
|
|
CX88_VERSION_CODE & 0xff);
|
|
|
|
#ifdef SNAPSHOT
|
|
|
|
printk(KERN_INFO "cx2388x: snapshot date %04d-%02d-%02d\n",
|
|
|
|
SNAPSHOT/10000, (SNAPSHOT/100)%100, SNAPSHOT%100);
|
|
|
|
#endif
|
2006-12-03 07:15:51 +08:00
|
|
|
return cx8802_register_driver(&cx8802_dvb_driver);
|
2005-04-17 06:20:36 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
static void dvb_fini(void)
|
|
|
|
{
|
2006-12-03 07:15:51 +08:00
|
|
|
cx8802_unregister_driver(&cx8802_dvb_driver);
|
2005-04-17 06:20:36 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
module_init(dvb_init);
|
|
|
|
module_exit(dvb_fini);
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Local variables:
|
|
|
|
* c-basic-offset: 8
|
|
|
|
* compile-command: "make DVB=1"
|
|
|
|
* End:
|
|
|
|
*/
|