drbd: skip spurious wait_event in drbd_al_begin_io
authorLars Ellenberg <lars.ellenberg@linbit.com>
Tue, 3 May 2011 14:49:20 +0000 (16:49 +0200)
committerPhilipp Reisner <philipp.reisner@linbit.com>
Thu, 8 Nov 2012 15:55:49 +0000 (16:55 +0100)
commit7dc1d67f7c324e5bf23883b94508112ca7a70f62
tree624819e978b5bef8ef1c70ba90a3d4ca04f356e9
parent6139f60dc192e2c5478c1126d1aff7905dc0a98a
drbd: skip spurious wait_event in drbd_al_begin_io

Activity log transaction writes are serialized on a bit lock.
If several CPUs race to write an AL transaction,
those that did not get the lock the first time
may continue as soon as there are no more pending transactions.

The do not need to all grab the lock in turn,
just to realize that the AL is clean already,
and they have nothing to do.

This also closes a potential deadlock with drbd_adm_disk_opts.
Once it got the AL bit lock, it knows there are no pending transactions,
the AL is clean, and it should be safe to wait for all element references
to drop to zero.

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