* [PATCH] [media] vp7045: fix buffer setup [not found] <20110809200842.GA29662@mac.home> @ 2011-08-10 10:05 ` Florian Mickler 2011-08-19 16:35 ` Florian Mickler 0 siblings, 1 reply; 3+ messages in thread From: Florian Mickler @ 2011-08-10 10:05 UTC (permalink / raw) To: mchehab; +Cc: tino.keitel, linux-media, linux-kernel, Florian Mickler, v3.0.y dvb_usb_device_init calls the frontend_attach method of this driver which uses vp7045_usb_ob. In order to have a buffer ready in vp7045_usb_op, it has to be allocated before that happens. Luckily we can use the whole private data as the buffer as it gets separately allocated on the heap via kzalloc in dvb_usb_device_init and is thus apt for use via usb_control_msg. This fixes a BUG: unable to handle kernel paging request at 0000000000001e78 reported by Tino Keitel and diagnosed by Dan Carpenter. References: https://bugzilla.kernel.org/show_bug.cgi?id=40062 Cc: v3.0.y <stable@kernel.org> Tested-by: Tino Keitel <tino.keitel@tikei.de> Signed-off-by: Florian Mickler <florian@mickler.org> --- drivers/media/dvb/dvb-usb/vp7045.c | 26 ++++---------------------- 1 files changed, 4 insertions(+), 22 deletions(-) diff --git a/drivers/media/dvb/dvb-usb/vp7045.c b/drivers/media/dvb/dvb-usb/vp7045.c index 3db89e3..536c16c 100644 --- a/drivers/media/dvb/dvb-usb/vp7045.c +++ b/drivers/media/dvb/dvb-usb/vp7045.c @@ -224,26 +224,8 @@ static struct dvb_usb_device_properties vp7045_properties; static int vp7045_usb_probe(struct usb_interface *intf, const struct usb_device_id *id) { - struct dvb_usb_device *d; - int ret = dvb_usb_device_init(intf, &vp7045_properties, - THIS_MODULE, &d, adapter_nr); - if (ret) - return ret; - - d->priv = kmalloc(20, GFP_KERNEL); - if (!d->priv) { - dvb_usb_device_exit(intf); - return -ENOMEM; - } - - return ret; -} - -static void vp7045_usb_disconnect(struct usb_interface *intf) -{ - struct dvb_usb_device *d = usb_get_intfdata(intf); - kfree(d->priv); - dvb_usb_device_exit(intf); + return dvb_usb_device_init(intf, &vp7045_properties, + THIS_MODULE, NULL, adapter_nr); } static struct usb_device_id vp7045_usb_table [] = { @@ -258,7 +240,7 @@ MODULE_DEVICE_TABLE(usb, vp7045_usb_table); static struct dvb_usb_device_properties vp7045_properties = { .usb_ctrl = CYPRESS_FX2, .firmware = "dvb-usb-vp7045-01.fw", - .size_of_priv = sizeof(u8 *), + .size_of_priv = 20, .num_adapters = 1, .adapter = { @@ -305,7 +287,7 @@ static struct dvb_usb_device_properties vp7045_properties = { static struct usb_driver vp7045_usb_driver = { .name = "dvb_usb_vp7045", .probe = vp7045_usb_probe, - .disconnect = vp7045_usb_disconnect, + .disconnect = dvb_usb_device_exit, .id_table = vp7045_usb_table, }; -- 1.7.6 ^ permalink raw reply related [flat|nested] 3+ messages in thread
* Re: [PATCH] [media] vp7045: fix buffer setup 2011-08-10 10:05 ` [PATCH] [media] vp7045: fix buffer setup Florian Mickler @ 2011-08-19 16:35 ` Florian Mickler 2011-08-24 16:26 ` Tino Keitel 0 siblings, 1 reply; 3+ messages in thread From: Florian Mickler @ 2011-08-19 16:35 UTC (permalink / raw) To: mchehab; +Cc: Florian Mickler, tino.keitel, linux-media, linux-kernel, v3.0.y On Wed, 10 Aug 2011 12:05:20 +0200 Florian Mickler <florian@mickler.org> wrote: > dvb_usb_device_init calls the frontend_attach method of this driver which > uses vp7045_usb_ob. In order to have a buffer ready in vp7045_usb_op, it has to > be allocated before that happens. > > Luckily we can use the whole private data as the buffer as it gets separately > allocated on the heap via kzalloc in dvb_usb_device_init and is thus apt for > use via usb_control_msg. > > This fixes a > BUG: unable to handle kernel paging request at 0000000000001e78 > > reported by Tino Keitel and diagnosed by Dan Carpenter. > > References: https://bugzilla.kernel.org/show_bug.cgi?id=40062 > Cc: v3.0.y <stable@kernel.org> > Tested-by: Tino Keitel <tino.keitel@tikei.de> > Signed-off-by: Florian Mickler <florian@mickler.org> ...ping... ^ permalink raw reply [flat|nested] 3+ messages in thread
* Re: [PATCH] [media] vp7045: fix buffer setup 2011-08-19 16:35 ` Florian Mickler @ 2011-08-24 16:26 ` Tino Keitel 0 siblings, 0 replies; 3+ messages in thread From: Tino Keitel @ 2011-08-24 16:26 UTC (permalink / raw) To: Florian Mickler; +Cc: mchehab, linux-media, linux-kernel, v3.0.y On Fri, Aug 19, 2011 at 18:35:21 +0200, Florian Mickler wrote: > On Wed, 10 Aug 2011 12:05:20 +0200 > Florian Mickler <florian@mickler.org> wrote: > > > dvb_usb_device_init calls the frontend_attach method of this driver which > > uses vp7045_usb_ob. In order to have a buffer ready in vp7045_usb_op, it has to > > be allocated before that happens. > > > > Luckily we can use the whole private data as the buffer as it gets separately > > allocated on the heap via kzalloc in dvb_usb_device_init and is thus apt for > > use via usb_control_msg. > > > > This fixes a > > BUG: unable to handle kernel paging request at 0000000000001e78 > > > > reported by Tino Keitel and diagnosed by Dan Carpenter. > > > > References: https://bugzilla.kernel.org/show_bug.cgi?id=40062 > > Cc: v3.0.y <stable@kernel.org> > > Tested-by: Tino Keitel <tino.keitel@tikei.de> > > Signed-off-by: Florian Mickler <florian@mickler.org> > > ...ping... Even pinger. I can't see the patch in 3.1 git yet, and I'm using the patch on 3.0 kernels for 2 weeks now without problems. Regards, Tino ^ permalink raw reply [flat|nested] 3+ messages in thread
end of thread, other threads:[~2011-08-24 16:33 UTC | newest]
Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
[not found] <20110809200842.GA29662@mac.home>
2011-08-10 10:05 ` [PATCH] [media] vp7045: fix buffer setup Florian Mickler
2011-08-19 16:35 ` Florian Mickler
2011-08-24 16:26 ` Tino Keitel
This is a public inbox, see mirroring instructions for how to clone and mirror all data and code used for this inbox