cx88: fix locking of sub-driver operations
authorJonathan Nieder <jrnieder@gmail.com>
Sun, 1 May 2011 09:29:37 +0000 (06:29 -0300)
committerSteve Conklin <sconklin@canonical.com>
Fri, 15 Jul 2011 17:21:08 +0000 (12:21 -0500)
commit4533f6347a2f9a11c3bfbbde54dd25100d6aee14
tree01a0e225f4d7df348c69ffd44ce5e1fb519c0fd0
parentebb57a777f1d55a28f2578dd51c2d4e81510fa74
cx88: fix locking of sub-driver operations

BugLink: http://bugs.launchpad.net/bugs/793702

commit 1fe70e963028f34ba5e32488a7870ff4b410b19b upstream.

The BKL conversion of this driver seems to have gone wrong.
Loading the cx88-blackbird driver deadlocks.

The cause: mpeg_ops::open in the cx2388x blackbird driver acquires the
device lock and calls the sub-driver's request_acquire, which tries to
acquire the lock again.  Fix it by clarifying the semantics of
request_acquire, request_release, advise_acquire, and advise_release:
now all will rely on the caller to acquire the device lock.

Based on work by Ben Hutchings <ben@decadent.org.uk>.

Fixes: https://bugzilla.kernel.org/show_bug.cgi?id=31962

Reported-by: Andi Huber <hobrom@gmx.at>
Tested-by: Andi Huber <hobrom@gmx.at>
Tested-by: Marlon de Boer <marlon@hyves.nl>
Signed-off-by: Jonathan Nieder <jrnieder@gmail.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@suse.de>
Signed-off-by: Tim Gardner <tim.gardner@canonical.com>
drivers/media/video/cx88/cx88-blackbird.c
drivers/media/video/cx88/cx88-dvb.c
drivers/media/video/cx88/cx88-mpeg.c
drivers/media/video/cx88/cx88.h