From: John Donoghue <jdonog01@eircom.net>
To: linux-dvb@linuxtv.org
Subject: Re: [linux-dvb] [PATCH] cx88-dvb: Fix order of frontend allocations (Re: current v4l-dvb - cannot access /dev/dvb/: No such file or directory)
Date: Mon, 12 Jan 2009 19:12:29 +0000 [thread overview]
Message-ID: <1231787549.5897.16.camel@john-desktop> (raw)
In-Reply-To: <1231719484.10277.4.camel@palomino.walls.org>
On Sun, 2009-01-11 at 19:18 -0500, Andy Walls wrote:
>
>
> I don't have the hardware to test with. Please try this patch.
>
> Regards,
> Andy
>
>
> Signed-off-by: Andy Walls <awalls@radix.net>
>
> diff -r a28c39659c25 linux/drivers/media/video/cx88/cx88-dvb.c
> --- a/linux/drivers/media/video/cx88/cx88-dvb.c Sat Jan 10 16:04:45 2009 -0500
> +++ b/linux/drivers/media/video/cx88/cx88-dvb.c Sun Jan 11 19:13:10 2009 -0500
> @@ -621,33 +621,40 @@ static struct stv0288_config tevii_tuner
> .set_ts_params = cx24116_set_ts_param,
> };
>
> +static int cx8802_alloc_frontends(struct cx8802_dev *dev)
> +{
> + struct cx88_core *core = dev->core;
> + struct videobuf_dvb_frontend *fe = NULL;
> + int i;
> +
> + mutex_init(&dev->frontends.lock);
> + INIT_LIST_HEAD(&dev->frontends.felist);
> +
> + if (!core->board.num_frontends)
> + return -ENODEV;
> +
> + printk(KERN_INFO "%s() allocating %d frontend(s)\n", __func__,
> + core->board.num_frontends);
> + for (i = 1; i <= core->board.num_frontends; i++) {
> + fe = videobuf_dvb_alloc_frontend(&dev->frontends, i);
> + if (!fe) {
> + printk(KERN_ERR "%s() failed to alloc\n", __func__);
> + videobuf_dvb_dealloc_frontends(&dev->frontends);
> + return -ENOMEM;
> + }
> + }
> + return 0;
> +}
> +
> static int dvb_register(struct cx8802_dev *dev)
> {
> struct cx88_core *core = dev->core;
> struct videobuf_dvb_frontend *fe0, *fe1 = NULL;
> int mfe_shared = 0; /* bus not shared by default */
> - int i;
>
> if (0 != core->i2c_rc) {
> printk(KERN_ERR "%s/2: no i2c-bus available, cannot attach dvb drivers\n", core->name);
> goto frontend_detach;
> - }
> -
> - if (!core->board.num_frontends)
> - return -EINVAL;
> -
> - mutex_init(&dev->frontends.lock);
> - INIT_LIST_HEAD(&dev->frontends.felist);
> -
> - printk(KERN_INFO "%s() allocating %d frontend(s)\n", __func__,
> - core->board.num_frontends);
> - for (i = 1; i <= core->board.num_frontends; i++) {
> - fe0 = videobuf_dvb_alloc_frontend(&dev->frontends, i);
> - if (!fe0) {
> - printk(KERN_ERR "%s() failed to alloc\n", __func__);
> - videobuf_dvb_dealloc_frontends(&dev->frontends);
> - goto frontend_detach;
> - }
> }
>
> /* Get the first frontend */
> @@ -1253,6 +1260,8 @@ static int cx8802_dvb_probe(struct cx880
> struct cx88_core *core = drv->core;
> struct cx8802_dev *dev = drv->core->dvbdev;
> int err;
> + struct videobuf_dvb_frontend *fe;
> + int i;
>
> dprintk( 1, "%s\n", __func__);
> dprintk( 1, " ->being probed by Card=%d Name=%s, PCI %02x:%02x\n",
> @@ -1268,39 +1277,34 @@ static int cx8802_dvb_probe(struct cx880
> /* If vp3054 isn't enabled, a stub will just return 0 */
> err = vp3054_i2c_probe(dev);
> if (0 != err)
> - goto fail_probe;
> + goto fail_core;
>
> /* dvb stuff */
> printk(KERN_INFO "%s/2: cx2388x based DVB/ATSC card\n", core->name);
> dev->ts_gen_cntrl = 0x0c;
>
> + err = cx8802_alloc_frontends(dev);
> + if (err)
> + goto fail_core;
> +
> err = -ENODEV;
> - if (core->board.num_frontends) {
> - struct videobuf_dvb_frontend *fe;
> - int i;
> -
> - for (i = 1; i <= core->board.num_frontends; i++) {
> - fe = videobuf_dvb_get_frontend(&core->dvbdev->frontends, i);
> - if (fe == NULL) {
> - printk(KERN_ERR "%s() failed to get frontend(%d)\n",
> + for (i = 1; i <= core->board.num_frontends; i++) {
> + fe = videobuf_dvb_get_frontend(&core->dvbdev->frontends, i);
> + if (fe == NULL) {
> + printk(KERN_ERR "%s() failed to get frontend(%d)\n",
> __func__, i);
> - goto fail_probe;
> - }
> - videobuf_queue_sg_init(&fe->dvb.dvbq, &dvb_qops,
> + goto fail_probe;
> + }
> + videobuf_queue_sg_init(&fe->dvb.dvbq, &dvb_qops,
> &dev->pci->dev, &dev->slock,
> V4L2_BUF_TYPE_VIDEO_CAPTURE,
> V4L2_FIELD_TOP,
> sizeof(struct cx88_buffer),
> dev);
> - /* init struct videobuf_dvb */
> - fe->dvb.name = dev->core->name;
> - }
> - } else {
> - /* no frontends allocated */
> - printk(KERN_ERR "%s/2 .num_frontends should be non-zero\n",
> - core->name);
> - goto fail_core;
> + /* init struct videobuf_dvb */
> + fe->dvb.name = dev->core->name;
> }
> +
> err = dvb_register(dev);
> if (err)
> /* frontends/adapter de-allocated in dvb_register */
>
>
>
>
> _______________________________________________
> linux-dvb users mailing list
> For V4L/DVB development, please use instead linux-media@vger.kernel.org
> linux-dvb@linuxtv.org
> http://www.linuxtv.org/cgi-bin/mailman/listinfo/linux-dvb
>
Andy,
Many thanks for the patch, which works for me on a Hauppauge
WinTV-Nova-S-Plus with both 2.6.27-7 and 2.6.27-9. I had been getting
the oops with 2.6.27-9 only.
Your earlier message mentioned dvb_init() being called twice and running
concurrently. I don't believe this is happening. It appears twice on
the kernel call trace, because it has called both printk and
cx8802_register_driver, and neither of these calls has yet completed.
Regards,
John
_______________________________________________
linux-dvb users mailing list
For V4L/DVB development, please use instead linux-media@vger.kernel.org
linux-dvb@linuxtv.org
http://www.linuxtv.org/cgi-bin/mailman/listinfo/linux-dvb
prev parent reply other threads:[~2009-01-12 19:13 UTC|newest]
Thread overview: 4+ messages / expand[flat|nested] mbox.gz Atom feed top
2009-01-09 12:40 [linux-dvb] current v4l-dvb - cannot access /dev/dvb/: No such file or directory Goga777
[not found] ` <1231719484.10277.4.camel@palomino.walls.org>
2009-01-12 10:40 ` [linux-dvb] [PATCH] cx88-dvb: Fix order of frontend allocations (Re: current v4l-dvb - cannot access /dev/dvb/: No such file or directory) Pierre Gronlier
2009-01-12 16:18 ` Mika Laitio
2009-01-12 19:12 ` John Donoghue [this message]
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=1231787549.5897.16.camel@john-desktop \
--to=jdonog01@eircom.net \
--cc=linux-dvb@linuxtv.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.