aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/staging/tm6000/tm6000-dvb.c
diff options
context:
space:
mode:
authorMichel Ludwig <michel.ludwig@gmail.com>2007-11-16 13:16:59 -0300
committerMauro Carvalho Chehab <mchehab@redhat.com>2010-05-18 00:39:59 -0300
commit5b74c2c739064248bb9c78102e94751b317684d5 (patch)
tree99ecfa46989a06cb4dfbcca93df5756c3ad66c26 /drivers/staging/tm6000/tm6000-dvb.c
parentV4L/DVB (12815): tm6000: follow videobuf API changes (diff)
downloadlinux-dev-5b74c2c739064248bb9c78102e94751b317684d5.tar.xz
linux-dev-5b74c2c739064248bb9c78102e94751b317684d5.zip
V4L/DVB (12816): tm6000: fix tm6000 attach method and fix a few CodingStyles
Signed-off-by: Michel Ludwig <michel.ludwig@gmail.com> Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
Diffstat (limited to 'drivers/staging/tm6000/tm6000-dvb.c')
-rw-r--r--drivers/staging/tm6000/tm6000-dvb.c34
1 files changed, 24 insertions, 10 deletions
diff --git a/drivers/staging/tm6000/tm6000-dvb.c b/drivers/staging/tm6000/tm6000-dvb.c
index 9df93cfe3106..15133109f7ec 100644
--- a/drivers/staging/tm6000/tm6000-dvb.c
+++ b/drivers/staging/tm6000/tm6000-dvb.c
@@ -28,6 +28,8 @@
#include <media/tuner.h>
+#include "tuner-xc2028.h"
+
static void tm6000_urb_received(struct urb *urb)
{
int ret;
@@ -231,20 +233,29 @@ int tm6000_dvb_register(struct tm6000_core *dev)
THIS_MODULE, &dev->udev->dev);
dvb->adapter.priv = dev;
- if(dvb->frontend) {
+ if (dvb->frontend) {
+ struct xc2028_config cfg = {
+ .i2c_adap = &dev->i2c_adap,
+ .video_dev = dev,
+ };
+
ret = dvb_register_frontend(&dvb->adapter, dvb->frontend);
- if(ret < 0) {
- printk("tm6000: couldn't register frontend\n");
+ if (ret < 0) {
+ printk(KERN_ERR
+ "tm6000: couldn't register frontend\n");
goto adapter_err;
}
- // attach the tuner like this for now
- tm6000_i2c_call_clients(dev, VIDIOC_INT_DVB_TUNER_ATTACH, dvb->frontend);
-
- printk("tm6000: XC2028/3028 asked to be attached to frontend!\n");
- }
- else {
- printk("tm6000: no frontend found\n");
+ if (!dvb_attach(xc2028_attach, dvb->frontend, &cfg)) {
+ printk(KERN_ERR "tm6000: couldn't register "
+ "frontend (xc3028)\n");
+ ret = -EINVAL;
+ goto adapter_err;
+ }
+ printk(KERN_INFO "tm6000: XC2028/3028 asked to be "
+ "attached to frontend!\n");
+ } else {
+ printk(KERN_ERR "tm6000: no frontend found\n");
}
dvb->demux.dmx.capabilities = DMX_TS_FILTERING | DMX_SECTION_FILTERING
@@ -278,6 +289,9 @@ dvb_dmx_err:
frontend_err:
if(dvb->frontend) {
dvb_unregister_frontend(dvb->frontend);
+#ifdef CONFIG_DVB_CORE_ATTACH
+ symbol_put(xc3028_attach);
+#endif
}
adapter_err:
dvb_unregister_adapter(&dvb->adapter);