drbd: fix potential spinlock deadlock
authorLars Ellenberg <lars.ellenberg@linbit.com>
Wed, 2 Nov 2011 15:29:45 +0000 (16:29 +0100)
committerPhilipp Reisner <philipp.reisner@linbit.com>
Wed, 9 May 2012 13:15:58 +0000 (15:15 +0200)
commit763eb63625a625e4d160cbb4cce2bcdb40141b97
tree7399533f422da35884c7a67b9972b23757890256
parente89868a0927cfb8a3f535c938e5d6dd7edc6353c
drbd: fix potential spinlock deadlock

drbd_try_clear_on_disk_bm() has a sanity check for the number of blocks
left to be resynced (rs_left) in the current resync extent.
If it detects a mismatch, it complains, and forces a disconnect using
drbd_force_state(mdev, NS(conn, C_DISCONNECTING));

Unfortunately, this may be called while holding the req_lock,
and drbd_force_state() want's to aquire that lock itself. Deadlock.

Don't force a disconnect, but fix up rs_left by recounting and
reassigning the number of dirty blocks in that extent.

Signed-off-by: Philipp Reisner <philipp.reisner@linbit.com>
Signed-off-by: Lars Ellenberg <lars.ellenberg@linbit.com>
drivers/block/drbd/drbd_actlog.c