dlm: fix lvb invalidation conditions
authorDavid Teigland <teigland@redhat.com>
Thu, 15 Nov 2012 21:01:51 +0000 (15:01 -0600)
committerDavid Teigland <teigland@redhat.com>
Fri, 16 Nov 2012 17:20:42 +0000 (11:20 -0600)
commitda8c66638ae684c99abcb30e89d2803402e7ca20
treee14974b7eb69db1d1c595892c94298a3f547ae23
parenta3de56bdb980c63b01662cac05d430db60ff4374
dlm: fix lvb invalidation conditions

When a node is removed that held a PW/EX lock, the
existing master node should invalidate the lvb on the
resource due to the purged lock.

Previously, the existing master node was invalidating
the lvb if it found only NL/CR locks on the resource
during recovery for the removed node.  This could lead
to cases where it invalidated the lvb and shouldn't
have, or cases where it should have invalidated and
didn't.

When recovery selects a *new* master node for a
resource, and that new master finds only NL/CR locks
on the resource after lock recovery, it should
invalidate the lvb.  This case was handled correctly
(but was incorrectly applied to the existing master
case also.)

When a process exits while holding a PW/EX lock,
the lvb on the resource should be invalidated.
This was not happening.

The lvb contents and VALNOTVALID flag should be
recovered before granting locks in recovery so that
the recovered lvb state is provided in the callback.
The lvb was being recovered after the lock was granted.

Signed-off-by: David Teigland <teigland@redhat.com>
fs/dlm/dlm_internal.h
fs/dlm/lock.c
fs/dlm/recover.c