Merge git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/v4l-dvb
* git://git.kernel.org/pub/scm/linux/kernel/git/mchehab/v4l-dvb: (70 commits) V4L/DVB (7900): pvrusb: Fix Kconfig if DVB=m V4L_core=y V4L/DVB (7899): Fixes a few remaining Kbuild issues at common/tuners V4L/DVB (7898): Fix VIDEO_MEDIA Kconfig logic V4L/DVB (7895): tveeprom: update Hauppauge analog audio and video decoders V4L/DVB (7893): xc5000: bug-fix: allow multiple devices in a single system V4L/DVB (7891): cx18/ivtv: fix open() kernel oops V4L/DVB (7890): cx18: removed bogus and confusing conditional V4L/DVB (7889): cx18: improve HVR-1600 detection. V4L/DVB (7888): cx18: minor card definition updates. V4L/DVB (7887): cx18: fix Compro H900 analog support. V4L/DVB (7881): saa7134: fixed a compile warning in saa7134-core.c V4L/DVB (7880): saa7134: remove explicit GPIO initialization V4L/DVB(7879): Adding cx18 Support for mxl5005s V4L/DVB(7878): mxl55005s: Makefile and Kconfig additions V4L/DVB(7877): mxl5005s: Ensure debug is off V4L/DVB(7876): mxl5005s: Remove incorrect copyright holders V4L/DVB(7875): mxl5005s: Remove redundant functions V4L/DVB(7874): mxl5005s: Fix function statics V4L/DVB(7873): mxl5005s: Fix header includes. V4L/DVB(7872): mxl5005s: checkpatch.pl compliance ...
This commit is contained in:
commit
4717df5830
76 changed files with 4976 additions and 498 deletions
|
@ -5,6 +5,6 @@
|
|||
4 -> DViCO FusionHDTV5 Express [18ac:d500]
|
||||
5 -> Hauppauge WinTV-HVR1500Q [0070:7790,0070:7797]
|
||||
6 -> Hauppauge WinTV-HVR1500 [0070:7710,0070:7717]
|
||||
7 -> Hauppauge WinTV-HVR1200 [0070:71d1]
|
||||
7 -> Hauppauge WinTV-HVR1200 [0070:71d1,0070:71d3]
|
||||
8 -> Hauppauge WinTV-HVR1700 [0070:8101]
|
||||
9 -> Hauppauge WinTV-HVR1400 [0070:8010]
|
||||
|
|
|
@ -14,4 +14,4 @@
|
|||
13 -> Terratec Prodigy XS (em2880) [0ccd:0047]
|
||||
14 -> Pixelview Prolink PlayTV USB 2.0 (em2820/em2840)
|
||||
15 -> V-Gear PocketTV (em2800)
|
||||
16 -> Hauppauge WinTV HVR 950 (em2880) [2040:6513]
|
||||
16 -> Hauppauge WinTV HVR 950 (em2880) [2040:6513,2040:6517,2040:651b,2040:651f]
|
||||
|
|
|
@ -1230,6 +1230,15 @@ P: Jaya Kumar
|
|||
M: jayakumar.alsa@gmail.com
|
||||
S: Maintained
|
||||
|
||||
CX18 VIDEO4LINUX DRIVER
|
||||
P: Hans Verkuil, Andy Walls
|
||||
M: hverkuil@xs4all.nl, awalls@radix.net
|
||||
L: ivtv-devel@ivtvdriver.org
|
||||
L: ivtv-users@ivtvdriver.org
|
||||
L: video4linux-list@redhat.com
|
||||
W: http://linuxtv.org
|
||||
S: Maintained
|
||||
|
||||
CYBERPRO FB DRIVER
|
||||
P: Russell King
|
||||
M: rmk@arm.linux.org.uk
|
||||
|
|
|
@ -89,8 +89,7 @@ config DVB_CORE
|
|||
|
||||
config VIDEO_MEDIA
|
||||
tristate
|
||||
default DVB_CORE || VIDEO_DEV
|
||||
depends on DVB_CORE || VIDEO_DEV
|
||||
default (DVB_CORE && (VIDEO_DEV = n)) || (VIDEO_DEV && (DVB_CORE = n)) || (DVB_CORE && VIDEO_DEV)
|
||||
|
||||
comment "Multimedia drivers"
|
||||
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
config MEDIA_ATTACH
|
||||
bool "Load and attach frontend and tuner driver modules as needed"
|
||||
depends on DVB_CORE
|
||||
depends on VIDEO_MEDIA
|
||||
depends on MODULES
|
||||
help
|
||||
Remove the static dependency of DVB card drivers on all
|
||||
|
@ -19,10 +19,10 @@ config MEDIA_ATTACH
|
|||
|
||||
config MEDIA_TUNER
|
||||
tristate
|
||||
default DVB_CORE || VIDEO_DEV
|
||||
depends on DVB_CORE || VIDEO_DEV
|
||||
select MEDIA_TUNER_XC2028 if !MEDIA_TUNER_CUSTOMIZE
|
||||
select MEDIA_TUNER_XC5000 if !MEDIA_TUNER_CUSTOMIZE
|
||||
default VIDEO_MEDIA && I2C
|
||||
depends on VIDEO_MEDIA && I2C
|
||||
select MEDIA_TUNER_XC2028 if !MEDIA_TUNER_CUSTOMIZE && HOTPLUG
|
||||
select MEDIA_TUNER_XC5000 if !MEDIA_TUNER_CUSTOMIZE && HOTPLUG
|
||||
select MEDIA_TUNER_MT20XX if !MEDIA_TUNER_CUSTOMIZE
|
||||
select MEDIA_TUNER_TDA8290 if !MEDIA_TUNER_CUSTOMIZE
|
||||
select MEDIA_TUNER_TEA5761 if !MEDIA_TUNER_CUSTOMIZE
|
||||
|
@ -46,7 +46,7 @@ if MEDIA_TUNER_CUSTOMIZE
|
|||
|
||||
config MEDIA_TUNER_SIMPLE
|
||||
tristate "Simple tuner support"
|
||||
depends on I2C
|
||||
depends on VIDEO_MEDIA && I2C
|
||||
select MEDIA_TUNER_TDA9887
|
||||
default m if MEDIA_TUNER_CUSTOMIZE
|
||||
help
|
||||
|
@ -54,7 +54,7 @@ config MEDIA_TUNER_SIMPLE
|
|||
|
||||
config MEDIA_TUNER_TDA8290
|
||||
tristate "TDA 8290/8295 + 8275(a)/18271 tuner combo"
|
||||
depends on I2C
|
||||
depends on VIDEO_MEDIA && I2C
|
||||
select MEDIA_TUNER_TDA827X
|
||||
select MEDIA_TUNER_TDA18271
|
||||
default m if MEDIA_TUNER_CUSTOMIZE
|
||||
|
@ -63,21 +63,21 @@ config MEDIA_TUNER_TDA8290
|
|||
|
||||
config MEDIA_TUNER_TDA827X
|
||||
tristate "Philips TDA827X silicon tuner"
|
||||
depends on DVB_CORE && I2C
|
||||
depends on VIDEO_MEDIA && I2C
|
||||
default m if DVB_FE_CUSTOMISE
|
||||
help
|
||||
A DVB-T silicon tuner module. Say Y when you want to support this tuner.
|
||||
|
||||
config MEDIA_TUNER_TDA18271
|
||||
tristate "NXP TDA18271 silicon tuner"
|
||||
depends on I2C
|
||||
depends on VIDEO_MEDIA && I2C
|
||||
default m if DVB_FE_CUSTOMISE
|
||||
help
|
||||
A silicon tuner module. Say Y when you want to support this tuner.
|
||||
|
||||
config MEDIA_TUNER_TDA9887
|
||||
tristate "TDA 9885/6/7 analog IF demodulator"
|
||||
depends on I2C
|
||||
depends on VIDEO_MEDIA && I2C
|
||||
default m if MEDIA_TUNER_CUSTOMIZE
|
||||
help
|
||||
Say Y here to include support for Philips TDA9885/6/7
|
||||
|
@ -85,67 +85,79 @@ config MEDIA_TUNER_TDA9887
|
|||
|
||||
config MEDIA_TUNER_TEA5761
|
||||
tristate "TEA 5761 radio tuner (EXPERIMENTAL)"
|
||||
depends on I2C && EXPERIMENTAL
|
||||
depends on VIDEO_MEDIA && I2C
|
||||
depends on EXPERIMENTAL
|
||||
default m if MEDIA_TUNER_CUSTOMIZE
|
||||
help
|
||||
Say Y here to include support for the Philips TEA5761 radio tuner.
|
||||
|
||||
config MEDIA_TUNER_TEA5767
|
||||
tristate "TEA 5767 radio tuner"
|
||||
depends on I2C
|
||||
depends on VIDEO_MEDIA && I2C
|
||||
default m if MEDIA_TUNER_CUSTOMIZE
|
||||
help
|
||||
Say Y here to include support for the Philips TEA5767 radio tuner.
|
||||
|
||||
config MEDIA_TUNER_MT20XX
|
||||
tristate "Microtune 2032 / 2050 tuners"
|
||||
depends on I2C
|
||||
depends on VIDEO_MEDIA && I2C
|
||||
default m if MEDIA_TUNER_CUSTOMIZE
|
||||
help
|
||||
Say Y here to include support for the MT2032 / MT2050 tuner.
|
||||
|
||||
config MEDIA_TUNER_MT2060
|
||||
tristate "Microtune MT2060 silicon IF tuner"
|
||||
depends on I2C
|
||||
depends on VIDEO_MEDIA && I2C
|
||||
default m if DVB_FE_CUSTOMISE
|
||||
help
|
||||
A driver for the silicon IF tuner MT2060 from Microtune.
|
||||
|
||||
config MEDIA_TUNER_MT2266
|
||||
tristate "Microtune MT2266 silicon tuner"
|
||||
depends on I2C
|
||||
depends on VIDEO_MEDIA && I2C
|
||||
default m if DVB_FE_CUSTOMISE
|
||||
help
|
||||
A driver for the silicon baseband tuner MT2266 from Microtune.
|
||||
|
||||
config MEDIA_TUNER_MT2131
|
||||
tristate "Microtune MT2131 silicon tuner"
|
||||
depends on I2C
|
||||
depends on VIDEO_MEDIA && I2C
|
||||
default m if DVB_FE_CUSTOMISE
|
||||
help
|
||||
A driver for the silicon baseband tuner MT2131 from Microtune.
|
||||
|
||||
config MEDIA_TUNER_QT1010
|
||||
tristate "Quantek QT1010 silicon tuner"
|
||||
depends on DVB_CORE && I2C
|
||||
depends on VIDEO_MEDIA && I2C
|
||||
default m if DVB_FE_CUSTOMISE
|
||||
help
|
||||
A driver for the silicon tuner QT1010 from Quantek.
|
||||
|
||||
config MEDIA_TUNER_XC2028
|
||||
tristate "XCeive xc2028/xc3028 tuners"
|
||||
depends on I2C && FW_LOADER
|
||||
depends on VIDEO_MEDIA && I2C
|
||||
depends on HOTPLUG
|
||||
select FW_LOADER
|
||||
default m if MEDIA_TUNER_CUSTOMIZE
|
||||
help
|
||||
Say Y here to include support for the xc2028/xc3028 tuners.
|
||||
|
||||
config MEDIA_TUNER_XC5000
|
||||
tristate "Xceive XC5000 silicon tuner"
|
||||
depends on I2C
|
||||
depends on VIDEO_MEDIA && I2C
|
||||
depends on HOTPLUG
|
||||
select FW_LOADER
|
||||
default m if DVB_FE_CUSTOMISE
|
||||
help
|
||||
A driver for the silicon tuner XC5000 from Xceive.
|
||||
This device is only used inside a SiP called togther with a
|
||||
demodulator for now.
|
||||
|
||||
config MEDIA_TUNER_MXL5005S
|
||||
tristate "MaxLinear MSL5005S silicon tuner"
|
||||
depends on VIDEO_MEDIA && I2C
|
||||
default m if DVB_FE_CUSTOMISE
|
||||
help
|
||||
A driver for the silicon tuner MXL5005S from MaxLinear.
|
||||
|
||||
endif # MEDIA_TUNER_CUSTOMIZE
|
||||
|
|
|
@ -20,6 +20,7 @@ obj-$(CONFIG_MEDIA_TUNER_MT2060) += mt2060.o
|
|||
obj-$(CONFIG_MEDIA_TUNER_MT2266) += mt2266.o
|
||||
obj-$(CONFIG_MEDIA_TUNER_QT1010) += qt1010.o
|
||||
obj-$(CONFIG_MEDIA_TUNER_MT2131) += mt2131.o
|
||||
obj-$(CONFIG_MEDIA_TUNER_MXL5005S) += mxl5005s.o
|
||||
|
||||
EXTRA_CFLAGS += -Idrivers/media/dvb/dvb-core
|
||||
EXTRA_CFLAGS += -Idrivers/media/dvb/frontends
|
||||
|
|
4110
drivers/media/common/tuners/mxl5005s.c
Normal file
4110
drivers/media/common/tuners/mxl5005s.c
Normal file
File diff suppressed because it is too large
Load diff
131
drivers/media/common/tuners/mxl5005s.h
Normal file
131
drivers/media/common/tuners/mxl5005s.h
Normal file
|
@ -0,0 +1,131 @@
|
|||
/*
|
||||
MaxLinear MXL5005S VSB/QAM/DVBT tuner driver
|
||||
|
||||
Copyright (C) 2008 MaxLinear
|
||||
Copyright (C) 2008 Steven Toth <stoth@hauppauge.com>
|
||||
|
||||
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.
|
||||
|
||||
*/
|
||||
|
||||
#ifndef __MXL5005S_H
|
||||
#define __MXL5005S_H
|
||||
|
||||
#include <linux/i2c.h>
|
||||
#include "dvb_frontend.h"
|
||||
|
||||
struct mxl5005s_config {
|
||||
|
||||
/* 7 bit i2c address */
|
||||
u8 i2c_address;
|
||||
|
||||
#define IF_FREQ_4570000HZ 4570000
|
||||
#define IF_FREQ_4571429HZ 4571429
|
||||
#define IF_FREQ_5380000HZ 5380000
|
||||
#define IF_FREQ_36000000HZ 36000000
|
||||
#define IF_FREQ_36125000HZ 36125000
|
||||
#define IF_FREQ_36166667HZ 36166667
|
||||
#define IF_FREQ_44000000HZ 44000000
|
||||
u32 if_freq;
|
||||
|
||||
#define CRYSTAL_FREQ_4000000HZ 4000000
|
||||
#define CRYSTAL_FREQ_16000000HZ 16000000
|
||||
#define CRYSTAL_FREQ_25000000HZ 25000000
|
||||
#define CRYSTAL_FREQ_28800000HZ 28800000
|
||||
u32 xtal_freq;
|
||||
|
||||
#define MXL_DUAL_AGC 0
|
||||
#define MXL_SINGLE_AGC 1
|
||||
u8 agc_mode;
|
||||
|
||||
#define MXL_TF_DEFAULT 0
|
||||
#define MXL_TF_OFF 1
|
||||
#define MXL_TF_C 2
|
||||
#define MXL_TF_C_H 3
|
||||
#define MXL_TF_D 4
|
||||
#define MXL_TF_D_L 5
|
||||
#define MXL_TF_E 6
|
||||
#define MXL_TF_F 7
|
||||
#define MXL_TF_E_2 8
|
||||
#define MXL_TF_E_NA 9
|
||||
#define MXL_TF_G 10
|
||||
u8 tracking_filter;
|
||||
|
||||
#define MXL_RSSI_DISABLE 0
|
||||
#define MXL_RSSI_ENABLE 1
|
||||
u8 rssi_enable;
|
||||
|
||||
#define MXL_CAP_SEL_DISABLE 0
|
||||
#define MXL_CAP_SEL_ENABLE 1
|
||||
u8 cap_select;
|
||||
|
||||
#define MXL_DIV_OUT_1 0
|
||||
#define MXL_DIV_OUT_4 1
|
||||
u8 div_out;
|
||||
|
||||
#define MXL_CLOCK_OUT_DISABLE 0
|
||||
#define MXL_CLOCK_OUT_ENABLE 1
|
||||
u8 clock_out;
|
||||
|
||||
#define MXL5005S_IF_OUTPUT_LOAD_200_OHM 200
|
||||
#define MXL5005S_IF_OUTPUT_LOAD_300_OHM 300
|
||||
u32 output_load;
|
||||
|
||||
#define MXL5005S_TOP_5P5 55
|
||||
#define MXL5005S_TOP_7P2 72
|
||||
#define MXL5005S_TOP_9P2 92
|
||||
#define MXL5005S_TOP_11P0 110
|
||||
#define MXL5005S_TOP_12P9 129
|
||||
#define MXL5005S_TOP_14P7 147
|
||||
#define MXL5005S_TOP_16P8 168
|
||||
#define MXL5005S_TOP_19P4 194
|
||||
#define MXL5005S_TOP_21P2 212
|
||||
#define MXL5005S_TOP_23P2 232
|
||||
#define MXL5005S_TOP_25P2 252
|
||||
#define MXL5005S_TOP_27P1 271
|
||||
#define MXL5005S_TOP_29P2 292
|
||||
#define MXL5005S_TOP_31P7 317
|
||||
#define MXL5005S_TOP_34P9 349
|
||||
u32 top;
|
||||
|
||||
#define MXL_ANALOG_MODE 0
|
||||
#define MXL_DIGITAL_MODE 1
|
||||
u8 mod_mode;
|
||||
|
||||
#define MXL_ZERO_IF 0
|
||||
#define MXL_LOW_IF 1
|
||||
u8 if_mode;
|
||||
|
||||
/* Stuff I don't know what to do with */
|
||||
u8 AgcMasterByte;
|
||||
};
|
||||
|
||||
#if defined(CONFIG_MEDIA_TUNER_MXL5005S) || \
|
||||
(defined(CONFIG_MEDIA_TUNER_MXL5005S_MODULE) && defined(MODULE))
|
||||
extern struct dvb_frontend *mxl5005s_attach(struct dvb_frontend *fe,
|
||||
struct i2c_adapter *i2c,
|
||||
struct mxl5005s_config *config);
|
||||
#else
|
||||
static inline struct dvb_frontend *mxl5005s_attach(struct dvb_frontend *fe,
|
||||
struct i2c_adapter *i2c,
|
||||
struct mxl5005s_config *config)
|
||||
{
|
||||
printk(KERN_WARNING "%s: driver disabled by Kconfig\n", __func__);
|
||||
return NULL;
|
||||
}
|
||||
#endif /* CONFIG_DVB_TUNER_MXL5005S */
|
||||
|
||||
#endif /* __MXL5005S_H */
|
||||
|
|
@ -227,9 +227,8 @@ int tda18271_charge_pump_source(struct dvb_frontend *fe,
|
|||
|
||||
regs[r_cp] &= ~0x20;
|
||||
regs[r_cp] |= ((force & 1) << 5);
|
||||
tda18271_write_regs(fe, r_cp, 1);
|
||||
|
||||
return 0;
|
||||
return tda18271_write_regs(fe, r_cp, 1);
|
||||
}
|
||||
|
||||
int tda18271_init_regs(struct dvb_frontend *fe)
|
||||
|
@ -487,16 +486,15 @@ int tda18271_set_standby_mode(struct dvb_frontend *fe,
|
|||
struct tda18271_priv *priv = fe->tuner_priv;
|
||||
unsigned char *regs = priv->tda18271_regs;
|
||||
|
||||
tda_dbg("sm = %d, sm_lt = %d, sm_xt = %d\n", sm, sm_lt, sm_xt);
|
||||
if (tda18271_debug & DBG_ADV)
|
||||
tda_dbg("sm = %d, sm_lt = %d, sm_xt = %d\n", sm, sm_lt, sm_xt);
|
||||
|
||||
regs[R_EP3] &= ~0xe0; /* clear sm, sm_lt, sm_xt */
|
||||
regs[R_EP3] |= sm ? (1 << 7) : 0 |
|
||||
sm_lt ? (1 << 6) : 0 |
|
||||
sm_xt ? (1 << 5) : 0;
|
||||
|
||||
tda18271_write_regs(fe, R_EP3, 1);
|
||||
|
||||
return 0;
|
||||
return tda18271_write_regs(fe, R_EP3, 1);
|
||||
}
|
||||
|
||||
/*---------------------------------------------------------------------*/
|
||||
|
@ -510,7 +508,7 @@ int tda18271_calc_main_pll(struct dvb_frontend *fe, u32 freq)
|
|||
u32 div;
|
||||
|
||||
int ret = tda18271_lookup_pll_map(fe, MAIN_PLL, &freq, &pd, &d);
|
||||
if (ret < 0)
|
||||
if (tda_fail(ret))
|
||||
goto fail;
|
||||
|
||||
regs[R_MPD] = (0x77 & pd);
|
||||
|
@ -542,7 +540,7 @@ int tda18271_calc_cal_pll(struct dvb_frontend *fe, u32 freq)
|
|||
u32 div;
|
||||
|
||||
int ret = tda18271_lookup_pll_map(fe, CAL_PLL, &freq, &pd, &d);
|
||||
if (ret < 0)
|
||||
if (tda_fail(ret))
|
||||
goto fail;
|
||||
|
||||
regs[R_CPD] = pd;
|
||||
|
@ -566,7 +564,7 @@ int tda18271_calc_bp_filter(struct dvb_frontend *fe, u32 *freq)
|
|||
u8 val;
|
||||
|
||||
int ret = tda18271_lookup_map(fe, BP_FILTER, freq, &val);
|
||||
if (ret < 0)
|
||||
if (tda_fail(ret))
|
||||
goto fail;
|
||||
|
||||
regs[R_EP1] &= ~0x07; /* clear bp filter bits */
|
||||
|
@ -583,7 +581,7 @@ int tda18271_calc_km(struct dvb_frontend *fe, u32 *freq)
|
|||
u8 val;
|
||||
|
||||
int ret = tda18271_lookup_map(fe, RF_CAL_KMCO, freq, &val);
|
||||
if (ret < 0)
|
||||
if (tda_fail(ret))
|
||||
goto fail;
|
||||
|
||||
regs[R_EB13] &= ~0x7c; /* clear k & m bits */
|
||||
|
@ -600,7 +598,7 @@ int tda18271_calc_rf_band(struct dvb_frontend *fe, u32 *freq)
|
|||
u8 val;
|
||||
|
||||
int ret = tda18271_lookup_map(fe, RF_BAND, freq, &val);
|
||||
if (ret < 0)
|
||||
if (tda_fail(ret))
|
||||
goto fail;
|
||||
|
||||
regs[R_EP2] &= ~0xe0; /* clear rf band bits */
|
||||
|
@ -617,7 +615,7 @@ int tda18271_calc_gain_taper(struct dvb_frontend *fe, u32 *freq)
|
|||
u8 val;
|
||||
|
||||
int ret = tda18271_lookup_map(fe, GAIN_TAPER, freq, &val);
|
||||
if (ret < 0)
|
||||
if (tda_fail(ret))
|
||||
goto fail;
|
||||
|
||||
regs[R_EP2] &= ~0x1f; /* clear gain taper bits */
|
||||
|
@ -634,7 +632,7 @@ int tda18271_calc_ir_measure(struct dvb_frontend *fe, u32 *freq)
|
|||
u8 val;
|
||||
|
||||
int ret = tda18271_lookup_map(fe, IR_MEASURE, freq, &val);
|
||||
if (ret < 0)
|
||||
if (tda_fail(ret))
|
||||
goto fail;
|
||||
|
||||
regs[R_EP5] &= ~0x07;
|
||||
|
|
|
@ -51,6 +51,7 @@ static int tda18271_channel_configuration(struct dvb_frontend *fe,
|
|||
{
|
||||
struct tda18271_priv *priv = fe->tuner_priv;
|
||||
unsigned char *regs = priv->tda18271_regs;
|
||||
int ret;
|
||||
u32 N;
|
||||
|
||||
/* update TV broadcast parameters */
|
||||
|
@ -85,7 +86,9 @@ static int tda18271_channel_configuration(struct dvb_frontend *fe,
|
|||
/* update rf top / if top */
|
||||
regs[R_EB22] = 0x00;
|
||||
regs[R_EB22] |= map->rfagc_top;
|
||||
tda18271_write_regs(fe, R_EB22, 1);
|
||||
ret = tda18271_write_regs(fe, R_EB22, 1);
|
||||
if (tda_fail(ret))
|
||||
goto fail;
|
||||
|
||||
/* --------------------------------------------------------------- */
|
||||
|
||||
|
@ -121,7 +124,9 @@ static int tda18271_channel_configuration(struct dvb_frontend *fe,
|
|||
/* agc1 has priority on agc2 */
|
||||
regs[R_EB1] &= ~0x01;
|
||||
|
||||
tda18271_write_regs(fe, R_EB1, 1);
|
||||
ret = tda18271_write_regs(fe, R_EB1, 1);
|
||||
if (tda_fail(ret))
|
||||
goto fail;
|
||||
|
||||
/* --------------------------------------------------------------- */
|
||||
|
||||
|
@ -141,7 +146,9 @@ static int tda18271_channel_configuration(struct dvb_frontend *fe,
|
|||
break;
|
||||
}
|
||||
|
||||
tda18271_write_regs(fe, R_TM, 7);
|
||||
ret = tda18271_write_regs(fe, R_TM, 7);
|
||||
if (tda_fail(ret))
|
||||
goto fail;
|
||||
|
||||
/* force charge pump source */
|
||||
charge_pump_source(fe, 1);
|
||||
|
@ -158,9 +165,9 @@ static int tda18271_channel_configuration(struct dvb_frontend *fe,
|
|||
regs[R_EP3] &= ~0x04;
|
||||
else
|
||||
regs[R_EP3] |= 0x04;
|
||||
tda18271_write_regs(fe, R_EP3, 1);
|
||||
|
||||
return 0;
|
||||
ret = tda18271_write_regs(fe, R_EP3, 1);
|
||||
fail:
|
||||
return ret;
|
||||
}
|
||||
|
||||
static int tda18271_read_thermometer(struct dvb_frontend *fe)
|
||||
|
@ -213,11 +220,13 @@ static int tda18271c2_rf_tracking_filters_correction(struct dvb_frontend *fe,
|
|||
struct tda18271_priv *priv = fe->tuner_priv;
|
||||
struct tda18271_rf_tracking_filter_cal *map = priv->rf_cal_state;
|
||||
unsigned char *regs = priv->tda18271_regs;
|
||||
int tm_current, rfcal_comp, approx, i;
|
||||
int tm_current, rfcal_comp, approx, i, ret;
|
||||
u8 dc_over_dt, rf_tab;
|
||||
|
||||
/* power up */
|
||||
tda18271_set_standby_mode(fe, 0, 0, 0);
|
||||
ret = tda18271_set_standby_mode(fe, 0, 0, 0);
|
||||
if (tda_fail(ret))
|
||||
goto fail;
|
||||
|
||||
/* read die current temperature */
|
||||
tm_current = tda18271_read_thermometer(fe);
|
||||
|
@ -228,8 +237,8 @@ static int tda18271c2_rf_tracking_filters_correction(struct dvb_frontend *fe,
|
|||
rf_tab = regs[R_EB14];
|
||||
|
||||
i = tda18271_lookup_rf_band(fe, &freq, NULL);
|
||||
if (i < 0)
|
||||
return -EINVAL;
|
||||
if (tda_fail(i))
|
||||
return i;
|
||||
|
||||
if ((0 == map[i].rf3) || (freq / 1000 < map[i].rf2)) {
|
||||
approx = map[i].rf_a1 *
|
||||
|
@ -250,35 +259,42 @@ static int tda18271c2_rf_tracking_filters_correction(struct dvb_frontend *fe,
|
|||
rfcal_comp = dc_over_dt * (tm_current - priv->tm_rfcal);
|
||||
|
||||
regs[R_EB14] = approx + rfcal_comp;
|
||||
tda18271_write_regs(fe, R_EB14, 1);
|
||||
|
||||
return 0;
|
||||
ret = tda18271_write_regs(fe, R_EB14, 1);
|
||||
fail:
|
||||
return ret;
|
||||
}
|
||||
|
||||
static int tda18271_por(struct dvb_frontend *fe)
|
||||
{
|
||||
struct tda18271_priv *priv = fe->tuner_priv;
|
||||
unsigned char *regs = priv->tda18271_regs;
|
||||
int ret;
|
||||
|
||||
/* power up detector 1 */
|
||||
regs[R_EB12] &= ~0x20;
|
||||
tda18271_write_regs(fe, R_EB12, 1);
|
||||
ret = tda18271_write_regs(fe, R_EB12, 1);
|
||||
if (tda_fail(ret))
|
||||
goto fail;
|
||||
|
||||
regs[R_EB18] &= ~0x80; /* turn agc1 loop on */
|
||||
regs[R_EB18] &= ~0x03; /* set agc1_gain to 6 dB */
|
||||
tda18271_write_regs(fe, R_EB18, 1);
|
||||
ret = tda18271_write_regs(fe, R_EB18, 1);
|
||||
if (tda_fail(ret))
|
||||
goto fail;
|
||||
|
||||
regs[R_EB21] |= 0x03; /* set agc2_gain to -6 dB */
|
||||
|
||||
/* POR mode */
|
||||
tda18271_set_standby_mode(fe, 1, 0, 0);
|
||||
ret = tda18271_set_standby_mode(fe, 1, 0, 0);
|
||||
if (tda_fail(ret))
|
||||
goto fail;
|
||||
|
||||
/* disable 1.5 MHz low pass filter */
|
||||
regs[R_EB23] &= ~0x04; /* forcelp_fc2_en = 0 */
|
||||
regs[R_EB23] &= ~0x02; /* XXX: lp_fc[2] = 0 */
|
||||
tda18271_write_regs(fe, R_EB21, 3);
|
||||
|
||||
return 0;
|
||||
ret = tda18271_write_regs(fe, R_EB21, 3);
|
||||
fail:
|
||||
return ret;
|
||||
}
|
||||
|
||||
static int tda18271_calibrate_rf(struct dvb_frontend *fe, u32 freq)
|
||||
|
@ -389,7 +405,7 @@ static int tda18271_powerscan(struct dvb_frontend *fe,
|
|||
{
|
||||
struct tda18271_priv *priv = fe->tuner_priv;
|
||||
unsigned char *regs = priv->tda18271_regs;
|
||||
int sgn, bcal, count, wait;
|
||||
int sgn, bcal, count, wait, ret;
|
||||
u8 cid_target;
|
||||
u16 count_limit;
|
||||
u32 freq;
|
||||
|
@ -421,7 +437,9 @@ static int tda18271_powerscan(struct dvb_frontend *fe,
|
|||
tda18271_write_regs(fe, R_EP2, 1);
|
||||
|
||||
/* read power detection info, stored in EB10 */
|
||||
tda18271_read_extended(fe);
|
||||
ret = tda18271_read_extended(fe);
|
||||
if (tda_fail(ret))
|
||||
return ret;
|
||||
|
||||
/* algorithm initialization */
|
||||
sgn = 1;
|
||||
|
@ -447,7 +465,9 @@ static int tda18271_powerscan(struct dvb_frontend *fe,
|
|||
tda18271_write_regs(fe, R_EP2, 1);
|
||||
|
||||
/* read power detection info, stored in EB10 */
|
||||
tda18271_read_extended(fe);
|
||||
ret = tda18271_read_extended(fe);
|
||||
if (tda_fail(ret))
|
||||
return ret;
|
||||
|
||||
count += 200;
|
||||
|
||||
|
@ -478,6 +498,7 @@ static int tda18271_powerscan_init(struct dvb_frontend *fe)
|
|||
{
|
||||
struct tda18271_priv *priv = fe->tuner_priv;
|
||||
unsigned char *regs = priv->tda18271_regs;
|
||||
int ret;
|
||||
|
||||
/* set standard to digital */
|
||||
regs[R_EP3] &= ~0x1f; /* clear std bits */
|
||||
|
@ -489,10 +510,14 @@ static int tda18271_powerscan_init(struct dvb_frontend *fe)
|
|||
/* update IF output level & IF notch frequency */
|
||||
regs[R_EP4] &= ~0x1c; /* clear if level bits */
|
||||
|
||||
tda18271_write_regs(fe, R_EP3, 2);
|
||||
ret = tda18271_write_regs(fe, R_EP3, 2);
|
||||
if (tda_fail(ret))
|
||||
goto fail;
|
||||
|
||||
regs[R_EB18] &= ~0x03; /* set agc1_gain to 6 dB */
|
||||
tda18271_write_regs(fe, R_EB18, 1);
|
||||
ret = tda18271_write_regs(fe, R_EB18, 1);
|
||||
if (tda_fail(ret))
|
||||
goto fail;
|
||||
|
||||
regs[R_EB21] &= ~0x03; /* set agc2_gain to -15 dB */
|
||||
|
||||
|
@ -500,9 +525,9 @@ static int tda18271_powerscan_init(struct dvb_frontend *fe)
|
|||
regs[R_EB23] |= 0x04; /* forcelp_fc2_en = 1 */
|
||||
regs[R_EB23] |= 0x02; /* lp_fc[2] = 1 */
|
||||
|
||||
tda18271_write_regs(fe, R_EB21, 3);
|
||||
|
||||
return 0;
|
||||
ret = tda18271_write_regs(fe, R_EB21, 3);
|
||||
fail:
|
||||
return ret;
|
||||
}
|
||||
|
||||
static int tda18271_rf_tracking_filters_init(struct dvb_frontend *fe, u32 freq)
|
||||
|
@ -521,7 +546,7 @@ static int tda18271_rf_tracking_filters_init(struct dvb_frontend *fe, u32 freq)
|
|||
|
||||
i = tda18271_lookup_rf_band(fe, &freq, NULL);
|
||||
|
||||
if (i < 0)
|
||||
if (tda_fail(i))
|
||||
return i;
|
||||
|
||||
rf_default[RF1] = 1000 * map[i].rf1_def;
|
||||
|
@ -535,6 +560,8 @@ static int tda18271_rf_tracking_filters_init(struct dvb_frontend *fe, u32 freq)
|
|||
|
||||
/* look for optimized calibration frequency */
|
||||
bcal = tda18271_powerscan(fe, &rf_default[rf], &rf_freq[rf]);
|
||||
if (tda_fail(bcal))
|
||||
return bcal;
|
||||
|
||||
tda18271_calc_rf_cal(fe, &rf_freq[rf]);
|
||||
prog_tab[rf] = regs[R_EB14];
|
||||
|
@ -575,22 +602,29 @@ static int tda18271_calc_rf_filter_curve(struct dvb_frontend *fe)
|
|||
{
|
||||
struct tda18271_priv *priv = fe->tuner_priv;
|
||||
unsigned int i;
|
||||
int ret;
|
||||
|
||||
tda_info("tda18271: performing RF tracking filter calibration\n");
|
||||
|
||||
/* wait for die temperature stabilization */
|
||||
msleep(200);
|
||||
|
||||
tda18271_powerscan_init(fe);
|
||||
ret = tda18271_powerscan_init(fe);
|
||||
if (tda_fail(ret))
|
||||
goto fail;
|
||||
|
||||
/* rf band calibration */
|
||||
for (i = 0; priv->rf_cal_state[i].rfmax != 0; i++)
|
||||
for (i = 0; priv->rf_cal_state[i].rfmax != 0; i++) {
|
||||
ret =
|
||||
tda18271_rf_tracking_filters_init(fe, 1000 *
|
||||
priv->rf_cal_state[i].rfmax);
|
||||
if (tda_fail(ret))
|
||||
goto fail;
|
||||
}
|
||||
|
||||
priv->tm_rfcal = tda18271_read_thermometer(fe);
|
||||
|
||||
return 0;
|
||||
fail:
|
||||
return ret;
|
||||
}
|
||||
|
||||
/* ------------------------------------------------------------------ */
|
||||
|
@ -599,6 +633,7 @@ static int tda18271c2_rf_cal_init(struct dvb_frontend *fe)
|
|||
{
|
||||
struct tda18271_priv *priv = fe->tuner_priv;
|
||||
unsigned char *regs = priv->tda18271_regs;
|
||||
int ret;
|
||||
|
||||
/* test RF_CAL_OK to see if we need init */
|
||||
if ((regs[R_EP1] & 0x10) == 0)
|
||||
|
@ -607,15 +642,22 @@ static int tda18271c2_rf_cal_init(struct dvb_frontend *fe)
|
|||
if (priv->cal_initialized)
|
||||
return 0;
|
||||
|
||||
tda18271_calc_rf_filter_curve(fe);
|
||||
ret = tda18271_calc_rf_filter_curve(fe);
|
||||
if (tda_fail(ret))
|
||||
goto fail;
|
||||
|
||||
tda18271_por(fe);
|
||||
ret = tda18271_por(fe);
|
||||
if (tda_fail(ret))
|
||||
goto fail;
|
||||
|
||||
tda_info("tda18271: RF tracking filter calibration complete\n");
|
||||
|
||||
priv->cal_initialized = true;
|
||||
|
||||
return 0;
|
||||
goto end;
|
||||
fail:
|
||||
tda_info("tda18271: RF tracking filter calibration failed!\n");
|
||||
end:
|
||||
return ret;
|
||||
}
|
||||
|
||||
static int tda18271c1_rf_tracking_filter_calibration(struct dvb_frontend *fe,
|
||||
|
@ -623,6 +665,7 @@ static int tda18271c1_rf_tracking_filter_calibration(struct dvb_frontend *fe,
|
|||
{
|
||||
struct tda18271_priv *priv = fe->tuner_priv;
|
||||
unsigned char *regs = priv->tda18271_regs;
|
||||
int ret;
|
||||
u32 N = 0;
|
||||
|
||||
/* calculate bp filter */
|
||||
|
@ -671,7 +714,10 @@ static int tda18271c1_rf_tracking_filter_calibration(struct dvb_frontend *fe,
|
|||
|
||||
tda18271_calc_main_pll(fe, N);
|
||||
|
||||
tda18271_write_regs(fe, R_EP3, 11);
|
||||
ret = tda18271_write_regs(fe, R_EP3, 11);
|
||||
if (tda_fail(ret))
|
||||
return ret;
|
||||
|
||||
msleep(5); /* RF tracking filter calibration initialization */
|
||||
|
||||
/* search for K,M,CO for RF calibration */
|
||||
|
@ -719,45 +765,56 @@ static int tda18271_ir_cal_init(struct dvb_frontend *fe)
|
|||
{
|
||||
struct tda18271_priv *priv = fe->tuner_priv;
|
||||
unsigned char *regs = priv->tda18271_regs;
|
||||
int ret;
|
||||
|
||||
tda18271_read_regs(fe);
|
||||
ret = tda18271_read_regs(fe);
|
||||
if (tda_fail(ret))
|
||||
goto fail;
|
||||
|
||||
/* test IR_CAL_OK to see if we need init */
|
||||
if ((regs[R_EP1] & 0x08) == 0)
|
||||
tda18271_init_regs(fe);
|
||||
|
||||
return 0;
|
||||
ret = tda18271_init_regs(fe);
|
||||
fail:
|
||||
return ret;
|
||||
}
|
||||
|
||||
static int tda18271_init(struct dvb_frontend *fe)
|
||||
{
|
||||
struct tda18271_priv *priv = fe->tuner_priv;
|
||||
int ret;
|
||||
|
||||
mutex_lock(&priv->lock);
|
||||
|
||||
/* power up */
|
||||
tda18271_set_standby_mode(fe, 0, 0, 0);
|
||||
ret = tda18271_set_standby_mode(fe, 0, 0, 0);
|
||||
if (tda_fail(ret))
|
||||
goto fail;
|
||||
|
||||
/* initialization */
|
||||
tda18271_ir_cal_init(fe);
|
||||
ret = tda18271_ir_cal_init(fe);
|
||||
if (tda_fail(ret))
|
||||
goto fail;
|
||||
|
||||
if (priv->id == TDA18271HDC2)
|
||||
tda18271c2_rf_cal_init(fe);
|
||||
|
||||
fail:
|
||||
mutex_unlock(&priv->lock);
|
||||
|
||||
return 0;
|
||||
return ret;
|
||||
}
|
||||
|
||||
static int tda18271_tune(struct dvb_frontend *fe,
|
||||
struct tda18271_std_map_item *map, u32 freq, u32 bw)
|
||||
{
|
||||
struct tda18271_priv *priv = fe->tuner_priv;
|
||||
int ret;
|
||||
|
||||
tda_dbg("freq = %d, ifc = %d, bw = %d, agc_mode = %d, std = %d\n",
|
||||
freq, map->if_freq, bw, map->agc_mode, map->std);
|
||||
|
||||
tda18271_init(fe);
|
||||
ret = tda18271_init(fe);
|
||||
if (tda_fail(ret))
|
||||
goto fail;
|
||||
|
||||
mutex_lock(&priv->lock);
|
||||
|
||||
|
@ -769,11 +826,11 @@ static int tda18271_tune(struct dvb_frontend *fe,
|
|||
tda18271c2_rf_tracking_filters_correction(fe, freq);
|
||||
break;
|
||||
}
|
||||
tda18271_channel_configuration(fe, map, freq, bw);
|
||||
ret = tda18271_channel_configuration(fe, map, freq, bw);
|
||||
|
||||
mutex_unlock(&priv->lock);
|
||||
|
||||
return 0;
|
||||
fail:
|
||||
return ret;
|
||||
}
|
||||
|
||||
/* ------------------------------------------------------------------ */
|
||||
|
@ -837,7 +894,7 @@ static int tda18271_set_params(struct dvb_frontend *fe,
|
|||
|
||||
ret = tda18271_tune(fe, map, freq, bw);
|
||||
|
||||
if (ret < 0)
|
||||
if (tda_fail(ret))
|
||||
goto fail;
|
||||
|
||||
priv->frequency = freq;
|
||||
|
@ -893,7 +950,7 @@ static int tda18271_set_analog_params(struct dvb_frontend *fe,
|
|||
|
||||
ret = tda18271_tune(fe, map, freq, 0);
|
||||
|
||||
if (ret < 0)
|
||||
if (tda_fail(ret))
|
||||
goto fail;
|
||||
|
||||
priv->frequency = freq;
|
||||
|
@ -905,16 +962,17 @@ fail:
|
|||
static int tda18271_sleep(struct dvb_frontend *fe)
|
||||
{
|
||||
struct tda18271_priv *priv = fe->tuner_priv;
|
||||
int ret;
|
||||
|
||||
mutex_lock(&priv->lock);
|
||||
|
||||
/* standby mode w/ slave tuner output
|
||||
* & loop thru & xtal oscillator on */
|
||||
tda18271_set_standby_mode(fe, 1, 0, 0);
|
||||
ret = tda18271_set_standby_mode(fe, 1, 0, 0);
|
||||
|
||||
mutex_unlock(&priv->lock);
|
||||
|
||||
return 0;
|
||||
return ret;
|
||||
}
|
||||
|
||||
static int tda18271_release(struct dvb_frontend *fe)
|
||||
|
@ -1095,10 +1153,10 @@ struct dvb_frontend *tda18271_attach(struct dvb_frontend *fe, u8 addr,
|
|||
if (cfg)
|
||||
priv->small_i2c = cfg->small_i2c;
|
||||
|
||||
if (tda18271_get_id(fe) < 0)
|
||||
if (tda_fail(tda18271_get_id(fe)))
|
||||
goto fail;
|
||||
|
||||
if (tda18271_assign_map_layout(fe) < 0)
|
||||
if (tda_fail(tda18271_assign_map_layout(fe)))
|
||||
goto fail;
|
||||
|
||||
mutex_lock(&priv->lock);
|
||||
|
|
|
@ -153,6 +153,15 @@ extern int tda18271_debug;
|
|||
#define tda_reg(fmt, arg...) dprintk(KERN_DEBUG, DBG_REG, fmt, ##arg)
|
||||
#define tda_cal(fmt, arg...) dprintk(KERN_DEBUG, DBG_CAL, fmt, ##arg)
|
||||
|
||||
#define tda_fail(ret) \
|
||||
({ \
|
||||
int __ret; \
|
||||
__ret = (ret < 0); \
|
||||
if (__ret) \
|
||||
tda_printk(KERN_ERR, "error %d on line %d\n", ret, __LINE__);\
|
||||
__ret; \
|
||||
})
|
||||
|
||||
/*---------------------------------------------------------------------*/
|
||||
|
||||
enum tda18271_map_type {
|
||||
|
|
|
@ -373,14 +373,14 @@ int tea5767_autodetection(struct i2c_adapter* i2c_adap, u8 i2c_addr)
|
|||
|
||||
if ((rc = tuner_i2c_xfer_recv(&i2c, buffer, 7))< 5) {
|
||||
printk(KERN_WARNING "It is not a TEA5767. Received %i bytes.\n", rc);
|
||||
return EINVAL;
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
/* If all bytes are the same then it's a TV tuner and not a tea5767 */
|
||||
if (buffer[0] == buffer[1] && buffer[0] == buffer[2] &&
|
||||
buffer[0] == buffer[3] && buffer[0] == buffer[4]) {
|
||||
printk(KERN_WARNING "All bytes are equal. It is not a TEA5767\n");
|
||||
return EINVAL;
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
/* Status bytes:
|
||||
|
@ -390,7 +390,7 @@ int tea5767_autodetection(struct i2c_adapter* i2c_adap, u8 i2c_addr)
|
|||
*/
|
||||
if (((buffer[3] & 0x0f) != 0x00) || (buffer[4] != 0x00)) {
|
||||
printk(KERN_WARNING "Chip ID is not zero. It is not a TEA5767\n");
|
||||
return EINVAL;
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
|
||||
|
|
|
@ -212,7 +212,7 @@ static void xc5000_TunerReset(struct dvb_frontend *fe)
|
|||
dprintk(1, "%s()\n", __func__);
|
||||
|
||||
if (priv->cfg->tuner_callback) {
|
||||
ret = priv->cfg->tuner_callback(priv->cfg->priv,
|
||||
ret = priv->cfg->tuner_callback(priv->devptr,
|
||||
XC5000_TUNER_RESET, 0);
|
||||
if (ret)
|
||||
printk(KERN_ERR "xc5000: reset failed\n");
|
||||
|
@ -900,9 +900,9 @@ static const struct dvb_tuner_ops xc5000_tuner_ops = {
|
|||
.get_status = xc5000_get_status
|
||||
};
|
||||
|
||||
struct dvb_frontend * xc5000_attach(struct dvb_frontend *fe,
|
||||
struct i2c_adapter *i2c,
|
||||
struct xc5000_config *cfg)
|
||||
struct dvb_frontend *xc5000_attach(struct dvb_frontend *fe,
|
||||
struct i2c_adapter *i2c,
|
||||
struct xc5000_config *cfg, void *devptr)
|
||||
{
|
||||
struct xc5000_priv *priv = NULL;
|
||||
u16 id = 0;
|
||||
|
@ -916,6 +916,7 @@ struct dvb_frontend * xc5000_attach(struct dvb_frontend *fe,
|
|||
priv->cfg = cfg;
|
||||
priv->bandwidth = BANDWIDTH_6_MHZ;
|
||||
priv->i2c = i2c;
|
||||
priv->devptr = devptr;
|
||||
|
||||
/* Check if firmware has been loaded. It is possible that another
|
||||
instance of the driver has loaded the firmware.
|
||||
|
|
|
@ -31,29 +31,31 @@ struct xc5000_config {
|
|||
u8 i2c_address;
|
||||
u32 if_khz;
|
||||
|
||||
/* For each bridge framework, when it attaches either analog or digital,
|
||||
* it has to store a reference back to its _core equivalent structure,
|
||||
* so that it can service the hardware by steering gpio's etc.
|
||||
* Each bridge implementation is different so cast priv accordingly.
|
||||
* The xc5000 driver cares not for this value, other than ensuring
|
||||
* it's passed back to a bridge during tuner_callback().
|
||||
*/
|
||||
void *priv;
|
||||
int (*tuner_callback) (void *priv, int command, int arg);
|
||||
};
|
||||
|
||||
/* xc5000 callback command */
|
||||
#define XC5000_TUNER_RESET 0
|
||||
|
||||
/* For each bridge framework, when it attaches either analog or digital,
|
||||
* it has to store a reference back to its _core equivalent structure,
|
||||
* so that it can service the hardware by steering gpio's etc.
|
||||
* Each bridge implementation is different so cast devptr accordingly.
|
||||
* The xc5000 driver cares not for this value, other than ensuring
|
||||
* it's passed back to a bridge during tuner_callback().
|
||||
*/
|
||||
|
||||
#if defined(CONFIG_MEDIA_TUNER_XC5000) || \
|
||||
(defined(CONFIG_MEDIA_TUNER_XC5000_MODULE) && defined(MODULE))
|
||||
extern struct dvb_frontend* xc5000_attach(struct dvb_frontend *fe,
|
||||
struct i2c_adapter *i2c,
|
||||
struct xc5000_config *cfg);
|
||||
struct xc5000_config *cfg,
|
||||
void *devptr);
|
||||
#else
|
||||
static inline struct dvb_frontend* xc5000_attach(struct dvb_frontend *fe,
|
||||
struct i2c_adapter *i2c,
|
||||
struct xc5000_config *cfg)
|
||||
struct xc5000_config *cfg,
|
||||
void *devptr)
|
||||
{
|
||||
printk(KERN_WARNING "%s: driver disabled by Kconfig\n", __func__);
|
||||
return NULL;
|
||||
|
|
|
@ -31,6 +31,8 @@ struct xc5000_priv {
|
|||
u8 video_standard;
|
||||
u8 rf_mode;
|
||||
u8 fwloaded;
|
||||
|
||||
void *devptr;
|
||||
};
|
||||
|
||||
#endif
|
||||
|
|
|
@ -634,7 +634,7 @@ int flexcop_frontend_init(struct flexcop_device *fc)
|
|||
}
|
||||
|
||||
/* try the sky v2.3 (vp310/Samsung tbdu18132(tsa5059)) */
|
||||
fc->fe = dvb_attach(vp310_mt312_attach,
|
||||
fc->fe = dvb_attach(mt312_attach,
|
||||
&skystar23_samsung_tbdu18132_config, i2c);
|
||||
if (fc->fe != NULL) {
|
||||
ops = &fc->fe->ops;
|
||||
|
|
|
@ -1,6 +1,7 @@
|
|||
config DVB_BT8XX
|
||||
tristate "BT8xx based PCI cards"
|
||||
depends on DVB_CORE && PCI && I2C && VIDEO_BT848
|
||||
depends on HOTPLUG # due to FW_LOADER
|
||||
select DVB_MT352 if !DVB_FE_CUSTOMISE
|
||||
select DVB_SP887X if !DVB_FE_CUSTOMISE
|
||||
select DVB_NXT6000 if !DVB_FE_CUSTOMISE
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
config DVB_CINERGYT2
|
||||
tristate "Terratec CinergyT2/qanu USB2 DVB-T receiver"
|
||||
depends on DVB_CORE && USB
|
||||
depends on DVB_CORE && USB && INPUT
|
||||
help
|
||||
Support for "TerraTec CinergyT2" USB2.0 Highspeed DVB Receivers
|
||||
|
||||
|
|
|
@ -910,15 +910,21 @@ static void dvb_ca_en50221_thread_update_delay(struct dvb_ca_private *ca)
|
|||
int curdelay = 100000000;
|
||||
int slot;
|
||||
|
||||
/* Beware of too high polling frequency, because one polling
|
||||
* call might take several hundred milliseconds until timeout!
|
||||
*/
|
||||
for (slot = 0; slot < ca->slot_count; slot++) {
|
||||
switch (ca->slot_info[slot].slot_state) {
|
||||
default:
|
||||
case DVB_CA_SLOTSTATE_NONE:
|
||||
delay = HZ * 60; /* 60s */
|
||||
if (!(ca->flags & DVB_CA_EN50221_FLAG_IRQ_CAMCHANGE))
|
||||
delay = HZ * 5; /* 5s */
|
||||
break;
|
||||
case DVB_CA_SLOTSTATE_INVALID:
|
||||
delay = HZ * 60;
|
||||
if (!(ca->flags & DVB_CA_EN50221_FLAG_IRQ_CAMCHANGE)) {
|
||||
delay = HZ / 10;
|
||||
}
|
||||
delay = HZ * 60; /* 60s */
|
||||
if (!(ca->flags & DVB_CA_EN50221_FLAG_IRQ_CAMCHANGE))
|
||||
delay = HZ / 10; /* 100ms */
|
||||
break;
|
||||
|
||||
case DVB_CA_SLOTSTATE_UNINITIALISED:
|
||||
|
@ -926,19 +932,17 @@ static void dvb_ca_en50221_thread_update_delay(struct dvb_ca_private *ca)
|
|||
case DVB_CA_SLOTSTATE_VALIDATE:
|
||||
case DVB_CA_SLOTSTATE_WAITFR:
|
||||
case DVB_CA_SLOTSTATE_LINKINIT:
|
||||
delay = HZ / 10;
|
||||
delay = HZ / 10; /* 100ms */
|
||||
break;
|
||||
|
||||
case DVB_CA_SLOTSTATE_RUNNING:
|
||||
delay = HZ * 60;
|
||||
if (!(ca->flags & DVB_CA_EN50221_FLAG_IRQ_CAMCHANGE)) {
|
||||
delay = HZ / 10;
|
||||
}
|
||||
delay = HZ * 60; /* 60s */
|
||||
if (!(ca->flags & DVB_CA_EN50221_FLAG_IRQ_CAMCHANGE))
|
||||
delay = HZ / 10; /* 100ms */
|
||||
if (ca->open) {
|
||||
if ((!ca->slot_info[slot].da_irq_supported) ||
|
||||
(!(ca->flags & DVB_CA_EN50221_FLAG_IRQ_DA))) {
|
||||
delay = HZ / 10;
|
||||
}
|
||||
(!(ca->flags & DVB_CA_EN50221_FLAG_IRQ_DA)))
|
||||
delay = HZ / 10; /* 100ms */
|
||||
}
|
||||
break;
|
||||
}
|
||||
|
|
|
@ -1,6 +1,7 @@
|
|||
config DVB_USB
|
||||
tristate "Support for various USB DVB devices"
|
||||
depends on DVB_CORE && USB && I2C
|
||||
depends on HOTPLUG # due to FW_LOADER
|
||||
select FW_LOADER
|
||||
help
|
||||
By enabling this you will be able to choose the various supported
|
||||
|
|
|
@ -30,7 +30,7 @@ config DVB_CX24123
|
|||
A DVB-S tuner module. Say Y when you want to support this frontend.
|
||||
|
||||
config DVB_MT312
|
||||
tristate "Zarlink VP310/MT312 based"
|
||||
tristate "Zarlink VP310/MT312/ZL10313 based"
|
||||
depends on DVB_CORE && I2C
|
||||
default m if DVB_FE_CUSTOMISE
|
||||
help
|
||||
|
@ -97,7 +97,7 @@ comment "DVB-T (terrestrial) frontends"
|
|||
|
||||
config DVB_SP8870
|
||||
tristate "Spase sp8870 based"
|
||||
depends on DVB_CORE && I2C
|
||||
depends on DVB_CORE && I2C && HOTPLUG
|
||||
default m if DVB_FE_CUSTOMISE
|
||||
select FW_LOADER
|
||||
help
|
||||
|
@ -110,7 +110,7 @@ config DVB_SP8870
|
|||
|
||||
config DVB_SP887X
|
||||
tristate "Spase sp887x based"
|
||||
depends on DVB_CORE && I2C
|
||||
depends on DVB_CORE && I2C && HOTPLUG
|
||||
default m if DVB_FE_CUSTOMISE
|
||||
select FW_LOADER
|
||||
help
|
||||
|
@ -144,7 +144,7 @@ config DVB_L64781
|
|||
|
||||
config DVB_TDA1004X
|
||||
tristate "Philips TDA10045H/TDA10046H based"
|
||||
depends on DVB_CORE && I2C
|
||||
depends on DVB_CORE && I2C && HOTPLUG
|
||||
default m if DVB_FE_CUSTOMISE
|
||||
select FW_LOADER
|
||||
help
|
||||
|
@ -211,7 +211,7 @@ config DVB_DIB7000P
|
|||
|
||||
config DVB_TDA10048
|
||||
tristate "Philips TDA10048HN based"
|
||||
depends on DVB_CORE && I2C
|
||||
depends on DVB_CORE && I2C && HOTPLUG
|
||||
default m if DVB_FE_CUSTOMISE
|
||||
select FW_LOADER
|
||||
help
|
||||
|
@ -253,7 +253,7 @@ comment "ATSC (North American/Korean Terrestrial/Cable DTV) frontends"
|
|||
|
||||
config DVB_NXT200X
|
||||
tristate "NxtWave Communications NXT2002/NXT2004 based"
|
||||
depends on DVB_CORE && I2C
|
||||
depends on DVB_CORE && I2C && HOTPLUG
|
||||
default m if DVB_FE_CUSTOMISE
|
||||
select FW_LOADER
|
||||
help
|
||||
|
@ -268,7 +268,7 @@ config DVB_NXT200X
|
|||
|
||||
config DVB_OR51211
|
||||
tristate "Oren OR51211 based"
|
||||
depends on DVB_CORE && I2C
|
||||
depends on DVB_CORE && I2C && HOTPLUG
|
||||
default m if DVB_FE_CUSTOMISE
|
||||
select FW_LOADER
|
||||
help
|
||||
|
@ -281,7 +281,7 @@ config DVB_OR51211
|
|||
|
||||
config DVB_OR51132
|
||||
tristate "Oren OR51132 based"
|
||||
depends on DVB_CORE && I2C
|
||||
depends on DVB_CORE && I2C && HOTPLUG
|
||||
default m if DVB_FE_CUSTOMISE
|
||||
select FW_LOADER
|
||||
help
|
||||
|
@ -297,7 +297,7 @@ config DVB_OR51132
|
|||
|
||||
config DVB_BCM3510
|
||||
tristate "Broadcom BCM3510"
|
||||
depends on DVB_CORE && I2C
|
||||
depends on DVB_CORE && I2C && HOTPLUG
|
||||
default m if DVB_FE_CUSTOMISE
|
||||
select FW_LOADER
|
||||
help
|
||||
|
|
|
@ -195,7 +195,7 @@ static void itd1000_set_vco(struct itd1000_state *state, u32 freq_khz)
|
|||
}
|
||||
}
|
||||
|
||||
struct {
|
||||
static const struct {
|
||||
u32 freq;
|
||||
u8 values[10]; /* RFTR, RFST1 - RFST9 */
|
||||
} itd1000_fre_values[] = {
|
||||
|
|
|
@ -737,7 +737,7 @@ static void mt312_release(struct dvb_frontend *fe)
|
|||
}
|
||||
|
||||
#define MT312_SYS_CLK 90000000UL /* 90 MHz */
|
||||
static struct dvb_frontend_ops vp310_mt312_ops = {
|
||||
static struct dvb_frontend_ops mt312_ops = {
|
||||
|
||||
.info = {
|
||||
.name = "Zarlink ???? DVB-S",
|
||||
|
@ -776,7 +776,7 @@ static struct dvb_frontend_ops vp310_mt312_ops = {
|
|||
.set_voltage = mt312_set_voltage,
|
||||
};
|
||||
|
||||
struct dvb_frontend *vp310_mt312_attach(const struct mt312_config *config,
|
||||
struct dvb_frontend *mt312_attach(const struct mt312_config *config,
|
||||
struct i2c_adapter *i2c)
|
||||
{
|
||||
struct mt312_state *state = NULL;
|
||||
|
@ -795,7 +795,7 @@ struct dvb_frontend *vp310_mt312_attach(const struct mt312_config *config,
|
|||
goto error;
|
||||
|
||||
/* create dvb_frontend */
|
||||
memcpy(&state->frontend.ops, &vp310_mt312_ops,
|
||||
memcpy(&state->frontend.ops, &mt312_ops,
|
||||
sizeof(struct dvb_frontend_ops));
|
||||
state->frontend.demodulator_priv = state;
|
||||
|
||||
|
@ -827,12 +827,13 @@ error:
|
|||
kfree(state);
|
||||
return NULL;
|
||||
}
|
||||
EXPORT_SYMBOL(vp310_mt312_attach);
|
||||
EXPORT_SYMBOL(mt312_attach);
|
||||
|
||||
module_param(debug, int, 0644);
|
||||
MODULE_PARM_DESC(debug, "Turn on/off frontend debugging (default:off).");
|
||||
|
||||
MODULE_DESCRIPTION("Zarlink VP310/MT312/ZL10313 DVB-S Demodulator driver");
|
||||
MODULE_AUTHOR("Andreas Oberritter <obi@linuxtv.org>");
|
||||
MODULE_AUTHOR("Matthias Schwarzott <zzam@gentoo.org>");
|
||||
MODULE_LICENSE("GPL");
|
||||
|
||||
|
|
|
@ -37,10 +37,10 @@ struct mt312_config {
|
|||
};
|
||||
|
||||
#if defined(CONFIG_DVB_MT312) || (defined(CONFIG_DVB_MT312_MODULE) && defined(MODULE))
|
||||
struct dvb_frontend *vp310_mt312_attach(const struct mt312_config *config,
|
||||
struct dvb_frontend *mt312_attach(const struct mt312_config *config,
|
||||
struct i2c_adapter *i2c);
|
||||
#else
|
||||
static inline struct dvb_frontend *vp310_mt312_attach(
|
||||
static inline struct dvb_frontend *mt312_attach(
|
||||
const struct mt312_config *config, struct i2c_adapter *i2c)
|
||||
{
|
||||
printk(KERN_WARNING "%s: driver disabled by Kconfig\n", __func__);
|
||||
|
|
|
@ -5,6 +5,7 @@ config TTPCI_EEPROM
|
|||
config DVB_AV7110
|
||||
tristate "AV7110 cards"
|
||||
depends on DVB_CORE && PCI && I2C
|
||||
depends on HOTPLUG
|
||||
select FW_LOADER if !DVB_AV7110_FIRMWARE
|
||||
select TTPCI_EEPROM
|
||||
select VIDEO_SAA7146_VV
|
||||
|
@ -123,6 +124,7 @@ config DVB_BUDGET_AV
|
|||
depends on DVB_BUDGET_CORE && I2C
|
||||
select VIDEO_SAA7146_VV
|
||||
depends on VIDEO_DEV # dependencies of VIDEO_SAA7146_VV
|
||||
depends on HOTPLUG # dependency of FW_LOADER
|
||||
select DVB_PLL if !DVB_FE_CUSTOMISE
|
||||
select DVB_STV0299 if !DVB_FE_CUSTOMISE
|
||||
select DVB_TDA1004X if !DVB_FE_CUSTOMISE
|
||||
|
|
|
@ -1,6 +1,7 @@
|
|||
config DVB_TTUSB_DEC
|
||||
tristate "Technotrend/Hauppauge USB DEC devices"
|
||||
depends on DVB_CORE && USB
|
||||
depends on HOTPLUG # due to FW_LOADER
|
||||
select FW_LOADER
|
||||
select CRC32
|
||||
help
|
||||
|
|
|
@ -44,6 +44,10 @@ config VIDEO_TVEEPROM
|
|||
tristate
|
||||
depends on I2C
|
||||
|
||||
config VIDEO_TUNER
|
||||
tristate
|
||||
depends on MEDIA_TUNER
|
||||
|
||||
#
|
||||
# Multimedia Video device configuration
|
||||
#
|
||||
|
@ -690,7 +694,7 @@ config VIDEO_MXB
|
|||
tristate "Siemens-Nixdorf 'Multimedia eXtension Board'"
|
||||
depends on PCI && VIDEO_V4L1 && I2C
|
||||
select VIDEO_SAA7146_VV
|
||||
select MEDIA_TUNER
|
||||
select VIDEO_TUNER
|
||||
select VIDEO_SAA7111 if VIDEO_HELPER_CHIPS_AUTO
|
||||
select VIDEO_TDA9840 if VIDEO_HELPER_CHIPS_AUTO
|
||||
select VIDEO_TEA6415C if VIDEO_HELPER_CHIPS_AUTO
|
||||
|
@ -906,7 +910,7 @@ config SOC_CAMERA
|
|||
|
||||
config SOC_CAMERA_MT9M001
|
||||
tristate "mt9m001 support"
|
||||
depends on SOC_CAMERA
|
||||
depends on SOC_CAMERA && I2C
|
||||
select GPIO_PCA953X if MT9M001_PCA9536_SWITCH
|
||||
help
|
||||
This driver supports MT9M001 cameras from Micron, monochrome
|
||||
|
@ -921,7 +925,7 @@ config MT9M001_PCA9536_SWITCH
|
|||
|
||||
config SOC_CAMERA_MT9V022
|
||||
tristate "mt9v022 support"
|
||||
depends on SOC_CAMERA
|
||||
depends on SOC_CAMERA && I2C
|
||||
select GPIO_PCA953X if MT9V022_PCA9536_SWITCH
|
||||
help
|
||||
This driver supports MT9V022 cameras from Micron
|
||||
|
|
|
@ -84,7 +84,7 @@ obj-$(CONFIG_VIDEO_HEXIUM_GEMINI) += hexium_gemini.o
|
|||
obj-$(CONFIG_VIDEO_DPC) += dpc7146.o
|
||||
obj-$(CONFIG_TUNER_3036) += tuner-3036.o
|
||||
|
||||
obj-$(CONFIG_MEDIA_TUNER) += tuner.o
|
||||
obj-$(CONFIG_VIDEO_TUNER) += tuner.o
|
||||
|
||||
obj-$(CONFIG_VIDEOBUF_GEN) += videobuf-core.o
|
||||
obj-$(CONFIG_VIDEOBUF_DMA_SG) += videobuf-dma-sg.o
|
||||
|
|
|
@ -1,8 +1,9 @@
|
|||
|
||||
config VIDEO_AU0828
|
||||
tristate "Auvitek AU0828 support"
|
||||
depends on VIDEO_DEV && I2C && INPUT && DVB_CORE
|
||||
depends on VIDEO_DEV && I2C && INPUT && DVB_CORE && USB
|
||||
select I2C_ALGOBIT
|
||||
select VIDEO_TVEEPROM
|
||||
select DVB_AU8522 if !DVB_FE_CUSTOMIZE
|
||||
select MEDIA_TUNER_XC5000 if !DVB_FE_CUSTOMIZE
|
||||
---help---
|
||||
|
|
|
@ -337,12 +337,10 @@ int au0828_dvb_register(struct au0828_dev *dev)
|
|||
dvb->frontend = dvb_attach(au8522_attach,
|
||||
&hauppauge_hvr950q_config,
|
||||
&dev->i2c_adap);
|
||||
if (dvb->frontend != NULL) {
|
||||
hauppauge_hvr950q_tunerconfig.priv = dev;
|
||||
if (dvb->frontend != NULL)
|
||||
dvb_attach(xc5000_attach, dvb->frontend,
|
||||
&dev->i2c_adap,
|
||||
&hauppauge_hvr950q_tunerconfig);
|
||||
}
|
||||
&hauppauge_hvr950q_tunerconfig, dev);
|
||||
break;
|
||||
default:
|
||||
printk(KERN_WARNING "The frontend of your DVB/ATSC card "
|
||||
|
|
|
@ -1,12 +1,13 @@
|
|||
config VIDEO_BT848
|
||||
tristate "BT848 Video For Linux"
|
||||
depends on VIDEO_DEV && PCI && I2C && VIDEO_V4L2 && INPUT
|
||||
depends on HOTPLUG # due to FW_LOADER
|
||||
select I2C_ALGOBIT
|
||||
select FW_LOADER
|
||||
select VIDEO_BTCX
|
||||
select VIDEOBUF_DMA_SG
|
||||
select VIDEO_IR
|
||||
select MEDIA_TUNER
|
||||
select VIDEO_TUNER
|
||||
select VIDEO_TVEEPROM
|
||||
select VIDEO_MSP3400 if VIDEO_HELPER_CHIPS_AUTO
|
||||
select VIDEO_TVAUDIO if VIDEO_HELPER_CHIPS_AUTO
|
||||
|
|
|
@ -1,14 +1,17 @@
|
|||
config VIDEO_CX18
|
||||
tristate "Conexant cx23418 MPEG encoder support"
|
||||
depends on VIDEO_V4L2 && DVB_CORE && PCI && I2C && EXPERIMENTAL
|
||||
depends on INPUT # due to VIDEO_IR
|
||||
depends on HOTPLUG # due to FW_LOADER
|
||||
select I2C_ALGOBIT
|
||||
select FW_LOADER
|
||||
select VIDEO_IR
|
||||
select MEDIA_TUNER
|
||||
select VIDEO_TUNER
|
||||
select VIDEO_TVEEPROM
|
||||
select VIDEO_CX2341X
|
||||
select VIDEO_CS5345
|
||||
select DVB_S5H1409
|
||||
select MEDIA_TUNER_MXL5005S
|
||||
---help---
|
||||
This is a video4linux driver for Conexant cx23418 based
|
||||
PCI combo video recorder devices.
|
||||
|
|
|
@ -47,11 +47,12 @@ static struct cx18_card_tuner_i2c cx18_i2c_std = {
|
|||
static const struct cx18_card cx18_card_hvr1600_esmt = {
|
||||
.type = CX18_CARD_HVR_1600_ESMT,
|
||||
.name = "Hauppauge HVR-1600",
|
||||
.comment = "DVB & VBI are not yet supported\n",
|
||||
.comment = "VBI is not yet supported\n",
|
||||
.v4l2_capabilities = CX18_CAP_ENCODER,
|
||||
.hw_audio_ctrl = CX18_HW_CX23418,
|
||||
.hw_muxer = CX18_HW_CS5345,
|
||||
.hw_all = CX18_HW_TVEEPROM | CX18_HW_TUNER | CX18_HW_CS5345,
|
||||
.hw_all = CX18_HW_TVEEPROM | CX18_HW_TUNER |
|
||||
CX18_HW_CS5345 | CX18_HW_DVB,
|
||||
.video_inputs = {
|
||||
{ CX18_CARD_INPUT_VID_TUNER, 0, CX23418_COMPOSITE7 },
|
||||
{ CX18_CARD_INPUT_SVIDEO1, 1, CX23418_SVIDEO1 },
|
||||
|
@ -86,11 +87,12 @@ static const struct cx18_card cx18_card_hvr1600_esmt = {
|
|||
static const struct cx18_card cx18_card_hvr1600_samsung = {
|
||||
.type = CX18_CARD_HVR_1600_SAMSUNG,
|
||||
.name = "Hauppauge HVR-1600 (Preproduction)",
|
||||
.comment = "DVB & VBI are not yet supported\n",
|
||||
.comment = "VBI is not yet supported\n",
|
||||
.v4l2_capabilities = CX18_CAP_ENCODER,
|
||||
.hw_audio_ctrl = CX18_HW_CX23418,
|
||||
.hw_muxer = CX18_HW_CS5345,
|
||||
.hw_all = CX18_HW_TVEEPROM | CX18_HW_TUNER | CX18_HW_CS5345,
|
||||
.hw_all = CX18_HW_TVEEPROM | CX18_HW_TUNER |
|
||||
CX18_HW_CS5345 | CX18_HW_DVB,
|
||||
.video_inputs = {
|
||||
{ CX18_CARD_INPUT_VID_TUNER, 0, CX23418_COMPOSITE7 },
|
||||
{ CX18_CARD_INPUT_SVIDEO1, 1, CX23418_SVIDEO1 },
|
||||
|
@ -134,14 +136,15 @@ static const struct cx18_card_pci_info cx18_pci_h900[] = {
|
|||
static const struct cx18_card cx18_card_h900 = {
|
||||
.type = CX18_CARD_COMPRO_H900,
|
||||
.name = "Compro VideoMate H900",
|
||||
.comment = "Not yet supported!\n",
|
||||
.v4l2_capabilities = 0,
|
||||
.comment = "DVB & VBI are not yet supported\n",
|
||||
.v4l2_capabilities = CX18_CAP_ENCODER,
|
||||
.hw_audio_ctrl = CX18_HW_CX23418,
|
||||
.hw_all = CX18_HW_TUNER,
|
||||
.video_inputs = {
|
||||
{ CX18_CARD_INPUT_VID_TUNER, 0, CX23418_COMPOSITE7 },
|
||||
{ CX18_CARD_INPUT_SVIDEO1, 1, CX23418_SVIDEO1 },
|
||||
{ CX18_CARD_INPUT_COMPOSITE1, 1, CX23418_COMPOSITE3 },
|
||||
{ CX18_CARD_INPUT_VID_TUNER, 0, CX23418_COMPOSITE2 },
|
||||
{ CX18_CARD_INPUT_SVIDEO1, 1,
|
||||
CX23418_SVIDEO_LUMA3 | CX23418_SVIDEO_CHROMA4 },
|
||||
{ CX18_CARD_INPUT_COMPOSITE1, 1, CX23418_COMPOSITE1 },
|
||||
},
|
||||
.audio_inputs = {
|
||||
{ CX18_CARD_INPUT_AUD_TUNER,
|
||||
|
@ -163,6 +166,7 @@ static const struct cx18_card cx18_card_h900 = {
|
|||
.tune_lane = 0,
|
||||
.initial_emrs = 0,
|
||||
},
|
||||
.xceive_pin = 15,
|
||||
.pci_list = cx18_pci_h900,
|
||||
.i2c = &cx18_i2c_std,
|
||||
};
|
||||
|
@ -200,8 +204,6 @@ static const struct cx18_card cx18_card_mpc718 = {
|
|||
/* XC3028 tuner */
|
||||
{ .std = V4L2_STD_ALL, .tuner = TUNER_XC2028 },
|
||||
},
|
||||
/* tuner reset */
|
||||
.gpio_init = { .direction = 0x1000, .initial_value = 0x1000 },
|
||||
.ddr = {
|
||||
/* Probably Samsung K4D263238G-VC33 memory */
|
||||
.chip_config = 0x003,
|
||||
|
@ -211,6 +213,7 @@ static const struct cx18_card cx18_card_mpc718 = {
|
|||
.tune_lane = 0,
|
||||
.initial_emrs = 2,
|
||||
},
|
||||
.xceive_pin = 15,
|
||||
.pci_list = cx18_pci_mpc718,
|
||||
.i2c = &cx18_i2c_std,
|
||||
};
|
||||
|
|
|
@ -114,8 +114,8 @@ struct cx18_card_pci_info {
|
|||
/* The mask is the set of bits used by the operation */
|
||||
|
||||
struct cx18_gpio_init { /* set initial GPIO DIR and OUT values */
|
||||
u16 direction; /* DIR setting. Leave to 0 if no init is needed */
|
||||
u16 initial_value;
|
||||
u32 direction; /* DIR setting. Leave to 0 if no init is needed */
|
||||
u32 initial_value;
|
||||
};
|
||||
|
||||
struct cx18_card_tuner {
|
||||
|
@ -153,6 +153,7 @@ struct cx18_card {
|
|||
struct cx18_card_audio_input radio_input;
|
||||
|
||||
/* GPIO card-specific settings */
|
||||
u8 xceive_pin; /* XCeive tuner GPIO reset pin */
|
||||
struct cx18_gpio_init gpio_init;
|
||||
|
||||
struct cx18_card_tuner tuners[CX18_CARD_MAX_TUNERS];
|
||||
|
|
|
@ -164,16 +164,6 @@ MODULE_LICENSE("GPL");
|
|||
|
||||
MODULE_VERSION(CX18_VERSION);
|
||||
|
||||
int cx18_waitq(wait_queue_head_t *waitq)
|
||||
{
|
||||
DEFINE_WAIT(wait);
|
||||
|
||||
prepare_to_wait(waitq, &wait, TASK_INTERRUPTIBLE);
|
||||
schedule();
|
||||
finish_wait(waitq, &wait);
|
||||
return signal_pending(current) ? -EINTR : 0;
|
||||
}
|
||||
|
||||
/* Generic utility functions */
|
||||
int cx18_msleep_timeout(unsigned int msecs, int intr)
|
||||
{
|
||||
|
@ -220,13 +210,13 @@ static void cx18_process_eeprom(struct cx18 *cx)
|
|||
|
||||
/* Many thanks to Steven Toth from Hauppauge for providing the
|
||||
model numbers */
|
||||
/* Note: the Samsung memory models cannot be reliably determined
|
||||
from the model number. Use the cardtype module option if you
|
||||
have one of these preproduction models. */
|
||||
switch (tv.model) {
|
||||
case 74000 ... 74099:
|
||||
case 74000 ... 74999:
|
||||
cx->card = cx18_get_card(CX18_CARD_HVR_1600_ESMT);
|
||||
break;
|
||||
case 74700 ... 74799:
|
||||
cx->card = cx18_get_card(CX18_CARD_HVR_1600_SAMSUNG);
|
||||
break;
|
||||
case 0:
|
||||
CX18_ERR("Invalid EEPROM\n");
|
||||
return;
|
||||
|
@ -548,6 +538,7 @@ static int cx18_setup_pci(struct cx18 *cx, struct pci_dev *dev,
|
|||
return 0;
|
||||
}
|
||||
|
||||
#ifdef MODULE
|
||||
static u32 cx18_request_module(struct cx18 *cx, u32 hw,
|
||||
const char *name, u32 id)
|
||||
{
|
||||
|
@ -560,18 +551,21 @@ static u32 cx18_request_module(struct cx18 *cx, u32 hw,
|
|||
CX18_DEBUG_INFO("Loaded module %s\n", name);
|
||||
return hw;
|
||||
}
|
||||
#endif
|
||||
|
||||
static void cx18_load_and_init_modules(struct cx18 *cx)
|
||||
{
|
||||
u32 hw = cx->card->hw_all;
|
||||
int i;
|
||||
|
||||
#ifdef MODULE
|
||||
/* load modules */
|
||||
#ifndef CONFIG_MEDIA_TUNER
|
||||
hw = cx18_request_module(cx, hw, "tuner", CX18_HW_TUNER);
|
||||
#endif
|
||||
#ifndef CONFIG_VIDEO_CS5345
|
||||
hw = cx18_request_module(cx, hw, "cs5345", CX18_HW_CS5345);
|
||||
#endif
|
||||
#endif
|
||||
|
||||
/* check which i2c devices are actually found */
|
||||
|
@ -801,7 +795,7 @@ static int __devinit cx18_probe(struct pci_dev *dev,
|
|||
return 0;
|
||||
|
||||
free_streams:
|
||||
cx18_streams_cleanup(cx);
|
||||
cx18_streams_cleanup(cx, 1);
|
||||
free_irq:
|
||||
free_irq(cx->dev->irq, (void *)cx);
|
||||
free_i2c:
|
||||
|
@ -904,14 +898,13 @@ static void cx18_remove(struct pci_dev *pci_dev)
|
|||
|
||||
cx18_halt_firmware(cx);
|
||||
|
||||
cx18_streams_cleanup(cx);
|
||||
cx18_streams_cleanup(cx, 1);
|
||||
|
||||
exit_cx18_i2c(cx);
|
||||
|
||||
free_irq(cx->dev->irq, (void *)cx);
|
||||
|
||||
if (cx->dev)
|
||||
cx18_iounmap(cx);
|
||||
cx18_iounmap(cx);
|
||||
|
||||
release_mem_region(cx->base_addr, CX18_MEM_SIZE);
|
||||
|
||||
|
|
|
@ -444,9 +444,6 @@ extern spinlock_t cx18_cards_lock;
|
|||
/* Return non-zero if a signal is pending */
|
||||
int cx18_msleep_timeout(unsigned int msecs, int intr);
|
||||
|
||||
/* Wait on queue, returns -EINTR if interrupted */
|
||||
int cx18_waitq(wait_queue_head_t *waitq);
|
||||
|
||||
/* Read Hauppauge eeprom */
|
||||
struct tveeprom; /* forward reference */
|
||||
void cx18_read_eeprom(struct cx18 *cx, struct tveeprom *tv);
|
||||
|
|
|
@ -24,25 +24,27 @@
|
|||
#include "cx18-streams.h"
|
||||
#include "cx18-cards.h"
|
||||
#include "s5h1409.h"
|
||||
|
||||
/* Wait until the MXL500X driver is merged */
|
||||
#ifdef HAVE_MXL500X
|
||||
#include "mxl500x.h"
|
||||
#endif
|
||||
#include "mxl5005s.h"
|
||||
|
||||
DVB_DEFINE_MOD_OPT_ADAPTER_NR(adapter_nr);
|
||||
|
||||
#define CX18_REG_DMUX_NUM_PORT_0_CONTROL 0xd5a000
|
||||
|
||||
#ifdef HAVE_MXL500X
|
||||
static struct mxl500x_config hauppauge_hvr1600_tuner = {
|
||||
.delsys = MXL500x_MODE_ATSC,
|
||||
.octf = MXL500x_OCTF_CH,
|
||||
.xtal_freq = 16000000,
|
||||
.iflo_freq = 5380000,
|
||||
.ref_freq = 322800000,
|
||||
.rssi_ena = MXL_RSSI_ENABLE,
|
||||
.addr = 0xC6 >> 1,
|
||||
static struct mxl5005s_config hauppauge_hvr1600_tuner = {
|
||||
.i2c_address = 0xC6 >> 1,
|
||||
.if_freq = IF_FREQ_5380000HZ,
|
||||
.xtal_freq = CRYSTAL_FREQ_16000000HZ,
|
||||
.agc_mode = MXL_SINGLE_AGC,
|
||||
.tracking_filter = MXL_TF_C_H,
|
||||
.rssi_enable = MXL_RSSI_ENABLE,
|
||||
.cap_select = MXL_CAP_SEL_ENABLE,
|
||||
.div_out = MXL_DIV_OUT_4,
|
||||
.clock_out = MXL_CLOCK_OUT_DISABLE,
|
||||
.output_load = MXL5005S_IF_OUTPUT_LOAD_200_OHM,
|
||||
.top = MXL5005S_TOP_25P2,
|
||||
.mod_mode = MXL_DIGITAL_MODE,
|
||||
.if_mode = MXL_ZERO_IF,
|
||||
.AgcMasterByte = 0x00,
|
||||
};
|
||||
|
||||
static struct s5h1409_config hauppauge_hvr1600_config = {
|
||||
|
@ -55,7 +57,6 @@ static struct s5h1409_config hauppauge_hvr1600_config = {
|
|||
.mpeg_timing = S5H1409_MPEGTIMING_CONTINOUS_NONINVERTING_CLOCK
|
||||
|
||||
};
|
||||
#endif
|
||||
|
||||
static int dvb_register(struct cx18_stream *stream);
|
||||
|
||||
|
@ -252,21 +253,18 @@ static int dvb_register(struct cx18_stream *stream)
|
|||
int ret = 0;
|
||||
|
||||
switch (cx->card->type) {
|
||||
/* Wait until the MXL500X driver is merged */
|
||||
#ifdef HAVE_MXL500X
|
||||
case CX18_CARD_HVR_1600_ESMT:
|
||||
case CX18_CARD_HVR_1600_SAMSUNG:
|
||||
dvb->fe = dvb_attach(s5h1409_attach,
|
||||
&hauppauge_hvr1600_config,
|
||||
&cx->i2c_adap[0]);
|
||||
if (dvb->fe != NULL) {
|
||||
dvb_attach(mxl500x_attach, dvb->fe,
|
||||
&hauppauge_hvr1600_tuner,
|
||||
&cx->i2c_adap[0]);
|
||||
dvb_attach(mxl5005s_attach, dvb->fe,
|
||||
&cx->i2c_adap[0],
|
||||
&hauppauge_hvr1600_tuner);
|
||||
ret = 0;
|
||||
}
|
||||
break;
|
||||
#endif
|
||||
default:
|
||||
/* No Digital Tv Support */
|
||||
break;
|
||||
|
|
|
@ -39,7 +39,7 @@
|
|||
associated VBI streams are also automatically claimed.
|
||||
Possible error returns: -EBUSY if someone else has claimed
|
||||
the stream or 0 on success. */
|
||||
int cx18_claim_stream(struct cx18_open_id *id, int type)
|
||||
static int cx18_claim_stream(struct cx18_open_id *id, int type)
|
||||
{
|
||||
struct cx18 *cx = id->cx;
|
||||
struct cx18_stream *s = &cx->streams[type];
|
||||
|
@ -87,7 +87,7 @@ int cx18_claim_stream(struct cx18_open_id *id, int type)
|
|||
|
||||
/* This function releases a previously claimed stream. It will take into
|
||||
account associated VBI streams. */
|
||||
void cx18_release_stream(struct cx18_stream *s)
|
||||
static void cx18_release_stream(struct cx18_stream *s)
|
||||
{
|
||||
struct cx18 *cx = s->cx;
|
||||
struct cx18_stream *s_vbi;
|
||||
|
@ -662,6 +662,8 @@ int cx18_v4l2_open(struct inode *inode, struct file *filp)
|
|||
for (x = 0; cx == NULL && x < cx18_cards_active; x++) {
|
||||
/* find out which stream this open was on */
|
||||
for (y = 0; y < CX18_MAX_STREAMS; y++) {
|
||||
if (cx18_cards[x] == NULL)
|
||||
continue;
|
||||
s = &cx18_cards[x]->streams[y];
|
||||
if (s->v4l2dev && s->v4l2dev->minor == minor) {
|
||||
cx = cx18_cards[x];
|
||||
|
|
|
@ -34,12 +34,3 @@ void cx18_stop_capture(struct cx18_open_id *id, int gop_end);
|
|||
void cx18_mute(struct cx18 *cx);
|
||||
void cx18_unmute(struct cx18 *cx);
|
||||
|
||||
/* Utilities */
|
||||
|
||||
/* Try to claim a stream for the filehandle. Return 0 on success,
|
||||
-EBUSY if stream already claimed. Once a stream is claimed, it
|
||||
remains claimed until the associated filehandle is closed. */
|
||||
int cx18_claim_stream(struct cx18_open_id *id, int type);
|
||||
|
||||
/* Release a previously claimed stream. */
|
||||
void cx18_release_stream(struct cx18_stream *s);
|
||||
|
|
|
@ -35,6 +35,9 @@
|
|||
#define CX18_REG_GPIO_OUT2 0xc78104
|
||||
#define CX18_REG_GPIO_DIR2 0xc7810c
|
||||
|
||||
static u32 gpio_dir;
|
||||
static u32 gpio_val;
|
||||
|
||||
/*
|
||||
* HVR-1600 GPIO pins, courtesy of Hauppauge:
|
||||
*
|
||||
|
@ -44,31 +47,53 @@
|
|||
* gpio13: cs5345 reset pin
|
||||
*/
|
||||
|
||||
static void gpio_write(struct cx18 *cx)
|
||||
{
|
||||
write_reg((gpio_dir & 0xffff) << 16, CX18_REG_GPIO_DIR1);
|
||||
write_reg(((gpio_dir & 0xffff) << 16) | (gpio_val & 0xffff),
|
||||
CX18_REG_GPIO_OUT1);
|
||||
write_reg(gpio_dir & 0xffff0000, CX18_REG_GPIO_DIR2);
|
||||
write_reg((gpio_dir & 0xffff0000) | ((gpio_val & 0xffff0000) >> 16),
|
||||
CX18_REG_GPIO_OUT2);
|
||||
}
|
||||
|
||||
void cx18_gpio_init(struct cx18 *cx)
|
||||
{
|
||||
if (cx->card->gpio_init.direction == 0)
|
||||
gpio_dir = cx->card->gpio_init.direction;
|
||||
gpio_val = cx->card->gpio_init.initial_value;
|
||||
|
||||
if (gpio_dir == 0)
|
||||
return;
|
||||
|
||||
CX18_DEBUG_INFO("GPIO initial dir: %08x out: %08x\n",
|
||||
read_reg(CX18_REG_GPIO_DIR1), read_reg(CX18_REG_GPIO_OUT1));
|
||||
gpio_dir |= 1 << cx->card->xceive_pin;
|
||||
gpio_val |= 1 << cx->card->xceive_pin;
|
||||
|
||||
/* init output data then direction */
|
||||
write_reg(cx->card->gpio_init.direction << 16, CX18_REG_GPIO_DIR1);
|
||||
write_reg(0, CX18_REG_GPIO_DIR2);
|
||||
write_reg((cx->card->gpio_init.direction << 16) |
|
||||
cx->card->gpio_init.initial_value, CX18_REG_GPIO_OUT1);
|
||||
write_reg(0, CX18_REG_GPIO_OUT2);
|
||||
CX18_DEBUG_INFO("GPIO initial dir: %08x/%08x out: %08x/%08x\n",
|
||||
read_reg(CX18_REG_GPIO_DIR1), read_reg(CX18_REG_GPIO_DIR2),
|
||||
read_reg(CX18_REG_GPIO_OUT1), read_reg(CX18_REG_GPIO_OUT2));
|
||||
|
||||
gpio_write(cx);
|
||||
}
|
||||
|
||||
/* Xceive tuner reset function */
|
||||
int cx18_reset_tuner_gpio(void *dev, int cmd, int value)
|
||||
{
|
||||
struct i2c_algo_bit_data *algo = dev;
|
||||
struct cx18 *cx = algo->data;
|
||||
/* int curdir, curout;*/
|
||||
struct cx18_i2c_algo_callback_data *cb_data = algo->data;
|
||||
struct cx18 *cx = cb_data->cx;
|
||||
|
||||
if (cmd != XC2028_TUNER_RESET)
|
||||
return 0;
|
||||
CX18_DEBUG_INFO("Resetting tuner\n");
|
||||
|
||||
gpio_dir |= 1 << cx->card->xceive_pin;
|
||||
gpio_val &= ~(1 << cx->card->xceive_pin);
|
||||
|
||||
gpio_write(cx);
|
||||
schedule_timeout_interruptible(msecs_to_jiffies(1));
|
||||
|
||||
gpio_val |= 1 << cx->card->xceive_pin;
|
||||
gpio_write(cx);
|
||||
schedule_timeout_interruptible(msecs_to_jiffies(1));
|
||||
return 0;
|
||||
}
|
||||
|
|
|
@ -25,6 +25,7 @@
|
|||
#include "cx18-cards.h"
|
||||
#include "cx18-gpio.h"
|
||||
#include "cx18-av-core.h"
|
||||
#include "cx18-i2c.h"
|
||||
|
||||
#include <media/ir-kbd-i2c.h>
|
||||
|
||||
|
|
|
@ -26,17 +26,6 @@
|
|||
#include "cx18-queue.h"
|
||||
#include "cx18-scb.h"
|
||||
|
||||
int cx18_buf_copy_from_user(struct cx18_stream *s, struct cx18_buffer *buf,
|
||||
const char __user *src, int copybytes)
|
||||
{
|
||||
if (s->buf_size - buf->bytesused < copybytes)
|
||||
copybytes = s->buf_size - buf->bytesused;
|
||||
if (copy_from_user(buf->buf + buf->bytesused, src, copybytes))
|
||||
return -EFAULT;
|
||||
buf->bytesused += copybytes;
|
||||
return copybytes;
|
||||
}
|
||||
|
||||
void cx18_buf_swap(struct cx18_buffer *buf)
|
||||
{
|
||||
int i;
|
||||
|
@ -159,8 +148,9 @@ static void cx18_queue_move_buf(struct cx18_stream *s, struct cx18_queue *from,
|
|||
-ENOMEM is returned if the buffers could not be obtained, 0 if all
|
||||
buffers where obtained from the 'from' list and if non-zero then
|
||||
the number of stolen buffers is returned. */
|
||||
int cx18_queue_move(struct cx18_stream *s, struct cx18_queue *from,
|
||||
struct cx18_queue *steal, struct cx18_queue *to, int needed_bytes)
|
||||
static int cx18_queue_move(struct cx18_stream *s, struct cx18_queue *from,
|
||||
struct cx18_queue *steal, struct cx18_queue *to,
|
||||
int needed_bytes)
|
||||
{
|
||||
unsigned long flags;
|
||||
int rc = 0;
|
||||
|
@ -239,12 +229,12 @@ int cx18_stream_alloc(struct cx18_stream *s)
|
|||
|
||||
/* allocate stream buffers. Initially all buffers are in q_free. */
|
||||
for (i = 0; i < s->buffers; i++) {
|
||||
struct cx18_buffer *buf =
|
||||
kzalloc(sizeof(struct cx18_buffer), GFP_KERNEL);
|
||||
struct cx18_buffer *buf = kzalloc(sizeof(struct cx18_buffer),
|
||||
GFP_KERNEL|__GFP_NOWARN);
|
||||
|
||||
if (buf == NULL)
|
||||
break;
|
||||
buf->buf = kmalloc(s->buf_size, GFP_KERNEL);
|
||||
buf->buf = kmalloc(s->buf_size, GFP_KERNEL|__GFP_NOWARN);
|
||||
if (buf->buf == NULL) {
|
||||
kfree(buf);
|
||||
break;
|
||||
|
|
|
@ -39,8 +39,6 @@ static inline void cx18_buf_sync_for_device(struct cx18_stream *s,
|
|||
s->buf_size, s->dma);
|
||||
}
|
||||
|
||||
int cx18_buf_copy_from_user(struct cx18_stream *s, struct cx18_buffer *buf,
|
||||
const char __user *src, int copybytes);
|
||||
void cx18_buf_swap(struct cx18_buffer *buf);
|
||||
|
||||
/* cx18_queue utility functions */
|
||||
|
@ -48,8 +46,6 @@ void cx18_queue_init(struct cx18_queue *q);
|
|||
void cx18_enqueue(struct cx18_stream *s, struct cx18_buffer *buf,
|
||||
struct cx18_queue *q);
|
||||
struct cx18_buffer *cx18_dequeue(struct cx18_stream *s, struct cx18_queue *q);
|
||||
int cx18_queue_move(struct cx18_stream *s, struct cx18_queue *from,
|
||||
struct cx18_queue *steal, struct cx18_queue *to, int needed_bytes);
|
||||
struct cx18_buffer *cx18_queue_find_buf(struct cx18_stream *s, u32 id,
|
||||
u32 bytesused);
|
||||
void cx18_flush_queues(struct cx18_stream *s);
|
||||
|
|
|
@ -218,7 +218,7 @@ int cx18_streams_setup(struct cx18 *cx)
|
|||
return 0;
|
||||
|
||||
/* One or more streams could not be initialized. Clean 'em all up. */
|
||||
cx18_streams_cleanup(cx);
|
||||
cx18_streams_cleanup(cx, 0);
|
||||
return -ENOMEM;
|
||||
}
|
||||
|
||||
|
@ -296,12 +296,12 @@ int cx18_streams_register(struct cx18 *cx)
|
|||
return 0;
|
||||
|
||||
/* One or more streams could not be initialized. Clean 'em all up. */
|
||||
cx18_streams_cleanup(cx);
|
||||
cx18_streams_cleanup(cx, 1);
|
||||
return -ENOMEM;
|
||||
}
|
||||
|
||||
/* Unregister v4l2 devices */
|
||||
void cx18_streams_cleanup(struct cx18 *cx)
|
||||
void cx18_streams_cleanup(struct cx18 *cx, int unregister)
|
||||
{
|
||||
struct video_device *vdev;
|
||||
int type;
|
||||
|
@ -319,8 +319,11 @@ void cx18_streams_cleanup(struct cx18 *cx)
|
|||
|
||||
cx18_stream_free(&cx->streams[type]);
|
||||
|
||||
/* Unregister device */
|
||||
video_unregister_device(vdev);
|
||||
/* Unregister or release device */
|
||||
if (unregister)
|
||||
video_unregister_device(vdev);
|
||||
else
|
||||
video_device_release(vdev);
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -24,7 +24,7 @@
|
|||
u32 cx18_find_handle(struct cx18 *cx);
|
||||
int cx18_streams_setup(struct cx18 *cx);
|
||||
int cx18_streams_register(struct cx18 *cx);
|
||||
void cx18_streams_cleanup(struct cx18 *cx);
|
||||
void cx18_streams_cleanup(struct cx18 *cx, int unregister);
|
||||
|
||||
/* Capture related */
|
||||
int cx18_start_v4l2_encode_stream(struct cx18_stream *s);
|
||||
|
|
|
@ -1,18 +1,20 @@
|
|||
config VIDEO_CX23885
|
||||
tristate "Conexant cx23885 (2388x successor) support"
|
||||
depends on DVB_CORE && VIDEO_DEV && PCI && I2C && INPUT
|
||||
depends on HOTPLUG # due to FW_LOADER
|
||||
select I2C_ALGOBIT
|
||||
select FW_LOADER
|
||||
select VIDEO_BTCX
|
||||
select MEDIA_TUNER
|
||||
select VIDEO_TUNER
|
||||
select VIDEO_TVEEPROM
|
||||
select VIDEO_IR
|
||||
select VIDEOBUF_DVB
|
||||
select VIDEO_CX25840
|
||||
select VIDEO_CX2341X
|
||||
select DVB_DIB7000P if !DVB_FE_CUSTOMISE
|
||||
select MEDIA_TUNER_MT2131 if !DVB_FE_CUSTOMISE
|
||||
select DVB_S5H1409 if !DVB_FE_CUSTOMISE
|
||||
select DVB_LGDT330X if !DVB_FE_CUSTOMISE
|
||||
select DVB_PLL if !DVB_FE_CUSTOMISE
|
||||
select MEDIA_TUNER_XC2028 if !DVB_FE_CUSTOMIZE
|
||||
select MEDIA_TUNER_TDA8290 if !DVB_FE_CUSTOMIZE
|
||||
select MEDIA_TUNER_TDA18271 if !DVB_FE_CUSTOMIZE
|
||||
|
|
|
@ -198,6 +198,10 @@ struct cx23885_subid cx23885_subids[] = {
|
|||
.subvendor = 0x0070,
|
||||
.subdevice = 0x71d1,
|
||||
.card = CX23885_BOARD_HAUPPAUGE_HVR1200,
|
||||
}, {
|
||||
.subvendor = 0x0070,
|
||||
.subdevice = 0x71d3,
|
||||
.card = CX23885_BOARD_HAUPPAUGE_HVR1200,
|
||||
}, {
|
||||
.subvendor = 0x0070,
|
||||
.subdevice = 0x8101,
|
||||
|
@ -245,6 +249,33 @@ static void hauppauge_eeprom(struct cx23885_dev *dev, u8 *eeprom_data)
|
|||
/* Make sure we support the board model */
|
||||
switch (tv.model)
|
||||
{
|
||||
case 71009:
|
||||
/* WinTV-HVR1200 (PCIe, Retail, full height)
|
||||
* DVB-T and basic analog */
|
||||
case 71359:
|
||||
/* WinTV-HVR1200 (PCIe, OEM, half height)
|
||||
* DVB-T and basic analog */
|
||||
case 71439:
|
||||
/* WinTV-HVR1200 (PCIe, OEM, half height)
|
||||
* DVB-T and basic analog */
|
||||
case 71449:
|
||||
/* WinTV-HVR1200 (PCIe, OEM, full height)
|
||||
* DVB-T and basic analog */
|
||||
case 71939:
|
||||
/* WinTV-HVR1200 (PCIe, OEM, half height)
|
||||
* DVB-T and basic analog */
|
||||
case 71949:
|
||||
/* WinTV-HVR1200 (PCIe, OEM, full height)
|
||||
* DVB-T and basic analog */
|
||||
case 71959:
|
||||
/* WinTV-HVR1200 (PCIe, OEM, full height)
|
||||
* DVB-T and basic analog */
|
||||
case 71979:
|
||||
/* WinTV-HVR1200 (PCIe, OEM, half height)
|
||||
* DVB-T and basic analog */
|
||||
case 71999:
|
||||
/* WinTV-HVR1200 (PCIe, OEM, full height)
|
||||
* DVB-T and basic analog */
|
||||
case 76601: /* WinTV-HVR1800lp (PCIe, Retail, No IR, Dual channel ATSC and MPEG2 HW Encoder */
|
||||
case 77001: /* WinTV-HVR1500 (Express Card, OEM, No IR, ATSC and Basic analog */
|
||||
case 77011: /* WinTV-HVR1500 (Express Card, Retail, No IR, ATSC and Basic analog */
|
||||
|
@ -263,8 +294,11 @@ static void hauppauge_eeprom(struct cx23885_dev *dev, u8 *eeprom_data)
|
|||
case 80019:
|
||||
/* WinTV-HVR1400 (Express Card, Retail, IR,
|
||||
* DVB-T and Basic analog */
|
||||
case 81509:
|
||||
/* WinTV-HVR1700 (PCIe, OEM, No IR, half height)
|
||||
* DVB-T and MPEG2 HW Encoder */
|
||||
case 81519:
|
||||
/* WinTV-HVR1700 (PCIe, Retail, No IR, half height,
|
||||
/* WinTV-HVR1700 (PCIe, OEM, No IR, full height)
|
||||
* DVB-T and MPEG2 HW Encoder */
|
||||
break;
|
||||
default:
|
||||
|
|
|
@ -37,7 +37,6 @@
|
|||
#include "lgdt330x.h"
|
||||
#include "xc5000.h"
|
||||
#include "tda10048.h"
|
||||
#include "dvb-pll.h"
|
||||
#include "tuner-xc2028.h"
|
||||
#include "tuner-simple.h"
|
||||
#include "dib7000p.h"
|
||||
|
@ -385,12 +384,10 @@ static int dvb_register(struct cx23885_tsport *port)
|
|||
port->dvb.frontend = dvb_attach(s5h1409_attach,
|
||||
&hauppauge_hvr1500q_config,
|
||||
&dev->i2c_bus[0].i2c_adap);
|
||||
if (port->dvb.frontend != NULL) {
|
||||
hauppauge_hvr1500q_tunerconfig.priv = i2c_bus;
|
||||
if (port->dvb.frontend != NULL)
|
||||
dvb_attach(xc5000_attach, port->dvb.frontend,
|
||||
&i2c_bus->i2c_adap,
|
||||
&hauppauge_hvr1500q_tunerconfig);
|
||||
}
|
||||
&hauppauge_hvr1500q_tunerconfig, i2c_bus);
|
||||
break;
|
||||
case CX23885_BOARD_HAUPPAUGE_HVR1500:
|
||||
i2c_bus = &dev->i2c_bus[1];
|
||||
|
|
|
@ -1,6 +1,7 @@
|
|||
config VIDEO_CX25840
|
||||
tristate "Conexant CX2584x audio/video decoders"
|
||||
depends on VIDEO_V4L2 && I2C && EXPERIMENTAL
|
||||
depends on HOTPLUG # due to FW_LOADER
|
||||
select FW_LOADER
|
||||
---help---
|
||||
Support for the Conexant CX2584x audio/video decoders.
|
||||
|
|
|
@ -2,10 +2,9 @@ config VIDEO_CX88
|
|||
tristate "Conexant 2388x (bt878 successor) support"
|
||||
depends on VIDEO_DEV && PCI && I2C && INPUT
|
||||
select I2C_ALGOBIT
|
||||
select FW_LOADER
|
||||
select VIDEO_BTCX
|
||||
select VIDEOBUF_DMA_SG
|
||||
select MEDIA_TUNER
|
||||
select VIDEO_TUNER
|
||||
select VIDEO_TVEEPROM
|
||||
select VIDEO_IR
|
||||
select VIDEO_WM8775 if VIDEO_HELPER_CHIPS_AUTO
|
||||
|
@ -34,8 +33,9 @@ config VIDEO_CX88_ALSA
|
|||
|
||||
config VIDEO_CX88_BLACKBIRD
|
||||
tristate "Blackbird MPEG encoder support (cx2388x + cx23416)"
|
||||
depends on VIDEO_CX88
|
||||
depends on VIDEO_CX88 && HOTPLUG
|
||||
select VIDEO_CX2341X
|
||||
select FW_LOADER
|
||||
---help---
|
||||
This adds support for MPEG encoder cards based on the
|
||||
Blackbird reference design, using the Conexant 2388x
|
||||
|
|
|
@ -509,9 +509,6 @@ static int attach_xc3028(u8 addr, struct cx8802_dev *dev)
|
|||
if (!fe) {
|
||||
printk(KERN_ERR "%s/2: xc3028 attach failed\n",
|
||||
dev->core->name);
|
||||
dvb_frontend_detach(dev->dvb.frontend);
|
||||
dvb_unregister_frontend(dev->dvb.frontend);
|
||||
dev->dvb.frontend = NULL;
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
|
@ -523,20 +520,23 @@ static int attach_xc3028(u8 addr, struct cx8802_dev *dev)
|
|||
|
||||
static int dvb_register(struct cx8802_dev *dev)
|
||||
{
|
||||
struct cx88_core *core = dev->core;
|
||||
|
||||
/* init struct videobuf_dvb */
|
||||
dev->dvb.name = dev->core->name;
|
||||
dev->dvb.name = core->name;
|
||||
dev->ts_gen_cntrl = 0x0c;
|
||||
|
||||
/* init frontend */
|
||||
switch (dev->core->boardnr) {
|
||||
switch (core->boardnr) {
|
||||
case CX88_BOARD_HAUPPAUGE_DVB_T1:
|
||||
dev->dvb.frontend = dvb_attach(cx22702_attach,
|
||||
&connexant_refboard_config,
|
||||
&dev->core->i2c_adap);
|
||||
&core->i2c_adap);
|
||||
if (dev->dvb.frontend != NULL) {
|
||||
dvb_attach(dvb_pll_attach, dev->dvb.frontend, 0x61,
|
||||
&dev->core->i2c_adap,
|
||||
DVB_PLL_THOMSON_DTT759X);
|
||||
if (!dvb_attach(dvb_pll_attach, dev->dvb.frontend,
|
||||
0x61, &core->i2c_adap,
|
||||
DVB_PLL_THOMSON_DTT759X))
|
||||
goto frontend_detach;
|
||||
}
|
||||
break;
|
||||
case CX88_BOARD_TERRATEC_CINERGY_1400_DVB_T1:
|
||||
|
@ -545,11 +545,12 @@ static int dvb_register(struct cx8802_dev *dev)
|
|||
case CX88_BOARD_WINFAST_DTV1000:
|
||||
dev->dvb.frontend = dvb_attach(cx22702_attach,
|
||||
&connexant_refboard_config,
|
||||
&dev->core->i2c_adap);
|
||||
&core->i2c_adap);
|
||||
if (dev->dvb.frontend != NULL) {
|
||||
dvb_attach(dvb_pll_attach, dev->dvb.frontend, 0x60,
|
||||
&dev->core->i2c_adap,
|
||||
DVB_PLL_THOMSON_DTT7579);
|
||||
if (!dvb_attach(dvb_pll_attach, dev->dvb.frontend,
|
||||
0x60, &core->i2c_adap,
|
||||
DVB_PLL_THOMSON_DTT7579))
|
||||
goto frontend_detach;
|
||||
}
|
||||
break;
|
||||
case CX88_BOARD_WINFAST_DTV2000H:
|
||||
|
@ -559,29 +560,32 @@ static int dvb_register(struct cx8802_dev *dev)
|
|||
case CX88_BOARD_HAUPPAUGE_HVR3000:
|
||||
dev->dvb.frontend = dvb_attach(cx22702_attach,
|
||||
&hauppauge_hvr_config,
|
||||
&dev->core->i2c_adap);
|
||||
&core->i2c_adap);
|
||||
if (dev->dvb.frontend != NULL) {
|
||||
dvb_attach(simple_tuner_attach, dev->dvb.frontend,
|
||||
&dev->core->i2c_adap, 0x61,
|
||||
TUNER_PHILIPS_FMD1216ME_MK3);
|
||||
if (!dvb_attach(simple_tuner_attach, dev->dvb.frontend,
|
||||
&core->i2c_adap, 0x61,
|
||||
TUNER_PHILIPS_FMD1216ME_MK3))
|
||||
goto frontend_detach;
|
||||
}
|
||||
break;
|
||||
case CX88_BOARD_DVICO_FUSIONHDTV_DVB_T_PLUS:
|
||||
dev->dvb.frontend = dvb_attach(mt352_attach,
|
||||
&dvico_fusionhdtv,
|
||||
&dev->core->i2c_adap);
|
||||
&core->i2c_adap);
|
||||
if (dev->dvb.frontend != NULL) {
|
||||
dvb_attach(dvb_pll_attach, dev->dvb.frontend, 0x60,
|
||||
NULL, DVB_PLL_THOMSON_DTT7579);
|
||||
if (!dvb_attach(dvb_pll_attach, dev->dvb.frontend,
|
||||
0x60, NULL, DVB_PLL_THOMSON_DTT7579))
|
||||
goto frontend_detach;
|
||||
break;
|
||||
}
|
||||
/* ZL10353 replaces MT352 on later cards */
|
||||
dev->dvb.frontend = dvb_attach(zl10353_attach,
|
||||
&dvico_fusionhdtv_plus_v1_1,
|
||||
&dev->core->i2c_adap);
|
||||
&core->i2c_adap);
|
||||
if (dev->dvb.frontend != NULL) {
|
||||
dvb_attach(dvb_pll_attach, dev->dvb.frontend, 0x60,
|
||||
NULL, DVB_PLL_THOMSON_DTT7579);
|
||||
if (!dvb_attach(dvb_pll_attach, dev->dvb.frontend,
|
||||
0x60, NULL, DVB_PLL_THOMSON_DTT7579))
|
||||
goto frontend_detach;
|
||||
}
|
||||
break;
|
||||
case CX88_BOARD_DVICO_FUSIONHDTV_DVB_T_DUAL:
|
||||
|
@ -589,28 +593,31 @@ static int dvb_register(struct cx8802_dev *dev)
|
|||
* compatible, with a slightly different MT352 AGC gain. */
|
||||
dev->dvb.frontend = dvb_attach(mt352_attach,
|
||||
&dvico_fusionhdtv_dual,
|
||||
&dev->core->i2c_adap);
|
||||
&core->i2c_adap);
|
||||
if (dev->dvb.frontend != NULL) {
|
||||
dvb_attach(dvb_pll_attach, dev->dvb.frontend, 0x61,
|
||||
NULL, DVB_PLL_THOMSON_DTT7579);
|
||||
if (!dvb_attach(dvb_pll_attach, dev->dvb.frontend,
|
||||
0x61, NULL, DVB_PLL_THOMSON_DTT7579))
|
||||
goto frontend_detach;
|
||||
break;
|
||||
}
|
||||
/* ZL10353 replaces MT352 on later cards */
|
||||
dev->dvb.frontend = dvb_attach(zl10353_attach,
|
||||
&dvico_fusionhdtv_plus_v1_1,
|
||||
&dev->core->i2c_adap);
|
||||
&core->i2c_adap);
|
||||
if (dev->dvb.frontend != NULL) {
|
||||
dvb_attach(dvb_pll_attach, dev->dvb.frontend, 0x61,
|
||||
NULL, DVB_PLL_THOMSON_DTT7579);
|
||||
if (!dvb_attach(dvb_pll_attach, dev->dvb.frontend,
|
||||
0x61, NULL, DVB_PLL_THOMSON_DTT7579))
|
||||
goto frontend_detach;
|
||||
}
|
||||
break;
|
||||
case CX88_BOARD_DVICO_FUSIONHDTV_DVB_T1:
|
||||
dev->dvb.frontend = dvb_attach(mt352_attach,
|
||||
&dvico_fusionhdtv,
|
||||
&dev->core->i2c_adap);
|
||||
&core->i2c_adap);
|
||||
if (dev->dvb.frontend != NULL) {
|
||||
dvb_attach(dvb_pll_attach, dev->dvb.frontend, 0x61,
|
||||
NULL, DVB_PLL_LG_Z201);
|
||||
if (!dvb_attach(dvb_pll_attach, dev->dvb.frontend,
|
||||
0x61, NULL, DVB_PLL_LG_Z201))
|
||||
goto frontend_detach;
|
||||
}
|
||||
break;
|
||||
case CX88_BOARD_KWORLD_DVB_T:
|
||||
|
@ -618,10 +625,11 @@ static int dvb_register(struct cx8802_dev *dev)
|
|||
case CX88_BOARD_ADSTECH_DVB_T_PCI:
|
||||
dev->dvb.frontend = dvb_attach(mt352_attach,
|
||||
&dntv_live_dvbt_config,
|
||||
&dev->core->i2c_adap);
|
||||
&core->i2c_adap);
|
||||
if (dev->dvb.frontend != NULL) {
|
||||
dvb_attach(dvb_pll_attach, dev->dvb.frontend, 0x61,
|
||||
NULL, DVB_PLL_UNKNOWN_1);
|
||||
if (!dvb_attach(dvb_pll_attach, dev->dvb.frontend,
|
||||
0x61, NULL, DVB_PLL_UNKNOWN_1))
|
||||
goto frontend_detach;
|
||||
}
|
||||
break;
|
||||
case CX88_BOARD_DNTV_LIVE_DVB_T_PRO:
|
||||
|
@ -630,32 +638,35 @@ static int dvb_register(struct cx8802_dev *dev)
|
|||
dev->dvb.frontend = dvb_attach(mt352_attach, &dntv_live_dvbt_pro_config,
|
||||
&dev->vp3054->adap);
|
||||
if (dev->dvb.frontend != NULL) {
|
||||
dvb_attach(simple_tuner_attach, dev->dvb.frontend,
|
||||
&dev->core->i2c_adap, 0x61,
|
||||
TUNER_PHILIPS_FMD1216ME_MK3);
|
||||
if (!dvb_attach(simple_tuner_attach, dev->dvb.frontend,
|
||||
&core->i2c_adap, 0x61,
|
||||
TUNER_PHILIPS_FMD1216ME_MK3))
|
||||
goto frontend_detach;
|
||||
}
|
||||
#else
|
||||
printk(KERN_ERR "%s/2: built without vp3054 support\n", dev->core->name);
|
||||
printk(KERN_ERR "%s/2: built without vp3054 support\n",
|
||||
core->name);
|
||||
#endif
|
||||
break;
|
||||
case CX88_BOARD_DVICO_FUSIONHDTV_DVB_T_HYBRID:
|
||||
dev->dvb.frontend = dvb_attach(zl10353_attach,
|
||||
&dvico_fusionhdtv_hybrid,
|
||||
&dev->core->i2c_adap);
|
||||
&core->i2c_adap);
|
||||
if (dev->dvb.frontend != NULL) {
|
||||
dvb_attach(simple_tuner_attach, dev->dvb.frontend,
|
||||
&dev->core->i2c_adap, 0x61,
|
||||
TUNER_THOMSON_FE6600);
|
||||
if (!dvb_attach(simple_tuner_attach, dev->dvb.frontend,
|
||||
&core->i2c_adap, 0x61,
|
||||
TUNER_THOMSON_FE6600))
|
||||
goto frontend_detach;
|
||||
}
|
||||
break;
|
||||
case CX88_BOARD_DVICO_FUSIONHDTV_DVB_T_PRO:
|
||||
dev->dvb.frontend = dvb_attach(zl10353_attach,
|
||||
&dvico_fusionhdtv_xc3028,
|
||||
&dev->core->i2c_adap);
|
||||
&core->i2c_adap);
|
||||
if (dev->dvb.frontend == NULL)
|
||||
dev->dvb.frontend = dvb_attach(mt352_attach,
|
||||
&dvico_fusionhdtv_mt352_xc3028,
|
||||
&dev->core->i2c_adap);
|
||||
&core->i2c_adap);
|
||||
/*
|
||||
* On this board, the demod provides the I2C bus pullup.
|
||||
* We must not permit gate_ctrl to be performed, or
|
||||
|
@ -668,19 +679,18 @@ static int dvb_register(struct cx8802_dev *dev)
|
|||
break;
|
||||
case CX88_BOARD_PCHDTV_HD3000:
|
||||
dev->dvb.frontend = dvb_attach(or51132_attach, &pchdtv_hd3000,
|
||||
&dev->core->i2c_adap);
|
||||
&core->i2c_adap);
|
||||
if (dev->dvb.frontend != NULL) {
|
||||
dvb_attach(simple_tuner_attach, dev->dvb.frontend,
|
||||
&dev->core->i2c_adap, 0x61,
|
||||
TUNER_THOMSON_DTT761X);
|
||||
if (!dvb_attach(simple_tuner_attach, dev->dvb.frontend,
|
||||
&core->i2c_adap, 0x61,
|
||||
TUNER_THOMSON_DTT761X))
|
||||
goto frontend_detach;
|
||||
}
|
||||
break;
|
||||
case CX88_BOARD_DVICO_FUSIONHDTV_3_GOLD_Q:
|
||||
dev->ts_gen_cntrl = 0x08;
|
||||
{
|
||||
/* Do a hardware reset of chip before using it. */
|
||||
struct cx88_core *core = dev->core;
|
||||
|
||||
/* Do a hardware reset of chip before using it. */
|
||||
cx_clear(MO_GP0_IO, 1);
|
||||
mdelay(100);
|
||||
cx_set(MO_GP0_IO, 1);
|
||||
|
@ -690,139 +700,137 @@ static int dvb_register(struct cx8802_dev *dev)
|
|||
fusionhdtv_3_gold.pll_rf_set = lgdt330x_pll_rf_set;
|
||||
dev->dvb.frontend = dvb_attach(lgdt330x_attach,
|
||||
&fusionhdtv_3_gold,
|
||||
&dev->core->i2c_adap);
|
||||
&core->i2c_adap);
|
||||
if (dev->dvb.frontend != NULL) {
|
||||
dvb_attach(simple_tuner_attach, dev->dvb.frontend,
|
||||
&dev->core->i2c_adap, 0x61,
|
||||
TUNER_MICROTUNE_4042FI5);
|
||||
}
|
||||
if (!dvb_attach(simple_tuner_attach, dev->dvb.frontend,
|
||||
&core->i2c_adap, 0x61,
|
||||
TUNER_MICROTUNE_4042FI5))
|
||||
goto frontend_detach;
|
||||
}
|
||||
break;
|
||||
case CX88_BOARD_DVICO_FUSIONHDTV_3_GOLD_T:
|
||||
dev->ts_gen_cntrl = 0x08;
|
||||
{
|
||||
/* Do a hardware reset of chip before using it. */
|
||||
struct cx88_core *core = dev->core;
|
||||
|
||||
/* Do a hardware reset of chip before using it. */
|
||||
cx_clear(MO_GP0_IO, 1);
|
||||
mdelay(100);
|
||||
cx_set(MO_GP0_IO, 9);
|
||||
mdelay(200);
|
||||
dev->dvb.frontend = dvb_attach(lgdt330x_attach,
|
||||
&fusionhdtv_3_gold,
|
||||
&dev->core->i2c_adap);
|
||||
&core->i2c_adap);
|
||||
if (dev->dvb.frontend != NULL) {
|
||||
dvb_attach(simple_tuner_attach, dev->dvb.frontend,
|
||||
&dev->core->i2c_adap, 0x61,
|
||||
TUNER_THOMSON_DTT761X);
|
||||
}
|
||||
if (!dvb_attach(simple_tuner_attach, dev->dvb.frontend,
|
||||
&core->i2c_adap, 0x61,
|
||||
TUNER_THOMSON_DTT761X))
|
||||
goto frontend_detach;
|
||||
}
|
||||
break;
|
||||
case CX88_BOARD_DVICO_FUSIONHDTV_5_GOLD:
|
||||
dev->ts_gen_cntrl = 0x08;
|
||||
{
|
||||
/* Do a hardware reset of chip before using it. */
|
||||
struct cx88_core *core = dev->core;
|
||||
|
||||
/* Do a hardware reset of chip before using it. */
|
||||
cx_clear(MO_GP0_IO, 1);
|
||||
mdelay(100);
|
||||
cx_set(MO_GP0_IO, 1);
|
||||
mdelay(200);
|
||||
dev->dvb.frontend = dvb_attach(lgdt330x_attach,
|
||||
&fusionhdtv_5_gold,
|
||||
&dev->core->i2c_adap);
|
||||
&core->i2c_adap);
|
||||
if (dev->dvb.frontend != NULL) {
|
||||
dvb_attach(simple_tuner_attach, dev->dvb.frontend,
|
||||
&dev->core->i2c_adap, 0x61,
|
||||
TUNER_LG_TDVS_H06XF);
|
||||
dvb_attach(tda9887_attach, dev->dvb.frontend,
|
||||
&dev->core->i2c_adap, 0x43);
|
||||
}
|
||||
if (!dvb_attach(simple_tuner_attach, dev->dvb.frontend,
|
||||
&core->i2c_adap, 0x61,
|
||||
TUNER_LG_TDVS_H06XF))
|
||||
goto frontend_detach;
|
||||
if (!dvb_attach(tda9887_attach, dev->dvb.frontend,
|
||||
&core->i2c_adap, 0x43))
|
||||
goto frontend_detach;
|
||||
}
|
||||
break;
|
||||
case CX88_BOARD_PCHDTV_HD5500:
|
||||
dev->ts_gen_cntrl = 0x08;
|
||||
{
|
||||
/* Do a hardware reset of chip before using it. */
|
||||
struct cx88_core *core = dev->core;
|
||||
|
||||
/* Do a hardware reset of chip before using it. */
|
||||
cx_clear(MO_GP0_IO, 1);
|
||||
mdelay(100);
|
||||
cx_set(MO_GP0_IO, 1);
|
||||
mdelay(200);
|
||||
dev->dvb.frontend = dvb_attach(lgdt330x_attach,
|
||||
&pchdtv_hd5500,
|
||||
&dev->core->i2c_adap);
|
||||
&core->i2c_adap);
|
||||
if (dev->dvb.frontend != NULL) {
|
||||
dvb_attach(simple_tuner_attach, dev->dvb.frontend,
|
||||
&dev->core->i2c_adap, 0x61,
|
||||
TUNER_LG_TDVS_H06XF);
|
||||
dvb_attach(tda9887_attach, dev->dvb.frontend,
|
||||
&dev->core->i2c_adap, 0x43);
|
||||
}
|
||||
if (!dvb_attach(simple_tuner_attach, dev->dvb.frontend,
|
||||
&core->i2c_adap, 0x61,
|
||||
TUNER_LG_TDVS_H06XF))
|
||||
goto frontend_detach;
|
||||
if (!dvb_attach(tda9887_attach, dev->dvb.frontend,
|
||||
&core->i2c_adap, 0x43))
|
||||
goto frontend_detach;
|
||||
}
|
||||
break;
|
||||
case CX88_BOARD_ATI_HDTVWONDER:
|
||||
dev->dvb.frontend = dvb_attach(nxt200x_attach,
|
||||
&ati_hdtvwonder,
|
||||
&dev->core->i2c_adap);
|
||||
&core->i2c_adap);
|
||||
if (dev->dvb.frontend != NULL) {
|
||||
dvb_attach(simple_tuner_attach, dev->dvb.frontend,
|
||||
&dev->core->i2c_adap, 0x61,
|
||||
TUNER_PHILIPS_TUV1236D);
|
||||
if (!dvb_attach(simple_tuner_attach, dev->dvb.frontend,
|
||||
&core->i2c_adap, 0x61,
|
||||
TUNER_PHILIPS_TUV1236D))
|
||||
goto frontend_detach;
|
||||
}
|
||||
break;
|
||||
case CX88_BOARD_HAUPPAUGE_NOVASPLUS_S1:
|
||||
case CX88_BOARD_HAUPPAUGE_NOVASE2_S1:
|
||||
dev->dvb.frontend = dvb_attach(cx24123_attach,
|
||||
&hauppauge_novas_config,
|
||||
&dev->core->i2c_adap);
|
||||
&core->i2c_adap);
|
||||
if (dev->dvb.frontend) {
|
||||
dvb_attach(isl6421_attach, dev->dvb.frontend,
|
||||
&dev->core->i2c_adap, 0x08, 0x00, 0x00);
|
||||
if (!dvb_attach(isl6421_attach, dev->dvb.frontend,
|
||||
&core->i2c_adap, 0x08, 0x00, 0x00))
|
||||
goto frontend_detach;
|
||||
}
|
||||
break;
|
||||
case CX88_BOARD_KWORLD_DVBS_100:
|
||||
dev->dvb.frontend = dvb_attach(cx24123_attach,
|
||||
&kworld_dvbs_100_config,
|
||||
&dev->core->i2c_adap);
|
||||
&core->i2c_adap);
|
||||
if (dev->dvb.frontend) {
|
||||
dev->core->prev_set_voltage = dev->dvb.frontend->ops.set_voltage;
|
||||
core->prev_set_voltage = dev->dvb.frontend->ops.set_voltage;
|
||||
dev->dvb.frontend->ops.set_voltage = kworld_dvbs_100_set_voltage;
|
||||
}
|
||||
break;
|
||||
case CX88_BOARD_GENIATECH_DVBS:
|
||||
dev->dvb.frontend = dvb_attach(cx24123_attach,
|
||||
&geniatech_dvbs_config,
|
||||
&dev->core->i2c_adap);
|
||||
&core->i2c_adap);
|
||||
if (dev->dvb.frontend) {
|
||||
dev->core->prev_set_voltage = dev->dvb.frontend->ops.set_voltage;
|
||||
core->prev_set_voltage = dev->dvb.frontend->ops.set_voltage;
|
||||
dev->dvb.frontend->ops.set_voltage = geniatech_dvbs_set_voltage;
|
||||
}
|
||||
break;
|
||||
case CX88_BOARD_PINNACLE_PCTV_HD_800i:
|
||||
dev->dvb.frontend = dvb_attach(s5h1409_attach,
|
||||
&pinnacle_pctv_hd_800i_config,
|
||||
&dev->core->i2c_adap);
|
||||
&core->i2c_adap);
|
||||
if (dev->dvb.frontend != NULL) {
|
||||
/* tuner_config.video_dev must point to
|
||||
* i2c_adap.algo_data
|
||||
*/
|
||||
pinnacle_pctv_hd_800i_tuner_config.priv =
|
||||
dev->core->i2c_adap.algo_data;
|
||||
dvb_attach(xc5000_attach, dev->dvb.frontend,
|
||||
&dev->core->i2c_adap,
|
||||
&pinnacle_pctv_hd_800i_tuner_config);
|
||||
if (!dvb_attach(xc5000_attach, dev->dvb.frontend,
|
||||
&core->i2c_adap,
|
||||
&pinnacle_pctv_hd_800i_tuner_config,
|
||||
core->i2c_adap.algo_data))
|
||||
goto frontend_detach;
|
||||
}
|
||||
break;
|
||||
case CX88_BOARD_DVICO_FUSIONHDTV_5_PCI_NANO:
|
||||
dev->dvb.frontend = dvb_attach(s5h1409_attach,
|
||||
&dvico_hdtv5_pci_nano_config,
|
||||
&dev->core->i2c_adap);
|
||||
&core->i2c_adap);
|
||||
if (dev->dvb.frontend != NULL) {
|
||||
struct dvb_frontend *fe;
|
||||
struct xc2028_config cfg = {
|
||||
.i2c_adap = &dev->core->i2c_adap,
|
||||
.i2c_adap = &core->i2c_adap,
|
||||
.i2c_addr = 0x61,
|
||||
.callback = cx88_pci_nano_callback,
|
||||
};
|
||||
|
@ -841,50 +849,50 @@ static int dvb_register(struct cx8802_dev *dev)
|
|||
case CX88_BOARD_PINNACLE_HYBRID_PCTV:
|
||||
dev->dvb.frontend = dvb_attach(zl10353_attach,
|
||||
&cx88_geniatech_x8000_mt,
|
||||
&dev->core->i2c_adap);
|
||||
&core->i2c_adap);
|
||||
if (attach_xc3028(0x61, dev) < 0)
|
||||
return -EINVAL;
|
||||
goto frontend_detach;
|
||||
break;
|
||||
case CX88_BOARD_GENIATECH_X8000_MT:
|
||||
dev->ts_gen_cntrl = 0x00;
|
||||
|
||||
dev->dvb.frontend = dvb_attach(zl10353_attach,
|
||||
&cx88_geniatech_x8000_mt,
|
||||
&dev->core->i2c_adap);
|
||||
&core->i2c_adap);
|
||||
if (attach_xc3028(0x61, dev) < 0)
|
||||
return -EINVAL;
|
||||
goto frontend_detach;
|
||||
break;
|
||||
case CX88_BOARD_KWORLD_ATSC_120:
|
||||
dev->dvb.frontend = dvb_attach(s5h1409_attach,
|
||||
&kworld_atsc_120_config,
|
||||
&dev->core->i2c_adap);
|
||||
&core->i2c_adap);
|
||||
if (attach_xc3028(0x61, dev) < 0)
|
||||
return -EINVAL;
|
||||
goto frontend_detach;
|
||||
break;
|
||||
case CX88_BOARD_DVICO_FUSIONHDTV_7_GOLD:
|
||||
dev->dvb.frontend = dvb_attach(s5h1411_attach,
|
||||
&dvico_fusionhdtv7_config,
|
||||
&dev->core->i2c_adap);
|
||||
&core->i2c_adap);
|
||||
if (dev->dvb.frontend != NULL) {
|
||||
/* tuner_config.video_dev must point to
|
||||
* i2c_adap.algo_data
|
||||
*/
|
||||
dvico_fusionhdtv7_tuner_config.priv =
|
||||
dev->core->i2c_adap.algo_data;
|
||||
dvb_attach(xc5000_attach, dev->dvb.frontend,
|
||||
&dev->core->i2c_adap,
|
||||
&dvico_fusionhdtv7_tuner_config);
|
||||
if (!dvb_attach(xc5000_attach, dev->dvb.frontend,
|
||||
&core->i2c_adap,
|
||||
&dvico_fusionhdtv7_tuner_config,
|
||||
core->i2c_adap.algo_data))
|
||||
goto frontend_detach;
|
||||
}
|
||||
break;
|
||||
default:
|
||||
printk(KERN_ERR "%s/2: The frontend of your DVB/ATSC card isn't supported yet\n",
|
||||
dev->core->name);
|
||||
core->name);
|
||||
break;
|
||||
}
|
||||
if (NULL == dev->dvb.frontend) {
|
||||
printk(KERN_ERR
|
||||
"%s/2: frontend initialization failed\n",
|
||||
dev->core->name);
|
||||
core->name);
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
|
@ -892,11 +900,18 @@ static int dvb_register(struct cx8802_dev *dev)
|
|||
dev->dvb.frontend->ops.ts_bus_ctrl = cx88_dvb_bus_ctrl;
|
||||
|
||||
/* Put the analog decoder in standby to keep it quiet */
|
||||
cx88_call_i2c_clients (dev->core, TUNER_SET_STANDBY, NULL);
|
||||
cx88_call_i2c_clients(core, TUNER_SET_STANDBY, NULL);
|
||||
|
||||
/* register everything */
|
||||
return videobuf_dvb_register(&dev->dvb, THIS_MODULE, dev,
|
||||
&dev->pci->dev, adapter_nr);
|
||||
|
||||
frontend_detach:
|
||||
if (dev->dvb.frontend) {
|
||||
dvb_frontend_detach(dev->dvb.frontend);
|
||||
dev->dvb.frontend = NULL;
|
||||
}
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
/* ----------------------------------------------------------- */
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
config VIDEO_EM28XX
|
||||
tristate "Empia EM28xx USB video capture support"
|
||||
depends on VIDEO_DEV && I2C && INPUT
|
||||
select MEDIA_TUNER
|
||||
select VIDEO_TUNER
|
||||
select VIDEO_TVEEPROM
|
||||
select VIDEO_IR
|
||||
select VIDEOBUF_VMALLOC
|
||||
|
@ -35,7 +35,6 @@ config VIDEO_EM28XX_DVB
|
|||
select DVB_LGDT330X if !DVB_FE_CUSTOMISE
|
||||
select DVB_ZL10353 if !DVB_FE_CUSTOMISE
|
||||
select VIDEOBUF_DVB
|
||||
select FW_LOADER
|
||||
---help---
|
||||
This adds support for DVB cards based on the
|
||||
Empiatech em28xx chips.
|
||||
|
|
|
@ -420,7 +420,13 @@ struct usb_device_id em28xx_id_table [] = {
|
|||
.driver_info = EM2880_BOARD_HAUPPAUGE_WINTV_HVR_900 },
|
||||
{ USB_DEVICE(0x2040, 0x6502),
|
||||
.driver_info = EM2880_BOARD_HAUPPAUGE_WINTV_HVR_900 },
|
||||
{ USB_DEVICE(0x2040, 0x6513),
|
||||
{ USB_DEVICE(0x2040, 0x6513), /* HCW HVR-980 */
|
||||
.driver_info = EM2880_BOARD_HAUPPAUGE_WINTV_HVR_950 },
|
||||
{ USB_DEVICE(0x2040, 0x6517), /* HP HVR-950 */
|
||||
.driver_info = EM2880_BOARD_HAUPPAUGE_WINTV_HVR_950 },
|
||||
{ USB_DEVICE(0x2040, 0x651b), /* RP HVR-950 */
|
||||
.driver_info = EM2880_BOARD_HAUPPAUGE_WINTV_HVR_950 },
|
||||
{ USB_DEVICE(0x2040, 0x651f), /* HCW HVR-850 */
|
||||
.driver_info = EM2880_BOARD_HAUPPAUGE_WINTV_HVR_950 },
|
||||
{ USB_DEVICE(0x0ccd, 0x0042),
|
||||
.driver_info = EM2880_BOARD_TERRATEC_HYBRID_XS },
|
||||
|
|
|
@ -251,7 +251,6 @@ static int attach_xc3028(u8 addr, struct em28xx *dev)
|
|||
printk(KERN_ERR "%s/2: xc3028 attach failed\n",
|
||||
dev->name);
|
||||
dvb_frontend_detach(dev->dvb->frontend);
|
||||
dvb_unregister_frontend(dev->dvb->frontend);
|
||||
dev->dvb->frontend = NULL;
|
||||
return -EINVAL;
|
||||
}
|
||||
|
|
|
@ -1,10 +1,12 @@
|
|||
config VIDEO_IVTV
|
||||
tristate "Conexant cx23416/cx23415 MPEG encoder/decoder support"
|
||||
depends on VIDEO_V4L1 && VIDEO_V4L2 && PCI && I2C && EXPERIMENTAL
|
||||
depends on INPUT # due to VIDEO_IR
|
||||
depends on HOTPLUG # due to FW_LOADER
|
||||
select I2C_ALGOBIT
|
||||
select FW_LOADER
|
||||
select VIDEO_IR
|
||||
select MEDIA_TUNER
|
||||
select VIDEO_TUNER
|
||||
select VIDEO_TVEEPROM
|
||||
select VIDEO_CX2341X
|
||||
select VIDEO_CX25840
|
||||
|
|
|
@ -181,12 +181,12 @@ static int ivtv_setup_vbi_fmt(struct ivtv *itv, enum v4l2_mpeg_stream_vbi_fmt fm
|
|||
return 0;
|
||||
}
|
||||
/* Need sliced data for mpeg insertion */
|
||||
if (get_service_set(itv->vbi.sliced_in) == 0) {
|
||||
if (ivtv_get_service_set(itv->vbi.sliced_in) == 0) {
|
||||
if (itv->is_60hz)
|
||||
itv->vbi.sliced_in->service_set = V4L2_SLICED_CAPTION_525;
|
||||
else
|
||||
itv->vbi.sliced_in->service_set = V4L2_SLICED_WSS_625;
|
||||
expand_service_set(itv->vbi.sliced_in, itv->is_50hz);
|
||||
ivtv_expand_service_set(itv->vbi.sliced_in, itv->is_50hz);
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
|
|
|
@ -853,6 +853,7 @@ static int ivtv_setup_pci(struct ivtv *itv, struct pci_dev *dev,
|
|||
return 0;
|
||||
}
|
||||
|
||||
#ifdef MODULE
|
||||
static u32 ivtv_request_module(struct ivtv *itv, u32 hw,
|
||||
const char *name, u32 id)
|
||||
{
|
||||
|
@ -865,12 +866,14 @@ static u32 ivtv_request_module(struct ivtv *itv, u32 hw,
|
|||
IVTV_DEBUG_INFO("Loaded module %s\n", name);
|
||||
return hw;
|
||||
}
|
||||
#endif
|
||||
|
||||
static void ivtv_load_and_init_modules(struct ivtv *itv)
|
||||
{
|
||||
u32 hw = itv->card->hw_all;
|
||||
unsigned i;
|
||||
|
||||
#ifdef MODULE
|
||||
/* load modules */
|
||||
#ifndef CONFIG_MEDIA_TUNER
|
||||
hw = ivtv_request_module(itv, hw, "tuner", IVTV_HW_TUNER);
|
||||
|
@ -910,6 +913,7 @@ static void ivtv_load_and_init_modules(struct ivtv *itv)
|
|||
#endif
|
||||
#ifndef CONFIG_VIDEO_M52790
|
||||
hw = ivtv_request_module(itv, hw, "m52790", IVTV_HW_M52790);
|
||||
#endif
|
||||
#endif
|
||||
|
||||
/* check which i2c devices are actually found */
|
||||
|
@ -1228,7 +1232,7 @@ static int __devinit ivtv_probe(struct pci_dev *dev,
|
|||
return 0;
|
||||
|
||||
free_streams:
|
||||
ivtv_streams_cleanup(itv);
|
||||
ivtv_streams_cleanup(itv, 1);
|
||||
free_irq:
|
||||
free_irq(itv->dev->irq, (void *)itv);
|
||||
free_i2c:
|
||||
|
@ -1373,7 +1377,7 @@ static void ivtv_remove(struct pci_dev *pci_dev)
|
|||
flush_workqueue(itv->irq_work_queues);
|
||||
destroy_workqueue(itv->irq_work_queues);
|
||||
|
||||
ivtv_streams_cleanup(itv);
|
||||
ivtv_streams_cleanup(itv, 1);
|
||||
ivtv_udma_free(itv);
|
||||
|
||||
exit_ivtv_i2c(itv);
|
||||
|
|
|
@ -987,6 +987,8 @@ int ivtv_v4l2_open(struct inode *inode, struct file *filp)
|
|||
/* Find which card this open was on */
|
||||
spin_lock(&ivtv_cards_lock);
|
||||
for (x = 0; itv == NULL && x < ivtv_cards_active; x++) {
|
||||
if (ivtv_cards[x] == NULL)
|
||||
continue;
|
||||
/* find out which stream this open was on */
|
||||
for (y = 0; y < IVTV_MAX_STREAMS; y++) {
|
||||
s = &ivtv_cards[x]->streams[y];
|
||||
|
|
|
@ -38,7 +38,7 @@
|
|||
#include <linux/dvb/audio.h>
|
||||
#include <linux/i2c-id.h>
|
||||
|
||||
u16 service2vbi(int type)
|
||||
u16 ivtv_service2vbi(int type)
|
||||
{
|
||||
switch (type) {
|
||||
case V4L2_SLICED_TELETEXT_B:
|
||||
|
@ -88,7 +88,7 @@ static u16 select_service_from_set(int field, int line, u16 set, int is_pal)
|
|||
return 0;
|
||||
}
|
||||
|
||||
void expand_service_set(struct v4l2_sliced_vbi_format *fmt, int is_pal)
|
||||
void ivtv_expand_service_set(struct v4l2_sliced_vbi_format *fmt, int is_pal)
|
||||
{
|
||||
u16 set = fmt->service_set;
|
||||
int f, l;
|
||||
|
@ -115,7 +115,7 @@ static int check_service_set(struct v4l2_sliced_vbi_format *fmt, int is_pal)
|
|||
return set != 0;
|
||||
}
|
||||
|
||||
u16 get_service_set(struct v4l2_sliced_vbi_format *fmt)
|
||||
u16 ivtv_get_service_set(struct v4l2_sliced_vbi_format *fmt)
|
||||
{
|
||||
int f, l;
|
||||
u16 set = 0;
|
||||
|
@ -466,7 +466,7 @@ static int ivtv_get_fmt(struct ivtv *itv, int streamtype, struct v4l2_format *fm
|
|||
vbifmt->service_lines[0][23] = V4L2_SLICED_WSS_625;
|
||||
vbifmt->service_lines[0][16] = V4L2_SLICED_VPS;
|
||||
}
|
||||
vbifmt->service_set = get_service_set(vbifmt);
|
||||
vbifmt->service_set = ivtv_get_service_set(vbifmt);
|
||||
break;
|
||||
}
|
||||
|
||||
|
@ -481,12 +481,12 @@ static int ivtv_get_fmt(struct ivtv *itv, int streamtype, struct v4l2_format *fm
|
|||
if (streamtype == IVTV_DEC_STREAM_TYPE_VBI) {
|
||||
vbifmt->service_set = itv->is_50hz ? V4L2_SLICED_VBI_625 :
|
||||
V4L2_SLICED_VBI_525;
|
||||
expand_service_set(vbifmt, itv->is_50hz);
|
||||
ivtv_expand_service_set(vbifmt, itv->is_50hz);
|
||||
break;
|
||||
}
|
||||
|
||||
itv->video_dec_func(itv, VIDIOC_G_FMT, fmt);
|
||||
vbifmt->service_set = get_service_set(vbifmt);
|
||||
vbifmt->service_set = ivtv_get_service_set(vbifmt);
|
||||
break;
|
||||
}
|
||||
case V4L2_BUF_TYPE_VBI_OUTPUT:
|
||||
|
@ -640,9 +640,9 @@ static int ivtv_try_or_set_fmt(struct ivtv *itv, int streamtype,
|
|||
memset(vbifmt->reserved, 0, sizeof(vbifmt->reserved));
|
||||
|
||||
if (vbifmt->service_set)
|
||||
expand_service_set(vbifmt, itv->is_50hz);
|
||||
ivtv_expand_service_set(vbifmt, itv->is_50hz);
|
||||
set = check_service_set(vbifmt, itv->is_50hz);
|
||||
vbifmt->service_set = get_service_set(vbifmt);
|
||||
vbifmt->service_set = ivtv_get_service_set(vbifmt);
|
||||
|
||||
if (!set_fmt)
|
||||
return 0;
|
||||
|
|
|
@ -21,9 +21,9 @@
|
|||
#ifndef IVTV_IOCTL_H
|
||||
#define IVTV_IOCTL_H
|
||||
|
||||
u16 service2vbi(int type);
|
||||
void expand_service_set(struct v4l2_sliced_vbi_format *fmt, int is_pal);
|
||||
u16 get_service_set(struct v4l2_sliced_vbi_format *fmt);
|
||||
u16 ivtv_service2vbi(int type);
|
||||
void ivtv_expand_service_set(struct v4l2_sliced_vbi_format *fmt, int is_pal);
|
||||
u16 ivtv_get_service_set(struct v4l2_sliced_vbi_format *fmt);
|
||||
int ivtv_v4l2_ioctl(struct inode *inode, struct file *filp, unsigned int cmd,
|
||||
unsigned long arg);
|
||||
int ivtv_v4l2_ioctls(struct ivtv *itv, struct file *filp, unsigned int cmd, void *arg);
|
||||
|
|
|
@ -203,14 +203,14 @@ int ivtv_stream_alloc(struct ivtv_stream *s)
|
|||
s->dma != PCI_DMA_NONE ? "DMA " : "",
|
||||
s->name, s->buffers, s->buf_size, s->buffers * s->buf_size / 1024);
|
||||
|
||||
s->sg_pending = kzalloc(SGsize, GFP_KERNEL);
|
||||
s->sg_pending = kzalloc(SGsize, GFP_KERNEL|__GFP_NOWARN);
|
||||
if (s->sg_pending == NULL) {
|
||||
IVTV_ERR("Could not allocate sg_pending for %s stream\n", s->name);
|
||||
return -ENOMEM;
|
||||
}
|
||||
s->sg_pending_size = 0;
|
||||
|
||||
s->sg_processing = kzalloc(SGsize, GFP_KERNEL);
|
||||
s->sg_processing = kzalloc(SGsize, GFP_KERNEL|__GFP_NOWARN);
|
||||
if (s->sg_processing == NULL) {
|
||||
IVTV_ERR("Could not allocate sg_processing for %s stream\n", s->name);
|
||||
kfree(s->sg_pending);
|
||||
|
@ -219,7 +219,8 @@ int ivtv_stream_alloc(struct ivtv_stream *s)
|
|||
}
|
||||
s->sg_processing_size = 0;
|
||||
|
||||
s->sg_dma = kzalloc(sizeof(struct ivtv_sg_element), GFP_KERNEL);
|
||||
s->sg_dma = kzalloc(sizeof(struct ivtv_sg_element),
|
||||
GFP_KERNEL|__GFP_NOWARN);
|
||||
if (s->sg_dma == NULL) {
|
||||
IVTV_ERR("Could not allocate sg_dma for %s stream\n", s->name);
|
||||
kfree(s->sg_pending);
|
||||
|
@ -235,11 +236,12 @@ int ivtv_stream_alloc(struct ivtv_stream *s)
|
|||
|
||||
/* allocate stream buffers. Initially all buffers are in q_free. */
|
||||
for (i = 0; i < s->buffers; i++) {
|
||||
struct ivtv_buffer *buf = kzalloc(sizeof(struct ivtv_buffer), GFP_KERNEL);
|
||||
struct ivtv_buffer *buf = kzalloc(sizeof(struct ivtv_buffer),
|
||||
GFP_KERNEL|__GFP_NOWARN);
|
||||
|
||||
if (buf == NULL)
|
||||
break;
|
||||
buf->buf = kmalloc(s->buf_size + 256, GFP_KERNEL);
|
||||
buf->buf = kmalloc(s->buf_size + 256, GFP_KERNEL|__GFP_NOWARN);
|
||||
if (buf->buf == NULL) {
|
||||
kfree(buf);
|
||||
break;
|
||||
|
|
|
@ -244,7 +244,7 @@ int ivtv_streams_setup(struct ivtv *itv)
|
|||
return 0;
|
||||
|
||||
/* One or more streams could not be initialized. Clean 'em all up. */
|
||||
ivtv_streams_cleanup(itv);
|
||||
ivtv_streams_cleanup(itv, 0);
|
||||
return -ENOMEM;
|
||||
}
|
||||
|
||||
|
@ -304,12 +304,12 @@ int ivtv_streams_register(struct ivtv *itv)
|
|||
return 0;
|
||||
|
||||
/* One or more streams could not be initialized. Clean 'em all up. */
|
||||
ivtv_streams_cleanup(itv);
|
||||
ivtv_streams_cleanup(itv, 1);
|
||||
return -ENOMEM;
|
||||
}
|
||||
|
||||
/* Unregister v4l2 devices */
|
||||
void ivtv_streams_cleanup(struct ivtv *itv)
|
||||
void ivtv_streams_cleanup(struct ivtv *itv, int unregister)
|
||||
{
|
||||
int type;
|
||||
|
||||
|
@ -322,8 +322,11 @@ void ivtv_streams_cleanup(struct ivtv *itv)
|
|||
continue;
|
||||
|
||||
ivtv_stream_free(&itv->streams[type]);
|
||||
/* Unregister device */
|
||||
video_unregister_device(vdev);
|
||||
/* Unregister or release device */
|
||||
if (unregister)
|
||||
video_unregister_device(vdev);
|
||||
else
|
||||
video_device_release(vdev);
|
||||
}
|
||||
}
|
||||
|
||||
|
|
|
@ -23,7 +23,7 @@
|
|||
|
||||
int ivtv_streams_setup(struct ivtv *itv);
|
||||
int ivtv_streams_register(struct ivtv *itv);
|
||||
void ivtv_streams_cleanup(struct ivtv *itv);
|
||||
void ivtv_streams_cleanup(struct ivtv *itv, int unregister);
|
||||
|
||||
/* Capture related */
|
||||
int ivtv_start_v4l2_encode_stream(struct ivtv_stream *s);
|
||||
|
|
|
@ -169,7 +169,8 @@ static void copy_vbi_data(struct ivtv *itv, int lines, u32 pts_stamp)
|
|||
linemask[0] |= (1 << l);
|
||||
else
|
||||
linemask[1] |= (1 << (l - 32));
|
||||
dst[sd + 12 + line * 43] = service2vbi(itv->vbi.sliced_data[i].id);
|
||||
dst[sd + 12 + line * 43] =
|
||||
ivtv_service2vbi(itv->vbi.sliced_data[i].id);
|
||||
memcpy(dst + sd + 12 + line * 43 + 1, itv->vbi.sliced_data[i].data, 42);
|
||||
line++;
|
||||
}
|
||||
|
|
|
@ -908,7 +908,7 @@ static void ivtv_yuv_init(struct ivtv *itv)
|
|||
}
|
||||
|
||||
/* We need a buffer for blanking when Y plane is offset - non-fatal if we can't get one */
|
||||
yi->blanking_ptr = kzalloc(720 * 16, GFP_KERNEL);
|
||||
yi->blanking_ptr = kzalloc(720 * 16, GFP_KERNEL|__GFP_NOWARN);
|
||||
if (yi->blanking_ptr) {
|
||||
yi->blanking_dmaptr = pci_map_single(itv->dev, yi->blanking_ptr, 720*16, PCI_DMA_TODEVICE);
|
||||
} else {
|
||||
|
|
|
@ -948,7 +948,8 @@ static int ivtvfb_init_vidmode(struct ivtv *itv)
|
|||
}
|
||||
|
||||
/* Allocate the pseudo palette */
|
||||
oi->ivtvfb_info.pseudo_palette = kmalloc(sizeof(u32) * 16, GFP_KERNEL);
|
||||
oi->ivtvfb_info.pseudo_palette =
|
||||
kmalloc(sizeof(u32) * 16, GFP_KERNEL|__GFP_NOWARN);
|
||||
|
||||
if (!oi->ivtvfb_info.pseudo_palette) {
|
||||
IVTVFB_ERR("abort, unable to alloc pseudo pallete\n");
|
||||
|
@ -1056,7 +1057,8 @@ static int ivtvfb_init_card(struct ivtv *itv)
|
|||
return -EBUSY;
|
||||
}
|
||||
|
||||
itv->osd_info = kzalloc(sizeof(struct osd_info), GFP_ATOMIC);
|
||||
itv->osd_info = kzalloc(sizeof(struct osd_info),
|
||||
GFP_ATOMIC|__GFP_NOWARN);
|
||||
if (itv->osd_info == NULL) {
|
||||
IVTVFB_ERR("Failed to allocate memory for osd_info\n");
|
||||
return -ENOMEM;
|
||||
|
|
|
@ -12,15 +12,12 @@
|
|||
#include <linux/slab.h>
|
||||
#include <linux/i2c.h>
|
||||
#include <linux/log2.h>
|
||||
#include <linux/gpio.h>
|
||||
|
||||
#include <media/v4l2-common.h>
|
||||
#include <media/v4l2-chip-ident.h>
|
||||
#include <media/soc_camera.h>
|
||||
|
||||
#ifdef CONFIG_MT9M001_PCA9536_SWITCH
|
||||
#include <asm/gpio.h>
|
||||
#endif
|
||||
|
||||
/* mt9m001 i2c address 0x5d
|
||||
* The platform has to define i2c_board_info
|
||||
* and call i2c_register_board_info() */
|
||||
|
|
|
@ -13,15 +13,12 @@
|
|||
#include <linux/i2c.h>
|
||||
#include <linux/delay.h>
|
||||
#include <linux/log2.h>
|
||||
#include <linux/gpio.h>
|
||||
|
||||
#include <media/v4l2-common.h>
|
||||
#include <media/v4l2-chip-ident.h>
|
||||
#include <media/soc_camera.h>
|
||||
|
||||
#ifdef CONFIG_MT9M001_PCA9536_SWITCH
|
||||
#include <asm/gpio.h>
|
||||
#endif
|
||||
|
||||
/* mt9v022 i2c address 0x48, 0x4c, 0x58, 0x5c
|
||||
* The platform has to define i2c_board_info
|
||||
* and call i2c_register_board_info() */
|
||||
|
@ -91,7 +88,7 @@ static const struct soc_camera_data_format mt9v022_monochrome_formats[] = {
|
|||
struct mt9v022 {
|
||||
struct i2c_client *client;
|
||||
struct soc_camera_device icd;
|
||||
int model; /* V4L2_IDENT_MT9M001* codes from v4l2-chip-ident.h */
|
||||
int model; /* V4L2_IDENT_MT9V022* codes from v4l2-chip-ident.h */
|
||||
int switch_gpio;
|
||||
u16 chip_control;
|
||||
unsigned char datawidth;
|
||||
|
|
|
@ -1,8 +1,10 @@
|
|||
config VIDEO_PVRUSB2
|
||||
tristate "Hauppauge WinTV-PVR USB2 support"
|
||||
depends on VIDEO_V4L2 && I2C
|
||||
depends on VIDEO_MEDIA # Avoids pvrusb = Y / DVB = M
|
||||
depends on HOTPLUG # due to FW_LOADER
|
||||
select FW_LOADER
|
||||
select MEDIA_TUNER
|
||||
select VIDEO_TUNER
|
||||
select VIDEO_TVEEPROM
|
||||
select VIDEO_CX2341X
|
||||
select VIDEO_SAA711X
|
||||
|
|
|
@ -3,7 +3,7 @@ config VIDEO_SAA7134
|
|||
depends on VIDEO_DEV && PCI && I2C && INPUT
|
||||
select VIDEOBUF_DMA_SG
|
||||
select VIDEO_IR
|
||||
select MEDIA_TUNER
|
||||
select VIDEO_TUNER
|
||||
select VIDEO_TVEEPROM
|
||||
select CRC32
|
||||
---help---
|
||||
|
@ -27,6 +27,7 @@ config VIDEO_SAA7134_ALSA
|
|||
config VIDEO_SAA7134_DVB
|
||||
tristate "DVB/ATSC Support for saa7134 based TV cards"
|
||||
depends on VIDEO_SAA7134 && DVB_CORE
|
||||
depends on HOTPLUG # due to FW_LOADER
|
||||
select VIDEOBUF_DVB
|
||||
select FW_LOADER
|
||||
select DVB_PLL if !DVB_FE_CUSTOMISE
|
||||
|
|
|
@ -864,7 +864,6 @@ static int __devinit saa7134_initdev(struct pci_dev *pci_dev,
|
|||
struct saa7134_dev *dev;
|
||||
struct saa7134_mpeg_ops *mops;
|
||||
int err;
|
||||
int mask;
|
||||
|
||||
if (saa7134_devcount == SAA7134_MAXBOARDS)
|
||||
return -ENOMEM;
|
||||
|
@ -1065,11 +1064,6 @@ static int __devinit saa7134_initdev(struct pci_dev *pci_dev,
|
|||
if (TUNER_ABSENT != dev->tuner_type)
|
||||
saa7134_i2c_call_clients(dev, TUNER_SET_STANDBY, NULL);
|
||||
|
||||
if (card(dev).gpiomask != 0) {
|
||||
mask = card(dev).gpiomask;
|
||||
saa_andorl(SAA7134_GPIO_GPMODE0 >> 2, mask, mask);
|
||||
saa_andorl(SAA7134_GPIO_GPSTATUS0 >> 2, mask, 0);
|
||||
}
|
||||
return 0;
|
||||
|
||||
fail4:
|
||||
|
|
|
@ -538,19 +538,23 @@ static int philips_tda827x_tuner_sleep(struct dvb_frontend *fe)
|
|||
return 0;
|
||||
}
|
||||
|
||||
static void configure_tda827x_fe(struct saa7134_dev *dev, struct tda1004x_config *cdec_conf,
|
||||
struct tda827x_config *tuner_conf)
|
||||
static int configure_tda827x_fe(struct saa7134_dev *dev,
|
||||
struct tda1004x_config *cdec_conf,
|
||||
struct tda827x_config *tuner_conf)
|
||||
{
|
||||
dev->dvb.frontend = dvb_attach(tda10046_attach, cdec_conf, &dev->i2c_adap);
|
||||
if (dev->dvb.frontend) {
|
||||
if (cdec_conf->i2c_gate)
|
||||
dev->dvb.frontend->ops.i2c_gate_ctrl = tda8290_i2c_gate_ctrl;
|
||||
if (dvb_attach(tda827x_attach, dev->dvb.frontend, cdec_conf->tuner_address,
|
||||
&dev->i2c_adap, tuner_conf) == NULL) {
|
||||
wprintk("no tda827x tuner found at addr: %02x\n",
|
||||
if (dvb_attach(tda827x_attach, dev->dvb.frontend,
|
||||
cdec_conf->tuner_address,
|
||||
&dev->i2c_adap, tuner_conf))
|
||||
return 0;
|
||||
|
||||
wprintk("no tda827x tuner found at addr: %02x\n",
|
||||
cdec_conf->tuner_address);
|
||||
}
|
||||
}
|
||||
return -EINVAL;
|
||||
}
|
||||
|
||||
/* ------------------------------------------------------------------ */
|
||||
|
@ -997,7 +1001,9 @@ static int dvb_init(struct saa7134_dev *dev)
|
|||
break;
|
||||
case SAA7134_BOARD_FLYDVBTDUO:
|
||||
case SAA7134_BOARD_FLYDVBT_DUO_CARDBUS:
|
||||
configure_tda827x_fe(dev, &tda827x_lifeview_config, &tda827x_cfg_0);
|
||||
if (configure_tda827x_fe(dev, &tda827x_lifeview_config,
|
||||
&tda827x_cfg_0) < 0)
|
||||
goto dettach_frontend;
|
||||
break;
|
||||
case SAA7134_BOARD_PHILIPS_EUROPA:
|
||||
case SAA7134_BOARD_VIDEOMATE_DVBT_300:
|
||||
|
@ -1022,36 +1028,52 @@ static int dvb_init(struct saa7134_dev *dev)
|
|||
}
|
||||
break;
|
||||
case SAA7134_BOARD_KWORLD_DVBT_210:
|
||||
configure_tda827x_fe(dev, &kworld_dvb_t_210_config, &tda827x_cfg_2);
|
||||
if (configure_tda827x_fe(dev, &kworld_dvb_t_210_config,
|
||||
&tda827x_cfg_2) < 0)
|
||||
goto dettach_frontend;
|
||||
break;
|
||||
case SAA7134_BOARD_PHILIPS_TIGER:
|
||||
configure_tda827x_fe(dev, &philips_tiger_config, &tda827x_cfg_0);
|
||||
if (configure_tda827x_fe(dev, &philips_tiger_config,
|
||||
&tda827x_cfg_0) < 0)
|
||||
goto dettach_frontend;
|
||||
break;
|
||||
case SAA7134_BOARD_PINNACLE_PCTV_310i:
|
||||
configure_tda827x_fe(dev, &pinnacle_pctv_310i_config, &tda827x_cfg_1);
|
||||
if (configure_tda827x_fe(dev, &pinnacle_pctv_310i_config,
|
||||
&tda827x_cfg_1) < 0)
|
||||
goto dettach_frontend;
|
||||
break;
|
||||
case SAA7134_BOARD_HAUPPAUGE_HVR1110:
|
||||
configure_tda827x_fe(dev, &hauppauge_hvr_1110_config, &tda827x_cfg_1);
|
||||
if (configure_tda827x_fe(dev, &hauppauge_hvr_1110_config,
|
||||
&tda827x_cfg_1) < 0)
|
||||
goto dettach_frontend;
|
||||
break;
|
||||
case SAA7134_BOARD_ASUSTeK_P7131_DUAL:
|
||||
configure_tda827x_fe(dev, &asus_p7131_dual_config, &tda827x_cfg_0);
|
||||
if (configure_tda827x_fe(dev, &asus_p7131_dual_config,
|
||||
&tda827x_cfg_0) < 0)
|
||||
goto dettach_frontend;
|
||||
break;
|
||||
case SAA7134_BOARD_FLYDVBT_LR301:
|
||||
configure_tda827x_fe(dev, &tda827x_lifeview_config, &tda827x_cfg_0);
|
||||
if (configure_tda827x_fe(dev, &tda827x_lifeview_config,
|
||||
&tda827x_cfg_0) < 0)
|
||||
goto dettach_frontend;
|
||||
break;
|
||||
case SAA7134_BOARD_FLYDVB_TRIO:
|
||||
if(! use_frontend) { /* terrestrial */
|
||||
configure_tda827x_fe(dev, &lifeview_trio_config, &tda827x_cfg_0);
|
||||
if (!use_frontend) { /* terrestrial */
|
||||
if (configure_tda827x_fe(dev, &lifeview_trio_config,
|
||||
&tda827x_cfg_0) < 0)
|
||||
goto dettach_frontend;
|
||||
} else { /* satellite */
|
||||
dev->dvb.frontend = dvb_attach(tda10086_attach, &flydvbs, &dev->i2c_adap);
|
||||
if (dev->dvb.frontend) {
|
||||
if (dvb_attach(tda826x_attach, dev->dvb.frontend, 0x63,
|
||||
&dev->i2c_adap, 0) == NULL) {
|
||||
wprintk("%s: Lifeview Trio, No tda826x found!\n", __func__);
|
||||
goto dettach_frontend;
|
||||
}
|
||||
if (dvb_attach(isl6421_attach, dev->dvb.frontend, &dev->i2c_adap,
|
||||
0x08, 0, 0) == NULL) {
|
||||
wprintk("%s: Lifeview Trio, No ISL6421 found!\n", __func__);
|
||||
goto dettach_frontend;
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -1067,15 +1089,20 @@ static int dvb_init(struct saa7134_dev *dev)
|
|||
&ads_duo_cfg) == NULL) {
|
||||
wprintk("no tda827x tuner found at addr: %02x\n",
|
||||
ads_tech_duo_config.tuner_address);
|
||||
goto dettach_frontend;
|
||||
}
|
||||
}
|
||||
break;
|
||||
case SAA7134_BOARD_TEVION_DVBT_220RF:
|
||||
configure_tda827x_fe(dev, &tevion_dvbt220rf_config, &tda827x_cfg_0);
|
||||
if (configure_tda827x_fe(dev, &tevion_dvbt220rf_config,
|
||||
&tda827x_cfg_0) < 0)
|
||||
goto dettach_frontend;
|
||||
break;
|
||||
case SAA7134_BOARD_MEDION_MD8800_QUADRO:
|
||||
if (!use_frontend) { /* terrestrial */
|
||||
configure_tda827x_fe(dev, &md8800_dvbt_config, &tda827x_cfg_0);
|
||||
if (configure_tda827x_fe(dev, &md8800_dvbt_config,
|
||||
&tda827x_cfg_0) < 0)
|
||||
goto dettach_frontend;
|
||||
} else { /* satellite */
|
||||
dev->dvb.frontend = dvb_attach(tda10086_attach,
|
||||
&flydvbs, &dev->i2c_adap);
|
||||
|
@ -1086,16 +1113,20 @@ static int dvb_init(struct saa7134_dev *dev)
|
|||
struct i2c_msg msg = {.addr = 0x08, .flags = 0, .len = 1};
|
||||
|
||||
if (dvb_attach(tda826x_attach, dev->dvb.frontend,
|
||||
0x60, &dev->i2c_adap, 0) == NULL)
|
||||
0x60, &dev->i2c_adap, 0) == NULL) {
|
||||
wprintk("%s: Medion Quadro, no tda826x "
|
||||
"found !\n", __func__);
|
||||
goto dettach_frontend;
|
||||
}
|
||||
if (dev_id != 0x08) {
|
||||
/* we need to open the i2c gate (we know it exists) */
|
||||
fe->ops.i2c_gate_ctrl(fe, 1);
|
||||
if (dvb_attach(isl6405_attach, fe,
|
||||
&dev->i2c_adap, 0x08, 0, 0) == NULL)
|
||||
&dev->i2c_adap, 0x08, 0, 0) == NULL) {
|
||||
wprintk("%s: Medion Quadro, no ISL6405 "
|
||||
"found !\n", __func__);
|
||||
goto dettach_frontend;
|
||||
}
|
||||
if (dev_id == 0x07) {
|
||||
/* fire up the 2nd section of the LNB supply since
|
||||
we can't do this from the other section */
|
||||
|
@ -1117,19 +1148,17 @@ static int dvb_init(struct saa7134_dev *dev)
|
|||
case SAA7134_BOARD_AVERMEDIA_AVERTVHD_A180:
|
||||
dev->dvb.frontend = dvb_attach(nxt200x_attach, &avertvhda180,
|
||||
&dev->i2c_adap);
|
||||
if (dev->dvb.frontend) {
|
||||
if (dev->dvb.frontend)
|
||||
dvb_attach(dvb_pll_attach, dev->dvb.frontend, 0x61,
|
||||
NULL, DVB_PLL_TDHU2);
|
||||
}
|
||||
break;
|
||||
case SAA7134_BOARD_KWORLD_ATSC110:
|
||||
dev->dvb.frontend = dvb_attach(nxt200x_attach, &kworldatsc110,
|
||||
&dev->i2c_adap);
|
||||
if (dev->dvb.frontend) {
|
||||
if (dev->dvb.frontend)
|
||||
dvb_attach(simple_tuner_attach, dev->dvb.frontend,
|
||||
&dev->i2c_adap, 0x61,
|
||||
TUNER_PHILIPS_TUV1236D);
|
||||
}
|
||||
break;
|
||||
case SAA7134_BOARD_FLYDVBS_LR300:
|
||||
dev->dvb.frontend = dvb_attach(tda10086_attach, &flydvbs,
|
||||
|
@ -1138,10 +1167,12 @@ static int dvb_init(struct saa7134_dev *dev)
|
|||
if (dvb_attach(tda826x_attach, dev->dvb.frontend, 0x60,
|
||||
&dev->i2c_adap, 0) == NULL) {
|
||||
wprintk("%s: No tda826x found!\n", __func__);
|
||||
goto dettach_frontend;
|
||||
}
|
||||
if (dvb_attach(isl6421_attach, dev->dvb.frontend,
|
||||
&dev->i2c_adap, 0x08, 0, 0) == NULL) {
|
||||
wprintk("%s: No ISL6421 found!\n", __func__);
|
||||
goto dettach_frontend;
|
||||
}
|
||||
}
|
||||
break;
|
||||
|
@ -1168,43 +1199,65 @@ static int dvb_init(struct saa7134_dev *dev)
|
|||
}
|
||||
break;
|
||||
case SAA7134_BOARD_CINERGY_HT_PCMCIA:
|
||||
configure_tda827x_fe(dev, &cinergy_ht_config, &tda827x_cfg_0);
|
||||
if (configure_tda827x_fe(dev, &cinergy_ht_config,
|
||||
&tda827x_cfg_0) < 0)
|
||||
goto dettach_frontend;
|
||||
break;
|
||||
case SAA7134_BOARD_CINERGY_HT_PCI:
|
||||
configure_tda827x_fe(dev, &cinergy_ht_pci_config, &tda827x_cfg_0);
|
||||
if (configure_tda827x_fe(dev, &cinergy_ht_pci_config,
|
||||
&tda827x_cfg_0) < 0)
|
||||
goto dettach_frontend;
|
||||
break;
|
||||
case SAA7134_BOARD_PHILIPS_TIGER_S:
|
||||
configure_tda827x_fe(dev, &philips_tiger_s_config, &tda827x_cfg_2);
|
||||
if (configure_tda827x_fe(dev, &philips_tiger_s_config,
|
||||
&tda827x_cfg_2) < 0)
|
||||
goto dettach_frontend;
|
||||
break;
|
||||
case SAA7134_BOARD_ASUS_P7131_4871:
|
||||
configure_tda827x_fe(dev, &asus_p7131_4871_config, &tda827x_cfg_2);
|
||||
if (configure_tda827x_fe(dev, &asus_p7131_4871_config,
|
||||
&tda827x_cfg_2) < 0)
|
||||
goto dettach_frontend;
|
||||
break;
|
||||
case SAA7134_BOARD_ASUSTeK_P7131_HYBRID_LNA:
|
||||
configure_tda827x_fe(dev, &asus_p7131_hybrid_lna_config, &tda827x_cfg_2);
|
||||
if (configure_tda827x_fe(dev, &asus_p7131_hybrid_lna_config,
|
||||
&tda827x_cfg_2) < 0)
|
||||
goto dettach_frontend;
|
||||
break;
|
||||
case SAA7134_BOARD_AVERMEDIA_SUPER_007:
|
||||
configure_tda827x_fe(dev, &avermedia_super_007_config, &tda827x_cfg_0);
|
||||
if (configure_tda827x_fe(dev, &avermedia_super_007_config,
|
||||
&tda827x_cfg_0) < 0)
|
||||
goto dettach_frontend;
|
||||
break;
|
||||
case SAA7134_BOARD_TWINHAN_DTV_DVB_3056:
|
||||
configure_tda827x_fe(dev, &twinhan_dtv_dvb_3056_config, &tda827x_cfg_2_sw42);
|
||||
if (configure_tda827x_fe(dev, &twinhan_dtv_dvb_3056_config,
|
||||
&tda827x_cfg_2_sw42) < 0)
|
||||
goto dettach_frontend;
|
||||
break;
|
||||
case SAA7134_BOARD_PHILIPS_SNAKE:
|
||||
dev->dvb.frontend = dvb_attach(tda10086_attach, &flydvbs,
|
||||
&dev->i2c_adap);
|
||||
if (dev->dvb.frontend) {
|
||||
if (dvb_attach(tda826x_attach, dev->dvb.frontend, 0x60,
|
||||
&dev->i2c_adap, 0) == NULL)
|
||||
&dev->i2c_adap, 0) == NULL) {
|
||||
wprintk("%s: No tda826x found!\n", __func__);
|
||||
goto dettach_frontend;
|
||||
}
|
||||
if (dvb_attach(lnbp21_attach, dev->dvb.frontend,
|
||||
&dev->i2c_adap, 0, 0) == NULL)
|
||||
&dev->i2c_adap, 0, 0) == NULL) {
|
||||
wprintk("%s: No lnbp21 found!\n", __func__);
|
||||
goto dettach_frontend;
|
||||
}
|
||||
}
|
||||
break;
|
||||
case SAA7134_BOARD_CREATIX_CTX953:
|
||||
configure_tda827x_fe(dev, &md8800_dvbt_config, &tda827x_cfg_0);
|
||||
if (configure_tda827x_fe(dev, &md8800_dvbt_config,
|
||||
&tda827x_cfg_0) < 0)
|
||||
goto dettach_frontend;
|
||||
break;
|
||||
case SAA7134_BOARD_MSI_TVANYWHERE_AD11:
|
||||
configure_tda827x_fe(dev, &philips_tiger_s_config, &tda827x_cfg_2);
|
||||
if (configure_tda827x_fe(dev, &philips_tiger_s_config,
|
||||
&tda827x_cfg_2) < 0)
|
||||
goto dettach_frontend;
|
||||
break;
|
||||
case SAA7134_BOARD_AVERMEDIA_CARDBUS_506:
|
||||
dev->dvb.frontend = dvb_attach(mt352_attach,
|
||||
|
@ -1218,16 +1271,20 @@ static int dvb_init(struct saa7134_dev *dev)
|
|||
if (dev->dvb.frontend) {
|
||||
struct dvb_frontend *fe;
|
||||
if (dvb_attach(dvb_pll_attach, dev->dvb.frontend, 0x60,
|
||||
&dev->i2c_adap, DVB_PLL_PHILIPS_SD1878_TDA8261) == NULL)
|
||||
&dev->i2c_adap, DVB_PLL_PHILIPS_SD1878_TDA8261) == NULL) {
|
||||
wprintk("%s: MD7134 DVB-S, no SD1878 "
|
||||
"found !\n", __func__);
|
||||
goto dettach_frontend;
|
||||
}
|
||||
/* we need to open the i2c gate (we know it exists) */
|
||||
fe = dev->dvb.frontend;
|
||||
fe->ops.i2c_gate_ctrl(fe, 1);
|
||||
if (dvb_attach(isl6405_attach, fe,
|
||||
&dev->i2c_adap, 0x08, 0, 0) == NULL)
|
||||
&dev->i2c_adap, 0x08, 0, 0) == NULL) {
|
||||
wprintk("%s: MD7134 DVB-S, no ISL6405 "
|
||||
"found !\n", __func__);
|
||||
goto dettach_frontend;
|
||||
}
|
||||
fe->ops.i2c_gate_ctrl(fe, 0);
|
||||
dev->original_set_voltage = fe->ops.set_voltage;
|
||||
fe->ops.set_voltage = md8800_set_voltage;
|
||||
|
@ -1254,10 +1311,7 @@ static int dvb_init(struct saa7134_dev *dev)
|
|||
if (!fe) {
|
||||
printk(KERN_ERR "%s/2: xc3028 attach failed\n",
|
||||
dev->name);
|
||||
dvb_frontend_detach(dev->dvb.frontend);
|
||||
dvb_unregister_frontend(dev->dvb.frontend);
|
||||
dev->dvb.frontend = NULL;
|
||||
return -1;
|
||||
goto dettach_frontend;
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -1282,6 +1336,12 @@ static int dvb_init(struct saa7134_dev *dev)
|
|||
dev->dvb.frontend->ops.tuner_ops.sleep(dev->dvb.frontend);
|
||||
}
|
||||
return ret;
|
||||
|
||||
dettach_frontend:
|
||||
dvb_frontend_detach(dev->dvb.frontend);
|
||||
dev->dvb.frontend = NULL;
|
||||
|
||||
return -1;
|
||||
}
|
||||
|
||||
static int dvb_fini(struct saa7134_dev *dev)
|
||||
|
|
|
@ -30,6 +30,7 @@
|
|||
#include <linux/kref.h>
|
||||
|
||||
#include <linux/usb.h>
|
||||
#include <linux/mm.h>
|
||||
#include <linux/vmalloc.h>
|
||||
#include <linux/videodev2.h>
|
||||
#include <media/v4l2-common.h>
|
||||
|
@ -245,6 +246,8 @@ static int stk_initialise(struct stk_camera *dev)
|
|||
return -1;
|
||||
}
|
||||
|
||||
#ifdef CONFIG_VIDEO_V4L1_COMPAT
|
||||
|
||||
/* sysfs functions */
|
||||
/*FIXME cleanup this */
|
||||
|
||||
|
@ -350,6 +353,10 @@ static void stk_remove_sysfs_files(struct video_device *vdev)
|
|||
video_device_remove_file(vdev, &dev_attr_vflip);
|
||||
}
|
||||
|
||||
#else
|
||||
#define stk_create_sysfs_files(a)
|
||||
#define stk_remove_sysfs_files(a)
|
||||
#endif
|
||||
|
||||
/* *********************************************** */
|
||||
/*
|
||||
|
|
|
@ -40,11 +40,11 @@
|
|||
typeof(&FUNCTION) __a = symbol_request(FUNCTION); \
|
||||
if (__a) { \
|
||||
__r = (int) __a(ARGS); \
|
||||
symbol_put(FUNCTION); \
|
||||
} else { \
|
||||
printk(KERN_ERR "TUNER: Unable to find " \
|
||||
"symbol "#FUNCTION"()\n"); \
|
||||
} \
|
||||
symbol_put(FUNCTION); \
|
||||
__r; \
|
||||
})
|
||||
|
||||
|
@ -340,16 +340,6 @@ static void tuner_i2c_address_check(struct tuner *t)
|
|||
tuner_warn("====================== WARNING! ======================\n");
|
||||
}
|
||||
|
||||
static void attach_tda829x(struct tuner *t)
|
||||
{
|
||||
struct tda829x_config cfg = {
|
||||
.lna_cfg = t->config,
|
||||
.tuner_callback = t->tuner_callback,
|
||||
};
|
||||
dvb_attach(tda829x_attach,
|
||||
&t->fe, t->i2c->adapter, t->i2c->addr, &cfg);
|
||||
}
|
||||
|
||||
static struct xc5000_config xc5000_cfg;
|
||||
|
||||
static void set_type(struct i2c_client *c, unsigned int type,
|
||||
|
@ -385,12 +375,19 @@ static void set_type(struct i2c_client *c, unsigned int type,
|
|||
|
||||
switch (t->type) {
|
||||
case TUNER_MT2032:
|
||||
dvb_attach(microtune_attach,
|
||||
&t->fe, t->i2c->adapter, t->i2c->addr);
|
||||
if (!dvb_attach(microtune_attach,
|
||||
&t->fe, t->i2c->adapter, t->i2c->addr))
|
||||
goto attach_failed;
|
||||
break;
|
||||
case TUNER_PHILIPS_TDA8290:
|
||||
{
|
||||
attach_tda829x(t);
|
||||
struct tda829x_config cfg = {
|
||||
.lna_cfg = t->config,
|
||||
.tuner_callback = t->tuner_callback,
|
||||
};
|
||||
if (!dvb_attach(tda829x_attach, &t->fe, t->i2c->adapter,
|
||||
t->i2c->addr, &cfg))
|
||||
goto attach_failed;
|
||||
break;
|
||||
}
|
||||
case TUNER_TEA5767:
|
||||
|
@ -441,8 +438,9 @@ static void set_type(struct i2c_client *c, unsigned int type,
|
|||
break;
|
||||
}
|
||||
case TUNER_TDA9887:
|
||||
dvb_attach(tda9887_attach,
|
||||
&t->fe, t->i2c->adapter, t->i2c->addr);
|
||||
if (!dvb_attach(tda9887_attach,
|
||||
&t->fe, t->i2c->adapter, t->i2c->addr))
|
||||
goto attach_failed;
|
||||
break;
|
||||
case TUNER_XC5000:
|
||||
{
|
||||
|
@ -450,10 +448,10 @@ static void set_type(struct i2c_client *c, unsigned int type,
|
|||
|
||||
xc5000_cfg.i2c_address = t->i2c->addr;
|
||||
xc5000_cfg.if_khz = 5380;
|
||||
xc5000_cfg.priv = c->adapter->algo_data;
|
||||
xc5000_cfg.tuner_callback = t->tuner_callback;
|
||||
if (!dvb_attach(xc5000_attach,
|
||||
&t->fe, t->i2c->adapter, &xc5000_cfg))
|
||||
&t->fe, t->i2c->adapter, &xc5000_cfg,
|
||||
c->adapter->algo_data))
|
||||
goto attach_failed;
|
||||
|
||||
xc_tuner_ops = &t->fe.ops.tuner_ops;
|
||||
|
@ -1167,7 +1165,7 @@ static int tuner_probe(struct i2c_client *client,
|
|||
/* If chip is not tda8290, don't register.
|
||||
since it can be tda9887*/
|
||||
if (tuner_symbol_probe(tda829x_probe, t->i2c->adapter,
|
||||
t->i2c->addr) == 0) {
|
||||
t->i2c->addr) >= 0) {
|
||||
tuner_dbg("tda829x detected\n");
|
||||
} else {
|
||||
/* Default is being tda9887 */
|
||||
|
@ -1181,7 +1179,7 @@ static int tuner_probe(struct i2c_client *client,
|
|||
case 0x60:
|
||||
if (tuner_symbol_probe(tea5767_autodetection,
|
||||
t->i2c->adapter, t->i2c->addr)
|
||||
!= EINVAL) {
|
||||
>= 0) {
|
||||
t->type = TUNER_TEA5767;
|
||||
t->mode_mask = T_RADIO;
|
||||
t->mode = T_STANDBY;
|
||||
|
|
|
@ -319,10 +319,12 @@ audioIC[] =
|
|||
{AUDIO_CHIP_INTERNAL, "CX25843"},
|
||||
{AUDIO_CHIP_INTERNAL, "CX23418"},
|
||||
{AUDIO_CHIP_INTERNAL, "CX23885"},
|
||||
/* 40-42 */
|
||||
/* 40-44 */
|
||||
{AUDIO_CHIP_INTERNAL, "CX23888"},
|
||||
{AUDIO_CHIP_INTERNAL, "SAA7131"},
|
||||
{AUDIO_CHIP_INTERNAL, "CX23887"},
|
||||
{AUDIO_CHIP_INTERNAL, "SAA7164"},
|
||||
{AUDIO_CHIP_INTERNAL, "AU8522"},
|
||||
};
|
||||
|
||||
/* This list is supplied by Hauppauge. Thanks! */
|
||||
|
@ -341,8 +343,10 @@ static const char *decoderIC[] = {
|
|||
"CX882", "TVP5150A", "CX25840", "CX25841", "CX25842",
|
||||
/* 30-34 */
|
||||
"CX25843", "CX23418", "NEC61153", "CX23885", "CX23888",
|
||||
/* 35-37 */
|
||||
"SAA7131", "CX25837", "CX23887"
|
||||
/* 35-39 */
|
||||
"SAA7131", "CX25837", "CX23887", "CX23885A", "CX23887A",
|
||||
/* 40-42 */
|
||||
"SAA7164", "CX23885B", "AU8522"
|
||||
};
|
||||
|
||||
static int hasRadioTuner(int tunerType)
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
config VIDEO_USBVISION
|
||||
tristate "USB video devices based on Nogatech NT1003/1004/1005"
|
||||
depends on I2C && VIDEO_V4L2
|
||||
select MEDIA_TUNER
|
||||
select VIDEO_TUNER
|
||||
select VIDEO_SAA711X if VIDEO_HELPER_CHIPS_AUTO
|
||||
---help---
|
||||
There are more than 50 different USB video devices based on
|
||||
|
|
Loading…
Reference in a new issue