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"
|
2011-06-08 00:12:29 +08:00
|
|
|
#include "xc4000.h"
|
2008-01-06 03:53:01 +08:00
|
|
|
#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"
|
2009-11-17 09:22:32 +08:00
|
|
|
#include "stv0900.h"
|
|
|
|
#include "stb6100.h"
|
|
|
|
#include "stb6100_proc.h"
|
2010-08-09 21:18:32 +08:00
|
|
|
#include "mb86a16.h"
|
2011-02-26 05:41:24 +08:00
|
|
|
#include "ds3000.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");
|
[media] Stop using linux/version.h on most video drivers
All the modified drivers didn't have any version increment since
Jan, 1 2011. Several of them didn't have any version increment
for a long time, even having new features and important bug fixes
happening.
As we're now filling the QUERYCAP version with the current Kernel
Release, we don't need to maintain a per-driver version control
anymore. So, let's just use the default.
In order to preserve the Kernel module version history, a
KERNEL_VERSION() macro were added to all modified drivers, and
the extraver number were incremented.
I opted to preserve the per-driver version control to a few
pwc, pvrusb2, s2255, s5p-fimc and sh_vou.
A few drivers are still using the legacy way to handle ioctl's.
So, we can't do such change on them, otherwise, they'll break.
Those are: uvc, et61x251 and sn9c102.
The rationale is that the per-driver version control seems to be
actively maintained on those.
Yet, I think that the better for them would be to just use the
default version numbering, instead of doing that by themselves.
While here, removed a few uneeded include linux/version.h
Acked-by: Hans Verkuil <hans.verkuil@cisco.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
2011-06-25 01:45:49 +08:00
|
|
|
MODULE_VERSION(CX88_VERSION);
|
2005-04-17 06:20:36 +08:00
|
|
|
|
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]");
|
|
|
|
|
2010-12-24 13:40:46 +08:00
|
|
|
static unsigned int dvb_buf_tscnt = 32;
|
|
|
|
module_param(dvb_buf_tscnt, int, 0644);
|
|
|
|
MODULE_PARM_DESC(dvb_buf_tscnt, "DVB Buffer TS count [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;
|
2010-12-24 13:40:46 +08:00
|
|
|
dev->ts_packet_count = dvb_buf_tscnt;
|
2005-04-17 06:20:36 +08:00
|
|
|
|
|
|
|
*size = dev->ts_packet_size * dev->ts_packet_count;
|
2010-12-24 13:40:46 +08:00
|
|
|
*count = dvb_buf_tscnt;
|
2005-04-17 06:20:36 +08:00
|
|
|
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
|
|
|
}
|
|
|
|
|
2010-08-25 20:50:20 +08:00
|
|
|
static const 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;
|
|
|
|
}
|
|
|
|
|
2011-05-01 17:29:16 +08:00
|
|
|
mutex_lock(&dev->core->lock);
|
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
|
|
|
}
|
2011-05-01 17:29:37 +08:00
|
|
|
mutex_unlock(&dev->core->lock);
|
2006-12-05 12:38:58 +08:00
|
|
|
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
V4L/DVB (10190): cx88: Fix some Kbuild troubles
As Randy Dunlap <randy.dunlap@oracle.com> reported, cx88 has some compilation issues:
drivers/built-in.o: In function `cx88_call_i2c_clients':
(.text+0x20af17): undefined reference to `videobuf_dvb_get_frontend'
drivers/built-in.o: In function `cx8802_probe':
cx88-mpeg.c:(.devinit.text+0x268c4): undefined reference to `videobuf_dvb_alloc_frontend'
cx88-mpeg.c:(.devinit.text+0x268ea): undefined reference to `videobuf_dvb_dealloc_frontends'
With those configs:
CONFIG_VIDEO_CX88=y
CONFIG_VIDEO_CX88_BLACKBIRD=y
CONFIG_VIDEO_CX88_DVB=m
CONFIG_DVB_CORE=m
After carefully examining the code, with the current code, several cx88 drivers
(cx8800, cx8802, cx88_dvb and cx88_blackbird) should be compiled as a module,
if one of them is marked as such. Just fixing Kconfig could create a very complex
set of rules. Also, this hides a problem with the current approach where the dvb
functionality weren't confined inside dvb module.
What happens is that:
- cx88-i2c (part of cx8800) has some special rules if DVB;
- cx88-mpeg (cx8802 module) has also part of DVB init code;
- cx88-dvb has the rest of the dvb code;
- cx88-blackbird can be used with cx88-mpeg, having cx88-dvb or not.
So, instead of doing some tricks at Kconfig and wait for a next breakage,
this patch moves the dvb code inside cx88-i2c and cx88-mpeg into cx88-dvb.
Another problem is that cx8802 were being compiled, even without cx88-dvb
and cx88-blackbird modules.
While on this code, let's fix also a reported problem:
http://www.linuxtv.org/pipermail/linux-dvb/2009-January/031225.html
A solution for the issue were proposed here:
http://www.mail-archive.com/linux-media@vger.kernel.org/msg00021.html
Thanks to Randy, Andy, Gregoire and Thomas for helping us to detect
and solve the issues.
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
2009-01-07 03:06:07 +08:00
|
|
|
static void cx88_dvb_gate_ctrl(struct cx88_core *core, int open)
|
|
|
|
{
|
|
|
|
struct videobuf_dvb_frontends *f;
|
|
|
|
struct videobuf_dvb_frontend *fe;
|
|
|
|
|
|
|
|
if (!core->dvbdev)
|
|
|
|
return;
|
|
|
|
|
|
|
|
f = &core->dvbdev->frontends;
|
|
|
|
|
|
|
|
if (!f)
|
|
|
|
return;
|
|
|
|
|
|
|
|
if (f->gate <= 1) /* undefined or fe0 */
|
|
|
|
fe = videobuf_dvb_get_frontend(f, 1);
|
|
|
|
else
|
|
|
|
fe = videobuf_dvb_get_frontend(f, f->gate);
|
|
|
|
|
|
|
|
if (fe && fe->dvb.frontend && fe->dvb.frontend->ops.i2c_gate_ctrl)
|
|
|
|
fe->dvb.frontend->ops.i2c_gate_ctrl(fe->dvb.frontend, open);
|
|
|
|
}
|
|
|
|
|
2006-12-05 12:38:58 +08:00
|
|
|
/* ------------------------------------------------------------------ */
|
|
|
|
|
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
|
|
|
{
|
2010-08-25 20:50:20 +08:00
|
|
|
static const u8 clock_config [] = { CLOCK_CTL, 0x38, 0x39 };
|
|
|
|
static const u8 reset [] = { RESET, 0x80 };
|
|
|
|
static const u8 adc_ctl_1_cfg [] = { ADC_CTL_1, 0x40 };
|
|
|
|
static const u8 agc_cfg [] = { AGC_TARGET, 0x24, 0x20 };
|
|
|
|
static const u8 gpp_ctl_cfg [] = { GPP_CTL, 0x33 };
|
|
|
|
static const u8 capt_range_cfg[] = { CAPT_RANGE, 0x32 };
|
2005-04-17 06:20:36 +08:00
|
|
|
|
|
|
|
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)
|
|
|
|
{
|
2010-08-25 20:50:20 +08:00
|
|
|
static const u8 clock_config [] = { CLOCK_CTL, 0x38, 0x38 };
|
|
|
|
static const u8 reset [] = { RESET, 0x80 };
|
|
|
|
static const u8 adc_ctl_1_cfg [] = { ADC_CTL_1, 0x40 };
|
|
|
|
static const u8 agc_cfg [] = { AGC_TARGET, 0x28, 0x20 };
|
|
|
|
static const u8 gpp_ctl_cfg [] = { GPP_CTL, 0x33 };
|
|
|
|
static const u8 capt_range_cfg[] = { CAPT_RANGE, 0x32 };
|
2006-01-10 04:21:28 +08:00
|
|
|
|
|
|
|
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)
|
|
|
|
{
|
2010-08-25 20:50:20 +08:00
|
|
|
static const u8 clock_config [] = { 0x89, 0x38, 0x39 };
|
|
|
|
static const u8 reset [] = { 0x50, 0x80 };
|
|
|
|
static const u8 adc_ctl_1_cfg [] = { 0x8E, 0x40 };
|
|
|
|
static const u8 agc_cfg [] = { 0x67, 0x10, 0x23, 0x00, 0xFF, 0xFF,
|
2005-11-09 13:37:45 +08:00
|
|
|
0x00, 0xFF, 0x00, 0x40, 0x40 };
|
2010-08-25 20:50:20 +08:00
|
|
|
static const u8 dntv_extra[] = { 0xB5, 0x7A };
|
|
|
|
static const u8 capt_range_cfg[] = { 0x75, 0x32 };
|
2005-04-17 06:20:36 +08:00
|
|
|
|
|
|
|
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;
|
|
|
|
}
|
|
|
|
|
2010-08-25 20:50:20 +08:00
|
|
|
static const 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
|
|
|
};
|
|
|
|
|
2010-08-25 20:50:20 +08:00
|
|
|
static const struct mt352_config dntv_live_dvbt_config = {
|
2005-04-17 06:20:36 +08:00
|
|
|
.demod_address = 0x0f,
|
|
|
|
.demod_init = dntv_live_dvbt_demod_init,
|
|
|
|
};
|
2006-01-10 01:25:35 +08:00
|
|
|
|
2010-08-25 20:50:20 +08:00
|
|
|
static const 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,
|
|
|
|
};
|
|
|
|
|
2010-08-25 20:50:20 +08:00
|
|
|
static const struct zl10353_config cx88_terratec_cinergy_ht_pci_mkii_config = {
|
2009-03-11 06:08:06 +08:00
|
|
|
.demod_address = (0x1e >> 1),
|
|
|
|
.no_tuner = 1,
|
|
|
|
.if2 = 45600,
|
|
|
|
};
|
|
|
|
|
2010-08-09 21:18:32 +08:00
|
|
|
static struct mb86a16_config twinhan_vp1027 = {
|
|
|
|
.demod_address = 0x08,
|
|
|
|
};
|
|
|
|
|
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)
|
|
|
|
{
|
2010-08-25 20:50:20 +08:00
|
|
|
static const u8 clock_config [] = { 0x89, 0x38, 0x38 };
|
|
|
|
static const u8 reset [] = { 0x50, 0x80 };
|
|
|
|
static const u8 adc_ctl_1_cfg [] = { 0x8E, 0x40 };
|
|
|
|
static const u8 agc_cfg [] = { 0x67, 0x10, 0x20, 0x00, 0xFF, 0xFF,
|
2006-01-10 04:21:31 +08:00
|
|
|
0x00, 0xFF, 0x00, 0x40, 0x40 };
|
2010-08-25 20:50:20 +08:00
|
|
|
static const u8 dntv_extra[] = { 0xB5, 0x7A };
|
|
|
|
static const u8 capt_range_cfg[] = { 0x75, 0x32 };
|
2006-01-10 04:21:31 +08:00
|
|
|
|
|
|
|
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;
|
|
|
|
}
|
|
|
|
|
2010-08-25 20:50:20 +08:00
|
|
|
static const struct mt352_config dntv_live_dvbt_pro_config = {
|
2006-01-10 01:25:35 +08:00
|
|
|
.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
|
|
|
|
2010-08-25 20:50:20 +08:00
|
|
|
static const 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
|
|
|
};
|
|
|
|
|
2010-08-25 20:50:20 +08:00
|
|
|
static const struct zl10353_config dvico_fusionhdtv_xc3028 = {
|
2008-04-23 01:45:15 +08:00
|
|
|
.demod_address = 0x0f,
|
|
|
|
.if2 = 45600,
|
|
|
|
.no_tuner = 1,
|
|
|
|
};
|
|
|
|
|
2010-08-25 20:50:20 +08:00
|
|
|
static const struct mt352_config dvico_fusionhdtv_mt352_xc3028 = {
|
2008-04-23 01:45:15 +08:00
|
|
|
.demod_address = 0x0f,
|
|
|
|
.if2 = 4560,
|
|
|
|
.no_tuner = 1,
|
|
|
|
.demod_init = dvico_fusionhdtv_demod_init,
|
|
|
|
};
|
|
|
|
|
2010-08-25 20:50:20 +08:00
|
|
|
static const 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
|
|
|
};
|
|
|
|
|
2010-08-25 20:50:20 +08:00
|
|
|
static const struct cx22702_config connexant_refboard_config = {
|
2005-04-17 06:20:36 +08:00
|
|
|
.demod_address = 0x43,
|
2005-07-16 03:20:26 +08:00
|
|
|
.output_mode = CX22702_SERIAL_OUTPUT,
|
2005-04-17 06:20:36 +08:00
|
|
|
};
|
|
|
|
|
2010-08-25 20:50:20 +08:00
|
|
|
static const 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;
|
|
|
|
}
|
|
|
|
|
2010-08-25 20:50:20 +08:00
|
|
|
static const 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
|
|
|
|
2010-08-25 20:50:20 +08:00
|
|
|
static const 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
|
|
|
|
2010-08-25 20:50:20 +08:00
|
|
|
static const 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;
|
|
|
|
}
|
|
|
|
|
2010-08-25 20:50:20 +08:00
|
|
|
static const 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;
|
|
|
|
|
2009-07-30 06:18:28 +08:00
|
|
|
cx_set(MO_GP0_IO, 0x6040);
|
2008-09-05 04:24:14 +08:00
|
|
|
switch (voltage) {
|
2010-08-09 21:18:32 +08:00
|
|
|
case SEC_VOLTAGE_13:
|
|
|
|
cx_clear(MO_GP0_IO, 0x20);
|
|
|
|
break;
|
|
|
|
case SEC_VOLTAGE_18:
|
|
|
|
cx_set(MO_GP0_IO, 0x20);
|
|
|
|
break;
|
|
|
|
case SEC_VOLTAGE_OFF:
|
|
|
|
cx_clear(MO_GP0_IO, 0x20);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (core->prev_set_voltage)
|
|
|
|
return core->prev_set_voltage(fe, voltage);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int vp1027_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:
|
|
|
|
dprintk(1, "LNB SEC Voltage=13\n");
|
|
|
|
cx_write(MO_GP0_IO, 0x00001220);
|
|
|
|
break;
|
|
|
|
case SEC_VOLTAGE_18:
|
|
|
|
dprintk(1, "LNB SEC Voltage=18\n");
|
|
|
|
cx_write(MO_GP0_IO, 0x00001222);
|
|
|
|
break;
|
|
|
|
case SEC_VOLTAGE_OFF:
|
|
|
|
dprintk(1, "LNB Voltage OFF\n");
|
|
|
|
cx_write(MO_GP0_IO, 0x00001230);
|
|
|
|
break;
|
2008-09-05 04:24:14 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
if (core->prev_set_voltage)
|
|
|
|
return core->prev_set_voltage(fe, voltage);
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2010-08-25 20:50:20 +08:00
|
|
|
static const 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
|
|
|
};
|
|
|
|
|
2010-08-25 20:50:20 +08:00
|
|
|
static const 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
|
|
|
};
|
|
|
|
|
2010-08-25 20:50:20 +08:00
|
|
|
static const 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
|
|
|
};
|
|
|
|
|
2010-08-25 20:50:20 +08:00
|
|
|
static const struct s5h1409_config pinnacle_pctv_hd_800i_config = {
|
2008-01-06 03:53:01 +08:00
|
|
|
.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
|
|
|
};
|
|
|
|
|
2010-08-25 20:50:20 +08:00
|
|
|
static const struct s5h1409_config dvico_hdtv5_pci_nano_config = {
|
2008-04-23 01:45:14 +08:00
|
|
|
.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,
|
|
|
|
};
|
|
|
|
|
2010-08-25 20:50:20 +08:00
|
|
|
static const struct s5h1409_config kworld_atsc_120_config = {
|
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
|
|
|
.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,
|
|
|
|
};
|
|
|
|
|
2010-08-25 20:50:20 +08:00
|
|
|
static const struct xc5000_config pinnacle_pctv_hd_800i_tuner_config = {
|
2008-01-06 03:53:01 +08:00
|
|
|
.i2c_address = 0x64,
|
|
|
|
.if_khz = 5380,
|
|
|
|
};
|
|
|
|
|
2010-08-25 20:50:20 +08:00
|
|
|
static const struct zl10353_config cx88_pinnacle_hybrid_pctv = {
|
2008-09-06 01:33:54 +08:00
|
|
|
.demod_address = (0x1e >> 1),
|
|
|
|
.no_tuner = 1,
|
|
|
|
.if2 = 45600,
|
|
|
|
};
|
|
|
|
|
2010-08-25 20:50:20 +08:00
|
|
|
static const struct zl10353_config cx88_geniatech_x8000_mt = {
|
2009-08-20 21:14:45 +08:00
|
|
|
.demod_address = (0x1e >> 1),
|
|
|
|
.no_tuner = 1,
|
|
|
|
.disable_i2c_gate_ctrl = 1,
|
2008-04-23 01:45:15 +08:00
|
|
|
};
|
|
|
|
|
2010-08-25 20:50:20 +08:00
|
|
|
static const struct s5h1411_config dvico_fusionhdtv7_config = {
|
2008-04-25 14:46:43 +08:00
|
|
|
.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
|
|
|
|
};
|
|
|
|
|
2010-08-25 20:50:20 +08:00
|
|
|
static const struct xc5000_config dvico_fusionhdtv7_tuner_config = {
|
2008-04-25 14:46:43 +08:00
|
|
|
.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
|
|
|
|
2011-06-08 00:12:29 +08:00
|
|
|
static int attach_xc4000(struct cx8802_dev *dev, struct xc4000_config *cfg)
|
|
|
|
{
|
|
|
|
struct dvb_frontend *fe;
|
|
|
|
struct videobuf_dvb_frontend *fe0 = NULL;
|
|
|
|
|
|
|
|
/* Get the first frontend */
|
|
|
|
fe0 = videobuf_dvb_get_frontend(&dev->frontends, 1);
|
|
|
|
if (!fe0)
|
|
|
|
return -EINVAL;
|
|
|
|
|
|
|
|
if (!fe0->dvb.frontend) {
|
|
|
|
printk(KERN_ERR "%s/2: dvb frontend not attached. "
|
|
|
|
"Can't attach xc4000\n",
|
|
|
|
dev->core->name);
|
|
|
|
return -EINVAL;
|
|
|
|
}
|
|
|
|
|
|
|
|
fe = dvb_attach(xc4000_attach, fe0->dvb.frontend, &dev->core->i2c_adap,
|
|
|
|
cfg);
|
|
|
|
if (!fe) {
|
|
|
|
printk(KERN_ERR "%s/2: xc4000 attach failed\n",
|
|
|
|
dev->core->name);
|
|
|
|
dvb_frontend_detach(fe0->dvb.frontend);
|
|
|
|
dvb_unregister_frontend(fe0->dvb.frontend);
|
|
|
|
fe0->dvb.frontend = NULL;
|
|
|
|
return -EINVAL;
|
|
|
|
}
|
|
|
|
|
|
|
|
printk(KERN_INFO "%s/2: xc4000 attached\n", dev->core->name);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
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;
|
|
|
|
}
|
|
|
|
|
2009-11-17 09:22:32 +08:00
|
|
|
static int stv0900_set_ts_param(struct dvb_frontend *fe,
|
|
|
|
int is_punctured)
|
|
|
|
{
|
|
|
|
struct cx8802_dev *dev = fe->dvb->priv;
|
|
|
|
dev->ts_gen_cntrl = 0;
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2008-09-04 12:17:33 +08:00
|
|
|
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;
|
|
|
|
}
|
|
|
|
|
2010-08-25 20:50:20 +08:00
|
|
|
static const struct cx24116_config hauppauge_hvr4000_config = {
|
2008-09-04 12:17:33 +08:00
|
|
|
.demod_address = 0x05,
|
|
|
|
.set_ts_params = cx24116_set_ts_param,
|
|
|
|
.reset_device = cx24116_reset_device,
|
|
|
|
};
|
|
|
|
|
2010-08-25 20:50:20 +08:00
|
|
|
static const struct cx24116_config tevii_s460_config = {
|
2008-09-05 04:24:14 +08:00
|
|
|
.demod_address = 0x55,
|
|
|
|
.set_ts_params = cx24116_set_ts_param,
|
|
|
|
.reset_device = cx24116_reset_device,
|
|
|
|
};
|
|
|
|
|
2011-02-26 05:41:24 +08:00
|
|
|
static int ds3000_set_ts_param(struct dvb_frontend *fe,
|
|
|
|
int is_punctured)
|
|
|
|
{
|
|
|
|
struct cx8802_dev *dev = fe->dvb->priv;
|
|
|
|
dev->ts_gen_cntrl = 4;
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static struct ds3000_config tevii_ds3000_config = {
|
|
|
|
.demod_address = 0x68,
|
|
|
|
.set_ts_params = ds3000_set_ts_param,
|
|
|
|
};
|
|
|
|
|
2010-08-25 20:50:20 +08:00
|
|
|
static const struct stv0900_config prof_7301_stv0900_config = {
|
2009-11-17 09:22:32 +08:00
|
|
|
.demod_address = 0x6a,
|
|
|
|
/* demod_mode = 0,*/
|
|
|
|
.xtal = 27000000,
|
|
|
|
.clkmode = 3,/* 0-CLKI, 2-XTALI, else AUTO */
|
|
|
|
.diseqc_mode = 2,/* 2/3 PWM */
|
|
|
|
.tun1_maddress = 0,/* 0x60 */
|
|
|
|
.tun1_adc = 0,/* 2 Vpp */
|
|
|
|
.path1_mode = 3,
|
|
|
|
.set_ts_params = stv0900_set_ts_param,
|
|
|
|
};
|
|
|
|
|
2010-08-25 20:50:20 +08:00
|
|
|
static const struct stb6100_config prof_7301_stb6100_config = {
|
2009-11-17 09:22:32 +08:00
|
|
|
.tuner_address = 0x60,
|
|
|
|
.refclock = 27000000,
|
|
|
|
};
|
|
|
|
|
2010-08-25 20:50:20 +08:00
|
|
|
static const struct stv0299_config tevii_tuner_sharp_config = {
|
2008-09-24 02:43:57 +08:00
|
|
|
.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,
|
|
|
|
};
|
|
|
|
|
2010-08-25 20:50:20 +08:00
|
|
|
static const struct stv0288_config tevii_tuner_earda_config = {
|
2008-09-24 02:43:57 +08:00
|
|
|
.demod_address = 0x68,
|
|
|
|
.min_delay_ms = 100,
|
|
|
|
.set_ts_params = cx24116_set_ts_param,
|
|
|
|
};
|
|
|
|
|
2009-01-12 08:18:04 +08:00
|
|
|
static int cx8802_alloc_frontends(struct cx8802_dev *dev)
|
2005-04-17 06:20:36 +08:00
|
|
|
{
|
2008-05-01 05:14:36 +08:00
|
|
|
struct cx88_core *core = dev->core;
|
2009-01-12 08:18:04 +08:00
|
|
|
struct videobuf_dvb_frontend *fe = NULL;
|
V4L/DVB (10190): cx88: Fix some Kbuild troubles
As Randy Dunlap <randy.dunlap@oracle.com> reported, cx88 has some compilation issues:
drivers/built-in.o: In function `cx88_call_i2c_clients':
(.text+0x20af17): undefined reference to `videobuf_dvb_get_frontend'
drivers/built-in.o: In function `cx8802_probe':
cx88-mpeg.c:(.devinit.text+0x268c4): undefined reference to `videobuf_dvb_alloc_frontend'
cx88-mpeg.c:(.devinit.text+0x268ea): undefined reference to `videobuf_dvb_dealloc_frontends'
With those configs:
CONFIG_VIDEO_CX88=y
CONFIG_VIDEO_CX88_BLACKBIRD=y
CONFIG_VIDEO_CX88_DVB=m
CONFIG_DVB_CORE=m
After carefully examining the code, with the current code, several cx88 drivers
(cx8800, cx8802, cx88_dvb and cx88_blackbird) should be compiled as a module,
if one of them is marked as such. Just fixing Kconfig could create a very complex
set of rules. Also, this hides a problem with the current approach where the dvb
functionality weren't confined inside dvb module.
What happens is that:
- cx88-i2c (part of cx8800) has some special rules if DVB;
- cx88-mpeg (cx8802 module) has also part of DVB init code;
- cx88-dvb has the rest of the dvb code;
- cx88-blackbird can be used with cx88-mpeg, having cx88-dvb or not.
So, instead of doing some tricks at Kconfig and wait for a next breakage,
this patch moves the dvb code inside cx88-i2c and cx88-mpeg into cx88-dvb.
Another problem is that cx8802 were being compiled, even without cx88-dvb
and cx88-blackbird modules.
While on this code, let's fix also a reported problem:
http://www.linuxtv.org/pipermail/linux-dvb/2009-January/031225.html
A solution for the issue were proposed here:
http://www.mail-archive.com/linux-media@vger.kernel.org/msg00021.html
Thanks to Randy, Andy, Gregoire and Thomas for helping us to detect
and solve the issues.
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
2009-01-07 03:06:07 +08:00
|
|
|
int i;
|
2008-05-01 05:14:36 +08:00
|
|
|
|
V4L/DVB (10190): cx88: Fix some Kbuild troubles
As Randy Dunlap <randy.dunlap@oracle.com> reported, cx88 has some compilation issues:
drivers/built-in.o: In function `cx88_call_i2c_clients':
(.text+0x20af17): undefined reference to `videobuf_dvb_get_frontend'
drivers/built-in.o: In function `cx8802_probe':
cx88-mpeg.c:(.devinit.text+0x268c4): undefined reference to `videobuf_dvb_alloc_frontend'
cx88-mpeg.c:(.devinit.text+0x268ea): undefined reference to `videobuf_dvb_dealloc_frontends'
With those configs:
CONFIG_VIDEO_CX88=y
CONFIG_VIDEO_CX88_BLACKBIRD=y
CONFIG_VIDEO_CX88_DVB=m
CONFIG_DVB_CORE=m
After carefully examining the code, with the current code, several cx88 drivers
(cx8800, cx8802, cx88_dvb and cx88_blackbird) should be compiled as a module,
if one of them is marked as such. Just fixing Kconfig could create a very complex
set of rules. Also, this hides a problem with the current approach where the dvb
functionality weren't confined inside dvb module.
What happens is that:
- cx88-i2c (part of cx8800) has some special rules if DVB;
- cx88-mpeg (cx8802 module) has also part of DVB init code;
- cx88-dvb has the rest of the dvb code;
- cx88-blackbird can be used with cx88-mpeg, having cx88-dvb or not.
So, instead of doing some tricks at Kconfig and wait for a next breakage,
this patch moves the dvb code inside cx88-i2c and cx88-mpeg into cx88-dvb.
Another problem is that cx8802 were being compiled, even without cx88-dvb
and cx88-blackbird modules.
While on this code, let's fix also a reported problem:
http://www.linuxtv.org/pipermail/linux-dvb/2009-January/031225.html
A solution for the issue were proposed here:
http://www.mail-archive.com/linux-media@vger.kernel.org/msg00021.html
Thanks to Randy, Andy, Gregoire and Thomas for helping us to detect
and solve the issues.
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
2009-01-07 03:06:07 +08:00
|
|
|
mutex_init(&dev->frontends.lock);
|
|
|
|
INIT_LIST_HEAD(&dev->frontends.felist);
|
|
|
|
|
2009-01-12 08:18:04 +08:00
|
|
|
if (!core->board.num_frontends)
|
|
|
|
return -ENODEV;
|
|
|
|
|
V4L/DVB (10190): cx88: Fix some Kbuild troubles
As Randy Dunlap <randy.dunlap@oracle.com> reported, cx88 has some compilation issues:
drivers/built-in.o: In function `cx88_call_i2c_clients':
(.text+0x20af17): undefined reference to `videobuf_dvb_get_frontend'
drivers/built-in.o: In function `cx8802_probe':
cx88-mpeg.c:(.devinit.text+0x268c4): undefined reference to `videobuf_dvb_alloc_frontend'
cx88-mpeg.c:(.devinit.text+0x268ea): undefined reference to `videobuf_dvb_dealloc_frontends'
With those configs:
CONFIG_VIDEO_CX88=y
CONFIG_VIDEO_CX88_BLACKBIRD=y
CONFIG_VIDEO_CX88_DVB=m
CONFIG_DVB_CORE=m
After carefully examining the code, with the current code, several cx88 drivers
(cx8800, cx8802, cx88_dvb and cx88_blackbird) should be compiled as a module,
if one of them is marked as such. Just fixing Kconfig could create a very complex
set of rules. Also, this hides a problem with the current approach where the dvb
functionality weren't confined inside dvb module.
What happens is that:
- cx88-i2c (part of cx8800) has some special rules if DVB;
- cx88-mpeg (cx8802 module) has also part of DVB init code;
- cx88-dvb has the rest of the dvb code;
- cx88-blackbird can be used with cx88-mpeg, having cx88-dvb or not.
So, instead of doing some tricks at Kconfig and wait for a next breakage,
this patch moves the dvb code inside cx88-i2c and cx88-mpeg into cx88-dvb.
Another problem is that cx8802 were being compiled, even without cx88-dvb
and cx88-blackbird modules.
While on this code, let's fix also a reported problem:
http://www.linuxtv.org/pipermail/linux-dvb/2009-January/031225.html
A solution for the issue were proposed here:
http://www.mail-archive.com/linux-media@vger.kernel.org/msg00021.html
Thanks to Randy, Andy, Gregoire and Thomas for helping us to detect
and solve the issues.
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
2009-01-07 03:06:07 +08:00
|
|
|
printk(KERN_INFO "%s() allocating %d frontend(s)\n", __func__,
|
|
|
|
core->board.num_frontends);
|
|
|
|
for (i = 1; i <= core->board.num_frontends; i++) {
|
2009-01-12 08:18:04 +08:00
|
|
|
fe = videobuf_dvb_alloc_frontend(&dev->frontends, i);
|
|
|
|
if (!fe) {
|
V4L/DVB (10190): cx88: Fix some Kbuild troubles
As Randy Dunlap <randy.dunlap@oracle.com> reported, cx88 has some compilation issues:
drivers/built-in.o: In function `cx88_call_i2c_clients':
(.text+0x20af17): undefined reference to `videobuf_dvb_get_frontend'
drivers/built-in.o: In function `cx8802_probe':
cx88-mpeg.c:(.devinit.text+0x268c4): undefined reference to `videobuf_dvb_alloc_frontend'
cx88-mpeg.c:(.devinit.text+0x268ea): undefined reference to `videobuf_dvb_dealloc_frontends'
With those configs:
CONFIG_VIDEO_CX88=y
CONFIG_VIDEO_CX88_BLACKBIRD=y
CONFIG_VIDEO_CX88_DVB=m
CONFIG_DVB_CORE=m
After carefully examining the code, with the current code, several cx88 drivers
(cx8800, cx8802, cx88_dvb and cx88_blackbird) should be compiled as a module,
if one of them is marked as such. Just fixing Kconfig could create a very complex
set of rules. Also, this hides a problem with the current approach where the dvb
functionality weren't confined inside dvb module.
What happens is that:
- cx88-i2c (part of cx8800) has some special rules if DVB;
- cx88-mpeg (cx8802 module) has also part of DVB init code;
- cx88-dvb has the rest of the dvb code;
- cx88-blackbird can be used with cx88-mpeg, having cx88-dvb or not.
So, instead of doing some tricks at Kconfig and wait for a next breakage,
this patch moves the dvb code inside cx88-i2c and cx88-mpeg into cx88-dvb.
Another problem is that cx8802 were being compiled, even without cx88-dvb
and cx88-blackbird modules.
While on this code, let's fix also a reported problem:
http://www.linuxtv.org/pipermail/linux-dvb/2009-January/031225.html
A solution for the issue were proposed here:
http://www.mail-archive.com/linux-media@vger.kernel.org/msg00021.html
Thanks to Randy, Andy, Gregoire and Thomas for helping us to detect
and solve the issues.
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
2009-01-07 03:06:07 +08:00
|
|
|
printk(KERN_ERR "%s() failed to alloc\n", __func__);
|
|
|
|
videobuf_dvb_dealloc_frontends(&dev->frontends);
|
2009-01-12 08:18:04 +08:00
|
|
|
return -ENOMEM;
|
V4L/DVB (10190): cx88: Fix some Kbuild troubles
As Randy Dunlap <randy.dunlap@oracle.com> reported, cx88 has some compilation issues:
drivers/built-in.o: In function `cx88_call_i2c_clients':
(.text+0x20af17): undefined reference to `videobuf_dvb_get_frontend'
drivers/built-in.o: In function `cx8802_probe':
cx88-mpeg.c:(.devinit.text+0x268c4): undefined reference to `videobuf_dvb_alloc_frontend'
cx88-mpeg.c:(.devinit.text+0x268ea): undefined reference to `videobuf_dvb_dealloc_frontends'
With those configs:
CONFIG_VIDEO_CX88=y
CONFIG_VIDEO_CX88_BLACKBIRD=y
CONFIG_VIDEO_CX88_DVB=m
CONFIG_DVB_CORE=m
After carefully examining the code, with the current code, several cx88 drivers
(cx8800, cx8802, cx88_dvb and cx88_blackbird) should be compiled as a module,
if one of them is marked as such. Just fixing Kconfig could create a very complex
set of rules. Also, this hides a problem with the current approach where the dvb
functionality weren't confined inside dvb module.
What happens is that:
- cx88-i2c (part of cx8800) has some special rules if DVB;
- cx88-mpeg (cx8802 module) has also part of DVB init code;
- cx88-dvb has the rest of the dvb code;
- cx88-blackbird can be used with cx88-mpeg, having cx88-dvb or not.
So, instead of doing some tricks at Kconfig and wait for a next breakage,
this patch moves the dvb code inside cx88-i2c and cx88-mpeg into cx88-dvb.
Another problem is that cx8802 were being compiled, even without cx88-dvb
and cx88-blackbird modules.
While on this code, let's fix also a reported problem:
http://www.linuxtv.org/pipermail/linux-dvb/2009-January/031225.html
A solution for the issue were proposed here:
http://www.mail-archive.com/linux-media@vger.kernel.org/msg00021.html
Thanks to Randy, Andy, Gregoire and Thomas for helping us to detect
and solve the issues.
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
2009-01-07 03:06:07 +08:00
|
|
|
}
|
|
|
|
}
|
2009-01-12 08:18:04 +08:00
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2010-02-12 05:06:34 +08:00
|
|
|
|
|
|
|
|
2010-08-25 20:50:20 +08:00
|
|
|
static const u8 samsung_smt_7020_inittab[] = {
|
2010-02-12 05:06:34 +08:00
|
|
|
0x01, 0x15,
|
|
|
|
0x02, 0x00,
|
|
|
|
0x03, 0x00,
|
|
|
|
0x04, 0x7D,
|
|
|
|
0x05, 0x0F,
|
|
|
|
0x06, 0x02,
|
|
|
|
0x07, 0x00,
|
|
|
|
0x08, 0x60,
|
|
|
|
|
|
|
|
0x0A, 0xC2,
|
|
|
|
0x0B, 0x00,
|
|
|
|
0x0C, 0x01,
|
|
|
|
0x0D, 0x81,
|
|
|
|
0x0E, 0x44,
|
|
|
|
0x0F, 0x09,
|
|
|
|
0x10, 0x3C,
|
|
|
|
0x11, 0x84,
|
|
|
|
0x12, 0xDA,
|
|
|
|
0x13, 0x99,
|
|
|
|
0x14, 0x8D,
|
|
|
|
0x15, 0xCE,
|
|
|
|
0x16, 0xE8,
|
|
|
|
0x17, 0x43,
|
|
|
|
0x18, 0x1C,
|
|
|
|
0x19, 0x1B,
|
|
|
|
0x1A, 0x1D,
|
|
|
|
|
|
|
|
0x1C, 0x12,
|
|
|
|
0x1D, 0x00,
|
|
|
|
0x1E, 0x00,
|
|
|
|
0x1F, 0x00,
|
|
|
|
0x20, 0x00,
|
|
|
|
0x21, 0x00,
|
|
|
|
0x22, 0x00,
|
|
|
|
0x23, 0x00,
|
|
|
|
|
|
|
|
0x28, 0x02,
|
|
|
|
0x29, 0x28,
|
|
|
|
0x2A, 0x14,
|
|
|
|
0x2B, 0x0F,
|
|
|
|
0x2C, 0x09,
|
|
|
|
0x2D, 0x05,
|
|
|
|
|
|
|
|
0x31, 0x1F,
|
|
|
|
0x32, 0x19,
|
|
|
|
0x33, 0xFC,
|
|
|
|
0x34, 0x13,
|
|
|
|
0xff, 0xff,
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2011-12-24 23:24:33 +08:00
|
|
|
static int samsung_smt_7020_tuner_set_params(struct dvb_frontend *fe)
|
2010-02-12 05:06:34 +08:00
|
|
|
{
|
2011-12-23 23:33:05 +08:00
|
|
|
struct dtv_frontend_properties *c = &fe->dtv_property_cache;
|
2010-02-12 05:06:34 +08:00
|
|
|
struct cx8802_dev *dev = fe->dvb->priv;
|
|
|
|
u8 buf[4];
|
|
|
|
u32 div;
|
|
|
|
struct i2c_msg msg = {
|
|
|
|
.addr = 0x61,
|
|
|
|
.flags = 0,
|
|
|
|
.buf = buf,
|
|
|
|
.len = sizeof(buf) };
|
|
|
|
|
2011-12-23 23:33:05 +08:00
|
|
|
div = c->frequency / 125;
|
2010-02-12 05:06:34 +08:00
|
|
|
|
|
|
|
buf[0] = (div >> 8) & 0x7f;
|
|
|
|
buf[1] = div & 0xff;
|
|
|
|
buf[2] = 0x84; /* 0xC4 */
|
|
|
|
buf[3] = 0x00;
|
|
|
|
|
2011-12-23 23:33:05 +08:00
|
|
|
if (c->frequency < 1500000)
|
2010-02-12 05:06:34 +08:00
|
|
|
buf[3] |= 0x10;
|
|
|
|
|
|
|
|
if (fe->ops.i2c_gate_ctrl)
|
|
|
|
fe->ops.i2c_gate_ctrl(fe, 1);
|
|
|
|
|
|
|
|
if (i2c_transfer(&dev->core->i2c_adap, &msg, 1) != 1)
|
|
|
|
return -EIO;
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int samsung_smt_7020_set_tone(struct dvb_frontend *fe,
|
|
|
|
fe_sec_tone_mode_t tone)
|
|
|
|
{
|
|
|
|
struct cx8802_dev *dev = fe->dvb->priv;
|
|
|
|
struct cx88_core *core = dev->core;
|
|
|
|
|
|
|
|
cx_set(MO_GP0_IO, 0x0800);
|
|
|
|
|
|
|
|
switch (tone) {
|
|
|
|
case SEC_TONE_ON:
|
|
|
|
cx_set(MO_GP0_IO, 0x08);
|
|
|
|
break;
|
|
|
|
case SEC_TONE_OFF:
|
|
|
|
cx_clear(MO_GP0_IO, 0x08);
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
return -EINVAL;
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int samsung_smt_7020_set_voltage(struct dvb_frontend *fe,
|
|
|
|
fe_sec_voltage_t voltage)
|
|
|
|
{
|
|
|
|
struct cx8802_dev *dev = fe->dvb->priv;
|
|
|
|
struct cx88_core *core = dev->core;
|
|
|
|
|
|
|
|
u8 data;
|
|
|
|
struct i2c_msg msg = {
|
|
|
|
.addr = 8,
|
|
|
|
.flags = 0,
|
|
|
|
.buf = &data,
|
|
|
|
.len = sizeof(data) };
|
|
|
|
|
|
|
|
cx_set(MO_GP0_IO, 0x8000);
|
|
|
|
|
|
|
|
switch (voltage) {
|
|
|
|
case SEC_VOLTAGE_OFF:
|
|
|
|
break;
|
|
|
|
case SEC_VOLTAGE_13:
|
|
|
|
data = ISL6421_EN1 | ISL6421_LLC1;
|
|
|
|
cx_clear(MO_GP0_IO, 0x80);
|
|
|
|
break;
|
|
|
|
case SEC_VOLTAGE_18:
|
|
|
|
data = ISL6421_EN1 | ISL6421_LLC1 | ISL6421_VSEL1;
|
|
|
|
cx_clear(MO_GP0_IO, 0x80);
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
return -EINVAL;
|
|
|
|
};
|
|
|
|
|
|
|
|
return (i2c_transfer(&dev->core->i2c_adap, &msg, 1) == 1) ? 0 : -EIO;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int samsung_smt_7020_stv0299_set_symbol_rate(struct dvb_frontend *fe,
|
|
|
|
u32 srate, u32 ratio)
|
|
|
|
{
|
|
|
|
u8 aclk = 0;
|
|
|
|
u8 bclk = 0;
|
|
|
|
|
|
|
|
if (srate < 1500000) {
|
|
|
|
aclk = 0xb7;
|
|
|
|
bclk = 0x47;
|
|
|
|
} else if (srate < 3000000) {
|
|
|
|
aclk = 0xb7;
|
|
|
|
bclk = 0x4b;
|
|
|
|
} else if (srate < 7000000) {
|
|
|
|
aclk = 0xb7;
|
|
|
|
bclk = 0x4f;
|
|
|
|
} else if (srate < 14000000) {
|
|
|
|
aclk = 0xb7;
|
|
|
|
bclk = 0x53;
|
|
|
|
} else if (srate < 30000000) {
|
|
|
|
aclk = 0xb6;
|
|
|
|
bclk = 0x53;
|
|
|
|
} else if (srate < 45000000) {
|
|
|
|
aclk = 0xb4;
|
|
|
|
bclk = 0x51;
|
|
|
|
}
|
|
|
|
|
|
|
|
stv0299_writereg(fe, 0x13, aclk);
|
|
|
|
stv0299_writereg(fe, 0x14, bclk);
|
|
|
|
stv0299_writereg(fe, 0x1f, (ratio >> 16) & 0xff);
|
|
|
|
stv0299_writereg(fe, 0x20, (ratio >> 8) & 0xff);
|
|
|
|
stv0299_writereg(fe, 0x21, ratio & 0xf0);
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2010-08-25 20:50:20 +08:00
|
|
|
static const struct stv0299_config samsung_stv0299_config = {
|
2010-02-12 05:06:34 +08:00
|
|
|
.demod_address = 0x68,
|
|
|
|
.inittab = samsung_smt_7020_inittab,
|
|
|
|
.mclk = 88000000UL,
|
|
|
|
.invert = 0,
|
|
|
|
.skip_reinit = 0,
|
|
|
|
.lock_output = STV0299_LOCKOUTPUT_LK,
|
|
|
|
.volt13_op0_op1 = STV0299_VOLT13_OP1,
|
|
|
|
.min_delay_ms = 100,
|
|
|
|
.set_symbol_rate = samsung_smt_7020_stv0299_set_symbol_rate,
|
|
|
|
};
|
|
|
|
|
2009-01-12 08:18:04 +08:00
|
|
|
static int dvb_register(struct cx8802_dev *dev)
|
|
|
|
{
|
|
|
|
struct cx88_core *core = dev->core;
|
|
|
|
struct videobuf_dvb_frontend *fe0, *fe1 = NULL;
|
|
|
|
int mfe_shared = 0; /* bus not shared by default */
|
2011-12-15 12:59:20 +08:00
|
|
|
int res = -EINVAL;
|
2009-01-12 08:18:04 +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;
|
|
|
|
}
|
V4L/DVB (10190): cx88: Fix some Kbuild troubles
As Randy Dunlap <randy.dunlap@oracle.com> reported, cx88 has some compilation issues:
drivers/built-in.o: In function `cx88_call_i2c_clients':
(.text+0x20af17): undefined reference to `videobuf_dvb_get_frontend'
drivers/built-in.o: In function `cx8802_probe':
cx88-mpeg.c:(.devinit.text+0x268c4): undefined reference to `videobuf_dvb_alloc_frontend'
cx88-mpeg.c:(.devinit.text+0x268ea): undefined reference to `videobuf_dvb_dealloc_frontends'
With those configs:
CONFIG_VIDEO_CX88=y
CONFIG_VIDEO_CX88_BLACKBIRD=y
CONFIG_VIDEO_CX88_DVB=m
CONFIG_DVB_CORE=m
After carefully examining the code, with the current code, several cx88 drivers
(cx8800, cx8802, cx88_dvb and cx88_blackbird) should be compiled as a module,
if one of them is marked as such. Just fixing Kconfig could create a very complex
set of rules. Also, this hides a problem with the current approach where the dvb
functionality weren't confined inside dvb module.
What happens is that:
- cx88-i2c (part of cx8800) has some special rules if DVB;
- cx88-mpeg (cx8802 module) has also part of DVB init code;
- cx88-dvb has the rest of the dvb code;
- cx88-blackbird can be used with cx88-mpeg, having cx88-dvb or not.
So, instead of doing some tricks at Kconfig and wait for a next breakage,
this patch moves the dvb code inside cx88-i2c and cx88-mpeg into cx88-dvb.
Another problem is that cx8802 were being compiled, even without cx88-dvb
and cx88-blackbird modules.
While on this code, let's fix also a reported problem:
http://www.linuxtv.org/pipermail/linux-dvb/2009-January/031225.html
A solution for the issue were proposed here:
http://www.mail-archive.com/linux-media@vger.kernel.org/msg00021.html
Thanks to Randy, Andy, Gregoire and Thomas for helping us to detect
and solve the issues.
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
2009-01-07 03:06:07 +08:00
|
|
|
|
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;
|
|
|
|
|
V4L/DVB (10190): cx88: Fix some Kbuild troubles
As Randy Dunlap <randy.dunlap@oracle.com> reported, cx88 has some compilation issues:
drivers/built-in.o: In function `cx88_call_i2c_clients':
(.text+0x20af17): undefined reference to `videobuf_dvb_get_frontend'
drivers/built-in.o: In function `cx8802_probe':
cx88-mpeg.c:(.devinit.text+0x268c4): undefined reference to `videobuf_dvb_alloc_frontend'
cx88-mpeg.c:(.devinit.text+0x268ea): undefined reference to `videobuf_dvb_dealloc_frontends'
With those configs:
CONFIG_VIDEO_CX88=y
CONFIG_VIDEO_CX88_BLACKBIRD=y
CONFIG_VIDEO_CX88_DVB=m
CONFIG_DVB_CORE=m
After carefully examining the code, with the current code, several cx88 drivers
(cx8800, cx8802, cx88_dvb and cx88_blackbird) should be compiled as a module,
if one of them is marked as such. Just fixing Kconfig could create a very complex
set of rules. Also, this hides a problem with the current approach where the dvb
functionality weren't confined inside dvb module.
What happens is that:
- cx88-i2c (part of cx8800) has some special rules if DVB;
- cx88-mpeg (cx8802 module) has also part of DVB init code;
- cx88-dvb has the rest of the dvb code;
- cx88-blackbird can be used with cx88-mpeg, having cx88-dvb or not.
So, instead of doing some tricks at Kconfig and wait for a next breakage,
this patch moves the dvb code inside cx88-i2c and cx88-mpeg into cx88-dvb.
Another problem is that cx8802 were being compiled, even without cx88-dvb
and cx88-blackbird modules.
While on this code, let's fix also a reported problem:
http://www.linuxtv.org/pipermail/linux-dvb/2009-January/031225.html
A solution for the issue were proposed here:
http://www.mail-archive.com/linux-media@vger.kernel.org/msg00021.html
Thanks to Randy, Andy, Gregoire and Thomas for helping us to detect
and solve the issues.
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
2009-01-07 03:06:07 +08:00
|
|
|
/* Sets the gate control callback to be used by i2c command calls */
|
|
|
|
core->gate_ctrl = cx88_dvb_gate_ctrl;
|
|
|
|
|
2008-10-11 22:31:41 +08:00
|
|
|
/* 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;
|
2011-12-14 02:36:15 +08:00
|
|
|
case CX88_BOARD_WINFAST_DTV2000H_J:
|
|
|
|
fe0->dvb.frontend = dvb_attach(cx22702_attach,
|
|
|
|
&hauppauge_hvr_config,
|
|
|
|
&core->i2c_adap);
|
|
|
|
if (fe0->dvb.frontend != NULL) {
|
|
|
|
if (!dvb_attach(simple_tuner_attach, fe0->dvb.frontend,
|
|
|
|
&core->i2c_adap, 0x61,
|
|
|
|
TUNER_PHILIPS_FMD1216MEX_MK3))
|
|
|
|
goto frontend_detach;
|
|
|
|
}
|
|
|
|
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;
|
2010-04-06 13:40:43 +08:00
|
|
|
case CX88_BOARD_PINNACLE_HYBRID_PCTV:
|
2009-06-01 03:47:28 +08:00
|
|
|
case CX88_BOARD_WINFAST_DTV1800H:
|
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;
|
2011-06-08 00:16:56 +08:00
|
|
|
case CX88_BOARD_WINFAST_DTV1800H_XC4000:
|
2011-06-08 00:14:53 +08:00
|
|
|
case CX88_BOARD_WINFAST_DTV2000H_PLUS:
|
|
|
|
fe0->dvb.frontend = dvb_attach(zl10353_attach,
|
|
|
|
&cx88_pinnacle_hybrid_pctv,
|
|
|
|
&core->i2c_adap);
|
|
|
|
if (fe0->dvb.frontend) {
|
|
|
|
struct xc4000_config cfg = {
|
|
|
|
.i2c_address = 0x61,
|
|
|
|
.default_pm = 0,
|
|
|
|
.dvb_amplitude = 134,
|
|
|
|
.set_smoothedcvbs = 1,
|
|
|
|
.if_khz = 4560
|
|
|
|
};
|
|
|
|
fe0->dvb.frontend->ops.i2c_gate_ctrl = NULL;
|
|
|
|
if (attach_xc4000(dev, &cfg) < 0)
|
|
|
|
goto frontend_detach;
|
|
|
|
}
|
|
|
|
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;
|
2011-02-26 05:41:24 +08:00
|
|
|
case CX88_BOARD_TEVII_S464:
|
|
|
|
fe0->dvb.frontend = dvb_attach(ds3000_attach,
|
|
|
|
&tevii_ds3000_config,
|
|
|
|
&core->i2c_adap);
|
|
|
|
if (fe0->dvb.frontend != NULL)
|
|
|
|
fe0->dvb.frontend->ops.set_voltage =
|
|
|
|
tevii_dvbs_set_voltage;
|
|
|
|
break;
|
2008-09-17 22:30:21 +08:00
|
|
|
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;
|
2009-03-11 06:08:06 +08:00
|
|
|
case CX88_BOARD_TERRATEC_CINERGY_HT_PCI_MKII:
|
|
|
|
fe0->dvb.frontend = dvb_attach(zl10353_attach,
|
|
|
|
&cx88_terratec_cinergy_ht_pci_mkii_config,
|
|
|
|
&core->i2c_adap);
|
|
|
|
if (fe0->dvb.frontend) {
|
|
|
|
fe0->dvb.frontend->ops.i2c_gate_ctrl = NULL;
|
|
|
|
if (attach_xc3028(0x61, dev) < 0)
|
|
|
|
goto frontend_detach;
|
|
|
|
}
|
|
|
|
break;
|
2009-11-17 09:22:32 +08:00
|
|
|
case CX88_BOARD_PROF_7301:{
|
|
|
|
struct dvb_tuner_ops *tuner_ops = NULL;
|
|
|
|
|
|
|
|
fe0->dvb.frontend = dvb_attach(stv0900_attach,
|
|
|
|
&prof_7301_stv0900_config,
|
|
|
|
&core->i2c_adap, 0);
|
|
|
|
if (fe0->dvb.frontend != NULL) {
|
|
|
|
if (!dvb_attach(stb6100_attach, fe0->dvb.frontend,
|
|
|
|
&prof_7301_stb6100_config,
|
|
|
|
&core->i2c_adap))
|
|
|
|
goto frontend_detach;
|
|
|
|
|
|
|
|
tuner_ops = &fe0->dvb.frontend->ops.tuner_ops;
|
|
|
|
tuner_ops->set_frequency = stb6100_set_freq;
|
|
|
|
tuner_ops->get_frequency = stb6100_get_freq;
|
|
|
|
tuner_ops->set_bandwidth = stb6100_set_bandw;
|
|
|
|
tuner_ops->get_bandwidth = stb6100_get_bandw;
|
|
|
|
|
|
|
|
core->prev_set_voltage =
|
|
|
|
fe0->dvb.frontend->ops.set_voltage;
|
|
|
|
fe0->dvb.frontend->ops.set_voltage =
|
|
|
|
tevii_dvbs_set_voltage;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
2010-02-12 05:06:34 +08:00
|
|
|
case CX88_BOARD_SAMSUNG_SMT_7020:
|
|
|
|
dev->ts_gen_cntrl = 0x08;
|
|
|
|
|
|
|
|
cx_set(MO_GP0_IO, 0x0101);
|
|
|
|
|
|
|
|
cx_clear(MO_GP0_IO, 0x01);
|
|
|
|
mdelay(100);
|
|
|
|
cx_set(MO_GP0_IO, 0x01);
|
|
|
|
mdelay(200);
|
|
|
|
|
|
|
|
fe0->dvb.frontend = dvb_attach(stv0299_attach,
|
|
|
|
&samsung_stv0299_config,
|
|
|
|
&dev->core->i2c_adap);
|
|
|
|
if (fe0->dvb.frontend) {
|
|
|
|
fe0->dvb.frontend->ops.tuner_ops.set_params =
|
|
|
|
samsung_smt_7020_tuner_set_params;
|
|
|
|
fe0->dvb.frontend->tuner_priv =
|
|
|
|
&dev->core->i2c_adap;
|
|
|
|
fe0->dvb.frontend->ops.set_voltage =
|
|
|
|
samsung_smt_7020_set_voltage;
|
|
|
|
fe0->dvb.frontend->ops.set_tone =
|
|
|
|
samsung_smt_7020_set_tone;
|
|
|
|
}
|
|
|
|
|
|
|
|
break;
|
2010-08-09 21:18:32 +08:00
|
|
|
case CX88_BOARD_TWINHAN_VP1027_DVBS:
|
|
|
|
dev->ts_gen_cntrl = 0x00;
|
|
|
|
fe0->dvb.frontend = dvb_attach(mb86a16_attach,
|
|
|
|
&twinhan_vp1027,
|
|
|
|
&core->i2c_adap);
|
|
|
|
if (fe0->dvb.frontend) {
|
|
|
|
core->prev_set_voltage =
|
|
|
|
fe0->dvb.frontend->ops.set_voltage;
|
|
|
|
fe0->dvb.frontend->ops.set_voltage =
|
|
|
|
vp1027_set_voltage;
|
|
|
|
}
|
|
|
|
break;
|
2010-02-12 05:06:34 +08:00
|
|
|
|
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 */
|
2009-10-05 21:48:17 +08:00
|
|
|
call_all(core, core, s_power, 0);
|
2005-09-13 16:25:42 +08:00
|
|
|
|
2005-04-17 06:20:36 +08:00
|
|
|
/* register everything */
|
2011-12-15 12:59:20 +08:00
|
|
|
res = videobuf_dvb_register_bus(&dev->frontends, THIS_MODULE, dev,
|
|
|
|
&dev->pci->dev, adapter_nr, mfe_shared, NULL);
|
|
|
|
if (res)
|
|
|
|
goto frontend_detach;
|
|
|
|
return res;
|
2008-05-01 05:14:36 +08:00
|
|
|
|
|
|
|
frontend_detach:
|
V4L/DVB (10190): cx88: Fix some Kbuild troubles
As Randy Dunlap <randy.dunlap@oracle.com> reported, cx88 has some compilation issues:
drivers/built-in.o: In function `cx88_call_i2c_clients':
(.text+0x20af17): undefined reference to `videobuf_dvb_get_frontend'
drivers/built-in.o: In function `cx8802_probe':
cx88-mpeg.c:(.devinit.text+0x268c4): undefined reference to `videobuf_dvb_alloc_frontend'
cx88-mpeg.c:(.devinit.text+0x268ea): undefined reference to `videobuf_dvb_dealloc_frontends'
With those configs:
CONFIG_VIDEO_CX88=y
CONFIG_VIDEO_CX88_BLACKBIRD=y
CONFIG_VIDEO_CX88_DVB=m
CONFIG_DVB_CORE=m
After carefully examining the code, with the current code, several cx88 drivers
(cx8800, cx8802, cx88_dvb and cx88_blackbird) should be compiled as a module,
if one of them is marked as such. Just fixing Kconfig could create a very complex
set of rules. Also, this hides a problem with the current approach where the dvb
functionality weren't confined inside dvb module.
What happens is that:
- cx88-i2c (part of cx8800) has some special rules if DVB;
- cx88-mpeg (cx8802 module) has also part of DVB init code;
- cx88-dvb has the rest of the dvb code;
- cx88-blackbird can be used with cx88-mpeg, having cx88-dvb or not.
So, instead of doing some tricks at Kconfig and wait for a next breakage,
this patch moves the dvb code inside cx88-i2c and cx88-mpeg into cx88-dvb.
Another problem is that cx8802 were being compiled, even without cx88-dvb
and cx88-blackbird modules.
While on this code, let's fix also a reported problem:
http://www.linuxtv.org/pipermail/linux-dvb/2009-January/031225.html
A solution for the issue were proposed here:
http://www.mail-archive.com/linux-media@vger.kernel.org/msg00021.html
Thanks to Randy, Andy, Gregoire and Thomas for helping us to detect
and solve the issues.
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
2009-01-07 03:06:07 +08:00
|
|
|
core->gate_ctrl = NULL;
|
2008-10-21 22:47:50 +08:00
|
|
|
videobuf_dvb_dealloc_frontends(&dev->frontends);
|
2011-12-15 12:59:20 +08:00
|
|
|
return res;
|
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
|
|
|
|
*/
|
2008-12-18 17:28:35 +08:00
|
|
|
/* Toggle reset on cx22702 leaving i2c active */
|
|
|
|
cx_set(MO_GP0_IO, 0x00000080);
|
|
|
|
udelay(1000);
|
|
|
|
cx_clear(MO_GP0_IO, 0x00000080);
|
|
|
|
udelay(50);
|
|
|
|
cx_set(MO_GP0_IO, 0x00000080);
|
|
|
|
udelay(1000);
|
|
|
|
/* enable the cx22702 pins */
|
2006-12-03 07:15:51 +08:00
|
|
|
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:
|
2008-12-18 17:28:35 +08:00
|
|
|
/* Toggle reset on cx22702 leaving i2c active */
|
|
|
|
cx_set(MO_GP0_IO, 0x00000080);
|
|
|
|
udelay(1000);
|
|
|
|
cx_clear(MO_GP0_IO, 0x00000080);
|
|
|
|
udelay(50);
|
|
|
|
cx_set(MO_GP0_IO, 0x00000080);
|
|
|
|
udelay(1000);
|
|
|
|
switch (core->dvbdev->frontends.active_fe_id) {
|
|
|
|
case 1: /* DVB-S/S2 Enabled */
|
|
|
|
/* tri-state the cx22702 pins */
|
|
|
|
cx_set(MO_GP0_IO, 0x00000004);
|
|
|
|
/* Take the cx24116/cx24123 out of reset */
|
|
|
|
cx_write(MO_SRST_IO, 1);
|
2008-10-11 22:05:50 +08:00
|
|
|
core->dvbdev->ts_gen_cntrl = 0x02; /* Parallel IO */
|
2008-12-18 17:28:35 +08:00
|
|
|
break;
|
|
|
|
case 2: /* DVB-T Enabled */
|
2008-10-11 22:05:50 +08:00
|
|
|
/* Put the cx24116/cx24123 into reset */
|
|
|
|
cx_write(MO_SRST_IO, 0);
|
2008-12-18 17:28:35 +08:00
|
|
|
/* enable the cx22702 pins */
|
2008-10-11 22:05:50 +08:00
|
|
|
cx_clear(MO_GP0_IO, 0x00000004);
|
|
|
|
core->dvbdev->ts_gen_cntrl = 0x0c; /* Serial IO */
|
2008-12-18 17:28:35 +08:00
|
|
|
break;
|
2008-10-11 22:05:50 +08:00
|
|
|
}
|
2008-12-18 17:28:35 +08:00
|
|
|
udelay(1000);
|
2008-10-11 22:05:50 +08:00
|
|
|
break;
|
|
|
|
|
2011-06-08 00:14:53 +08:00
|
|
|
case CX88_BOARD_WINFAST_DTV2000H_PLUS:
|
|
|
|
/* set RF input to AIR for DVB-T (GPIO 16) */
|
|
|
|
cx_write(MO_GP2_IO, 0x0101);
|
|
|
|
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;
|
2009-01-12 08:18:04 +08:00
|
|
|
struct videobuf_dvb_frontend *fe;
|
|
|
|
int i;
|
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)
|
2009-01-12 08:18:04 +08:00
|
|
|
goto fail_core;
|
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;
|
|
|
|
|
2009-01-12 08:18:04 +08:00
|
|
|
err = cx8802_alloc_frontends(dev);
|
|
|
|
if (err)
|
|
|
|
goto fail_core;
|
|
|
|
|
2008-10-30 16:07:44 +08:00
|
|
|
err = -ENODEV;
|
2009-01-12 08:18:04 +08:00
|
|
|
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",
|
2008-10-30 16:07:44 +08:00
|
|
|
__func__, i);
|
2009-01-12 08:18:04 +08:00
|
|
|
goto fail_probe;
|
|
|
|
}
|
|
|
|
videobuf_queue_sg_init(&fe->dvb.dvbq, &dvb_qops,
|
2008-10-30 16:07:44 +08:00
|
|
|
&dev->pci->dev, &dev->slock,
|
|
|
|
V4L2_BUF_TYPE_VIDEO_CAPTURE,
|
|
|
|
V4L2_FIELD_TOP,
|
|
|
|
sizeof(struct cx88_buffer),
|
2010-09-21 04:39:46 +08:00
|
|
|
dev, NULL);
|
2009-01-12 08:18:04 +08:00
|
|
|
/* init struct videobuf_dvb */
|
|
|
|
fe->dvb.name = dev->core->name;
|
2008-10-11 22:05:50 +08:00
|
|
|
}
|
2009-01-12 08:18:04 +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);
|
|
|
|
|
V4L/DVB (10190): cx88: Fix some Kbuild troubles
As Randy Dunlap <randy.dunlap@oracle.com> reported, cx88 has some compilation issues:
drivers/built-in.o: In function `cx88_call_i2c_clients':
(.text+0x20af17): undefined reference to `videobuf_dvb_get_frontend'
drivers/built-in.o: In function `cx8802_probe':
cx88-mpeg.c:(.devinit.text+0x268c4): undefined reference to `videobuf_dvb_alloc_frontend'
cx88-mpeg.c:(.devinit.text+0x268ea): undefined reference to `videobuf_dvb_dealloc_frontends'
With those configs:
CONFIG_VIDEO_CX88=y
CONFIG_VIDEO_CX88_BLACKBIRD=y
CONFIG_VIDEO_CX88_DVB=m
CONFIG_DVB_CORE=m
After carefully examining the code, with the current code, several cx88 drivers
(cx8800, cx8802, cx88_dvb and cx88_blackbird) should be compiled as a module,
if one of them is marked as such. Just fixing Kconfig could create a very complex
set of rules. Also, this hides a problem with the current approach where the dvb
functionality weren't confined inside dvb module.
What happens is that:
- cx88-i2c (part of cx8800) has some special rules if DVB;
- cx88-mpeg (cx8802 module) has also part of DVB init code;
- cx88-dvb has the rest of the dvb code;
- cx88-blackbird can be used with cx88-mpeg, having cx88-dvb or not.
So, instead of doing some tricks at Kconfig and wait for a next breakage,
this patch moves the dvb code inside cx88-i2c and cx88-mpeg into cx88-dvb.
Another problem is that cx8802 were being compiled, even without cx88-dvb
and cx88-blackbird modules.
While on this code, let's fix also a reported problem:
http://www.linuxtv.org/pipermail/linux-dvb/2009-January/031225.html
A solution for the issue were proposed here:
http://www.mail-archive.com/linux-media@vger.kernel.org/msg00021.html
Thanks to Randy, Andy, Gregoire and Thomas for helping us to detect
and solve the issues.
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
2009-01-07 03:06:07 +08:00
|
|
|
core->gate_ctrl = NULL;
|
|
|
|
|
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
|
|
|
};
|
|
|
|
|
2009-07-17 07:00:01 +08:00
|
|
|
static int __init dvb_init(void)
|
2005-04-17 06:20:36 +08:00
|
|
|
{
|
[media] Stop using linux/version.h on most video drivers
All the modified drivers didn't have any version increment since
Jan, 1 2011. Several of them didn't have any version increment
for a long time, even having new features and important bug fixes
happening.
As we're now filling the QUERYCAP version with the current Kernel
Release, we don't need to maintain a per-driver version control
anymore. So, let's just use the default.
In order to preserve the Kernel module version history, a
KERNEL_VERSION() macro were added to all modified drivers, and
the extraver number were incremented.
I opted to preserve the per-driver version control to a few
pwc, pvrusb2, s2255, s5p-fimc and sh_vou.
A few drivers are still using the legacy way to handle ioctl's.
So, we can't do such change on them, otherwise, they'll break.
Those are: uvc, et61x251 and sn9c102.
The rationale is that the per-driver version control seems to be
actively maintained on those.
Yet, I think that the better for them would be to just use the
default version numbering, instead of doing that by themselves.
While here, removed a few uneeded include linux/version.h
Acked-by: Hans Verkuil <hans.verkuil@cisco.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
2011-06-25 01:45:49 +08:00
|
|
|
printk(KERN_INFO "cx88/2: cx2388x dvb driver version %s loaded\n",
|
|
|
|
CX88_VERSION);
|
2006-12-03 07:15:51 +08:00
|
|
|
return cx8802_register_driver(&cx8802_dvb_driver);
|
2005-04-17 06:20:36 +08:00
|
|
|
}
|
|
|
|
|
2009-07-17 07:00:01 +08:00
|
|
|
static void __exit dvb_fini(void)
|
2005-04-17 06:20:36 +08:00
|
|
|
{
|
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);
|