V4L/DVB (6548): pvrusb2: Fix oops on module removal
The pvrusb2 driver is tearing down its sysfs related pieces in the incorrect order. This leaves dangling pointers which causes the kernel device core to oops. The problem has been present virtually forever but became malignant with the changeover to the way of handling /sys/class. Fix is just to make sure we don't tear down the class structure until AFTER the driver instances are deregistered. Signed-off-by: Mike Isely <isely@pobox.com> Signed-off-by: Mauro Carvalho Chehab <mchehab@infradead.org>
This commit is contained in:
parent
ac72fed79f
commit
4f663bdc65
|
@ -136,14 +136,13 @@ static int __init pvr_init(void)
|
||||||
|
|
||||||
static void __exit pvr_exit(void)
|
static void __exit pvr_exit(void)
|
||||||
{
|
{
|
||||||
|
|
||||||
pvr2_trace(PVR2_TRACE_INIT,"pvr_exit");
|
pvr2_trace(PVR2_TRACE_INIT,"pvr_exit");
|
||||||
|
|
||||||
|
usb_deregister(&pvr_driver);
|
||||||
|
|
||||||
#ifdef CONFIG_VIDEO_PVRUSB2_SYSFS
|
#ifdef CONFIG_VIDEO_PVRUSB2_SYSFS
|
||||||
pvr2_sysfs_class_destroy(class_ptr);
|
pvr2_sysfs_class_destroy(class_ptr);
|
||||||
#endif /* CONFIG_VIDEO_PVRUSB2_SYSFS */
|
#endif /* CONFIG_VIDEO_PVRUSB2_SYSFS */
|
||||||
|
|
||||||
usb_deregister(&pvr_driver);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
module_init(pvr_init);
|
module_init(pvr_init);
|
||||||
|
|
Loading…
Reference in New Issue