aboutsummaryrefslogtreecommitdiffstats
path: root/fs/ocfs2/dlm/dlmrecovery.c
diff options
context:
space:
mode:
authorKurt Hackel <kurt.hackel@oracle.com>2006-05-01 16:54:07 -0400
committerMark Fasheh <mark.fasheh@oracle.com>2006-06-26 17:43:12 -0400
commitb7084ab538ac2bd71ce494cf1cbbea9fe9db2c07 (patch)
treeb1d19839e9e7795fb1d86270c90008058e8860f7 /fs/ocfs2/dlm/dlmrecovery.c
parentc27069e6cfa242a3b84eb3442934c6fe51ee9066 (diff)
ocfs2: wait for recovery when starting lock mastery
Signed-off-by: Kurt Hackel <kurt.hackel@oracle.com> Signed-off-by: Mark Fasheh <mark.fasheh@oracle.com>
Diffstat (limited to 'fs/ocfs2/dlm/dlmrecovery.c')
-rw-r--r--fs/ocfs2/dlm/dlmrecovery.c30
1 files changed, 30 insertions, 0 deletions
diff --git a/fs/ocfs2/dlm/dlmrecovery.c b/fs/ocfs2/dlm/dlmrecovery.c
index c699a450b0f2..b03fecab299d 100644
--- a/fs/ocfs2/dlm/dlmrecovery.c
+++ b/fs/ocfs2/dlm/dlmrecovery.c
@@ -343,6 +343,18 @@ int dlm_is_node_dead(struct dlm_ctxt *dlm, u8 node)
343 return dead; 343 return dead;
344} 344}
345 345
346/* returns true if node is no longer in the domain
347 * could be dead or just not joined */
348int dlm_is_node_recovered(struct dlm_ctxt *dlm, u8 node)
349{
350 int recovered;
351 spin_lock(&dlm->spinlock);
352 recovered = !test_bit(node, dlm->recovery_map);
353 spin_unlock(&dlm->spinlock);
354 return recovered;
355}
356
357
346int dlm_wait_for_node_death(struct dlm_ctxt *dlm, u8 node, int timeout) 358int dlm_wait_for_node_death(struct dlm_ctxt *dlm, u8 node, int timeout)
347{ 359{
348 if (timeout) { 360 if (timeout) {
@@ -361,6 +373,24 @@ int dlm_wait_for_node_death(struct dlm_ctxt *dlm, u8 node, int timeout)
361 return 0; 373 return 0;
362} 374}
363 375
376int dlm_wait_for_node_recovery(struct dlm_ctxt *dlm, u8 node, int timeout)
377{
378 if (timeout) {
379 mlog(0, "%s: waiting %dms for notification of "
380 "recovery of node %u\n", dlm->name, timeout, node);
381 wait_event_timeout(dlm->dlm_reco_thread_wq,
382 dlm_is_node_recovered(dlm, node),
383 msecs_to_jiffies(timeout));
384 } else {
385 mlog(0, "%s: waiting indefinitely for notification "
386 "of recovery of node %u\n", dlm->name, node);
387 wait_event(dlm->dlm_reco_thread_wq,
388 dlm_is_node_recovered(dlm, node));
389 }
390 /* for now, return 0 */
391 return 0;
392}
393
364/* callers of the top-level api calls (dlmlock/dlmunlock) should 394/* callers of the top-level api calls (dlmlock/dlmunlock) should
365 * block on the dlm->reco.event when recovery is in progress. 395 * block on the dlm->reco.event when recovery is in progress.
366 * the dlm recovery thread will set this state when it begins 396 * the dlm recovery thread will set this state when it begins