V4L/DVB (9224): MFE: bugfix: add missing frontend allocation
authorDarron Broad <darron@kewl.org>
Sat, 11 Oct 2008 14:24:30 +0000 (11:24 -0300)
committerMauro Carvalho Chehab <mchehab@redhat.com>
Fri, 17 Oct 2008 20:23:21 +0000 (17:23 -0300)
When using MFE on a setup with both and HVR-3000 and ASUS P7131
card it was noticed that frontend allocation for saa7134
adapters was missing. This patch adds that allocation for
both saa7134 and cx23885 adapters.

Signed-off-by: Darron Broad <darron@kewl.org>
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
drivers/media/video/cx23885/cx23885-dvb.c
drivers/media/video/saa7134/saa7134-dvb.c

index d8c25a8025618f10de269b92b33bfc881089afd2..c14878f74bcc33be88295c5cbee58ac8b694d5e3 100644 (file)
@@ -314,6 +314,19 @@ static int dvb_register(struct cx23885_tsport *port)
        struct cx23885_i2c *i2c_bus = NULL;
        struct videobuf_dvb_frontend *fe0;
 
+       /* FIXME: add support for multi-frontend */
+       mutex_init(&port->frontends.lock);
+       INIT_LIST_HEAD(&port->frontends.frontend.felist);
+       port->frontends.active_fe_id = 0;
+
+       printk(KERN_INFO "%s() allocating 1 frontend\n", __func__);
+
+       if (videobuf_dvb_alloc_frontend(dev, &port->frontends, 1) == NULL) {
+               printk(KERN_ERR "%s() failed to alloc\n", __func__);
+               return -ENOMEM;
+       }
+
+       /* Get the first frontend */
        fe0 = videobuf_dvb_get_frontend(&port->frontends, 1);
        if (!fe0)
                return -EINVAL;
index cdb5f5dfe4d9619640f7e5d887be06862c01cefd..30ae0cbe78a005f8194f977375471747eff240d7 100644 (file)
@@ -951,6 +951,18 @@ static int dvb_init(struct saa7134_dev *dev)
        int attach_xc3028 = 0;
        struct videobuf_dvb_frontend *fe0;
 
+       /* FIXME: add support for multi-frontend */
+       mutex_init(&dev->frontends.lock);
+       INIT_LIST_HEAD(&dev->frontends.frontend.felist);
+       dev->frontends.active_fe_id = 0;
+
+       printk(KERN_INFO "%s() allocating 1 frontend\n", __func__);
+
+       if (videobuf_dvb_alloc_frontend(dev, &dev->frontends, 1) == NULL) {
+               printk(KERN_ERR "%s() failed to alloc\n", __func__);
+               return -ENOMEM;
+       }
+
        /* Get the first frontend */
        fe0 = videobuf_dvb_get_frontend(&dev->frontends, 1);
        if (!fe0)