diff options
Diffstat (limited to 'fs/ocfs2/dlm/dlmmaster.c')
-rw-r--r-- | fs/ocfs2/dlm/dlmmaster.c | 36 |
1 files changed, 20 insertions, 16 deletions
diff --git a/fs/ocfs2/dlm/dlmmaster.c b/fs/ocfs2/dlm/dlmmaster.c index a65a87726d6a..b36cce034ea0 100644 --- a/fs/ocfs2/dlm/dlmmaster.c +++ b/fs/ocfs2/dlm/dlmmaster.c | |||
@@ -1507,10 +1507,11 @@ way_up_top: | |||
1507 | 1507 | ||
1508 | /* take care of the easy cases up front */ | 1508 | /* take care of the easy cases up front */ |
1509 | spin_lock(&res->spinlock); | 1509 | spin_lock(&res->spinlock); |
1510 | if (res->state & DLM_LOCK_RES_RECOVERING) { | 1510 | if (res->state & (DLM_LOCK_RES_RECOVERING| |
1511 | DLM_LOCK_RES_MIGRATING)) { | ||
1511 | spin_unlock(&res->spinlock); | 1512 | spin_unlock(&res->spinlock); |
1512 | mlog(0, "returning DLM_MASTER_RESP_ERROR since res is " | 1513 | mlog(0, "returning DLM_MASTER_RESP_ERROR since res is " |
1513 | "being recovered\n"); | 1514 | "being recovered/migrated\n"); |
1514 | response = DLM_MASTER_RESP_ERROR; | 1515 | response = DLM_MASTER_RESP_ERROR; |
1515 | if (mle) | 1516 | if (mle) |
1516 | kmem_cache_free(dlm_mle_cache, mle); | 1517 | kmem_cache_free(dlm_mle_cache, mle); |
@@ -2493,6 +2494,9 @@ fail: | |||
2493 | * the lockres | 2494 | * the lockres |
2494 | */ | 2495 | */ |
2495 | 2496 | ||
2497 | /* now that remote nodes are spinning on the MIGRATING flag, | ||
2498 | * ensure that all assert_master work is flushed. */ | ||
2499 | flush_workqueue(dlm->dlm_worker); | ||
2496 | 2500 | ||
2497 | /* get an extra reference on the mle. | 2501 | /* get an extra reference on the mle. |
2498 | * otherwise the assert_master from the new | 2502 | * otherwise the assert_master from the new |
@@ -2547,7 +2551,8 @@ fail: | |||
2547 | res->owner == target) | 2551 | res->owner == target) |
2548 | break; | 2552 | break; |
2549 | 2553 | ||
2550 | mlog(0, "timed out during migration\n"); | 2554 | mlog(0, "%s:%.*s: timed out during migration\n", |
2555 | dlm->name, res->lockname.len, res->lockname.name); | ||
2551 | /* avoid hang during shutdown when migrating lockres | 2556 | /* avoid hang during shutdown when migrating lockres |
2552 | * to a node which also goes down */ | 2557 | * to a node which also goes down */ |
2553 | if (dlm_is_node_dead(dlm, target)) { | 2558 | if (dlm_is_node_dead(dlm, target)) { |
@@ -2555,20 +2560,19 @@ fail: | |||
2555 | "target %u is no longer up, restarting\n", | 2560 | "target %u is no longer up, restarting\n", |
2556 | dlm->name, res->lockname.len, | 2561 | dlm->name, res->lockname.len, |
2557 | res->lockname.name, target); | 2562 | res->lockname.name, target); |
2558 | ret = -ERESTARTSYS; | 2563 | ret = -EINVAL; |
2564 | /* migration failed, detach and clean up mle */ | ||
2565 | dlm_mle_detach_hb_events(dlm, mle); | ||
2566 | dlm_put_mle(mle); | ||
2567 | dlm_put_mle_inuse(mle); | ||
2568 | spin_lock(&res->spinlock); | ||
2569 | res->state &= ~DLM_LOCK_RES_MIGRATING; | ||
2570 | spin_unlock(&res->spinlock); | ||
2571 | goto leave; | ||
2559 | } | 2572 | } |
2560 | } | 2573 | } else |
2561 | if (ret == -ERESTARTSYS) { | 2574 | mlog(0, "%s:%.*s: caught signal during migration\n", |
2562 | /* migration failed, detach and clean up mle */ | 2575 | dlm->name, res->lockname.len, res->lockname.name); |
2563 | dlm_mle_detach_hb_events(dlm, mle); | ||
2564 | dlm_put_mle(mle); | ||
2565 | dlm_put_mle_inuse(mle); | ||
2566 | spin_lock(&res->spinlock); | ||
2567 | res->state &= ~DLM_LOCK_RES_MIGRATING; | ||
2568 | spin_unlock(&res->spinlock); | ||
2569 | goto leave; | ||
2570 | } | ||
2571 | /* TODO: if node died: stop, clean up, return error */ | ||
2572 | } | 2576 | } |
2573 | 2577 | ||
2574 | /* all done, set the owner, clear the flag */ | 2578 | /* all done, set the owner, clear the flag */ |