summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMarton Balint <cus@fazekas.hu>2008-03-26 06:07:35 +0100
committerMauro Carvalho Chehab <mchehab@infradead.org>2008-04-24 19:07:55 +0200
commitb12203d253732d282dd97909a1424016694183e9 (patch)
treec898f7f2582b7b2be9a216392e544e4f055d4964
parentV4L/DVB (7448): Add support for Kworld ATSC 120 (diff)
downloadlinux-b12203d253732d282dd97909a1424016694183e9.tar.xz
linux-b12203d253732d282dd97909a1424016694183e9.zip
V4L/DVB (7449): cx88: fix oops on module removal caused by IR worker
If the IR worker is not stopped before the removal of the cx88xx module, an OOPS may occur, because the worker function cx88_ir_work gets called. So stop the ir worker. Signed-off-by: Marton Balint <cus@fazekas.hu> Signed-off-by: Mauro Carvalho Chehab <mchehab@infradead.org>
-rw-r--r--drivers/media/video/cx88/cx88-video.c3
1 files changed, 3 insertions, 0 deletions
diff --git a/drivers/media/video/cx88/cx88-video.c b/drivers/media/video/cx88/cx88-video.c
index 327c0a87c081..1eea044969a1 100644
--- a/drivers/media/video/cx88/cx88-video.c
+++ b/drivers/media/video/cx88/cx88-video.c
@@ -1920,6 +1920,9 @@ static void __devexit cx8800_finidev(struct pci_dev *pci_dev)
core->kthread = NULL;
}
+ if (core->ir)
+ cx88_ir_stop(core, core->ir);
+
cx88_shutdown(core); /* FIXME */
pci_disable_device(pci_dev);