diff options
-rw-r--r-- | fs/ocfs2/dlm/dlmcommon.h | 4 | ||||
-rw-r--r-- | fs/ocfs2/dlm/dlmdomain.c | 11 | ||||
-rw-r--r-- | fs/ocfs2/dlm/dlmmaster.c | 11 |
3 files changed, 26 insertions, 0 deletions
diff --git a/fs/ocfs2/dlm/dlmcommon.h b/fs/ocfs2/dlm/dlmcommon.h index 7525a8ae3943..cc31abeadb8e 100644 --- a/fs/ocfs2/dlm/dlmcommon.h +++ b/fs/ocfs2/dlm/dlmcommon.h | |||
@@ -101,6 +101,7 @@ struct dlm_ctxt | |||
101 | struct list_head purge_list; | 101 | struct list_head purge_list; |
102 | struct list_head pending_asts; | 102 | struct list_head pending_asts; |
103 | struct list_head pending_basts; | 103 | struct list_head pending_basts; |
104 | struct list_head tracking_list; | ||
104 | unsigned int purge_count; | 105 | unsigned int purge_count; |
105 | spinlock_t spinlock; | 106 | spinlock_t spinlock; |
106 | spinlock_t ast_lock; | 107 | spinlock_t ast_lock; |
@@ -270,6 +271,9 @@ struct dlm_lock_resource | |||
270 | struct list_head dirty; | 271 | struct list_head dirty; |
271 | struct list_head recovering; // dlm_recovery_ctxt.resources list | 272 | struct list_head recovering; // dlm_recovery_ctxt.resources list |
272 | 273 | ||
274 | /* Added during init and removed during release */ | ||
275 | struct list_head tracking; /* dlm->tracking_list */ | ||
276 | |||
273 | /* unused lock resources have their last_used stamped and are | 277 | /* unused lock resources have their last_used stamped and are |
274 | * put on a list for the dlm thread to run. */ | 278 | * put on a list for the dlm thread to run. */ |
275 | unsigned long last_used; | 279 | unsigned long last_used; |
diff --git a/fs/ocfs2/dlm/dlmdomain.c b/fs/ocfs2/dlm/dlmdomain.c index b092364d0d52..4f7695c851ed 100644 --- a/fs/ocfs2/dlm/dlmdomain.c +++ b/fs/ocfs2/dlm/dlmdomain.c | |||
@@ -644,6 +644,7 @@ int dlm_shutting_down(struct dlm_ctxt *dlm) | |||
644 | void dlm_unregister_domain(struct dlm_ctxt *dlm) | 644 | void dlm_unregister_domain(struct dlm_ctxt *dlm) |
645 | { | 645 | { |
646 | int leave = 0; | 646 | int leave = 0; |
647 | struct dlm_lock_resource *res; | ||
647 | 648 | ||
648 | spin_lock(&dlm_domain_lock); | 649 | spin_lock(&dlm_domain_lock); |
649 | BUG_ON(dlm->dlm_state != DLM_CTXT_JOINED); | 650 | BUG_ON(dlm->dlm_state != DLM_CTXT_JOINED); |
@@ -673,6 +674,15 @@ void dlm_unregister_domain(struct dlm_ctxt *dlm) | |||
673 | msleep(500); | 674 | msleep(500); |
674 | mlog(0, "%s: more migration to do\n", dlm->name); | 675 | mlog(0, "%s: more migration to do\n", dlm->name); |
675 | } | 676 | } |
677 | |||
678 | /* This list should be empty. If not, print remaining lockres */ | ||
679 | if (!list_empty(&dlm->tracking_list)) { | ||
680 | mlog(ML_ERROR, "Following lockres' are still on the " | ||
681 | "tracking list:\n"); | ||
682 | list_for_each_entry(res, &dlm->tracking_list, tracking) | ||
683 | dlm_print_one_lock_resource(res); | ||
684 | } | ||
685 | |||
676 | dlm_mark_domain_leaving(dlm); | 686 | dlm_mark_domain_leaving(dlm); |
677 | dlm_leave_domain(dlm); | 687 | dlm_leave_domain(dlm); |
678 | dlm_complete_dlm_shutdown(dlm); | 688 | dlm_complete_dlm_shutdown(dlm); |
@@ -1526,6 +1536,7 @@ static struct dlm_ctxt *dlm_alloc_ctxt(const char *domain, | |||
1526 | INIT_LIST_HEAD(&dlm->reco.node_data); | 1536 | INIT_LIST_HEAD(&dlm->reco.node_data); |
1527 | INIT_LIST_HEAD(&dlm->purge_list); | 1537 | INIT_LIST_HEAD(&dlm->purge_list); |
1528 | INIT_LIST_HEAD(&dlm->dlm_domain_handlers); | 1538 | INIT_LIST_HEAD(&dlm->dlm_domain_handlers); |
1539 | INIT_LIST_HEAD(&dlm->tracking_list); | ||
1529 | dlm->reco.state = 0; | 1540 | dlm->reco.state = 0; |
1530 | 1541 | ||
1531 | INIT_LIST_HEAD(&dlm->pending_asts); | 1542 | INIT_LIST_HEAD(&dlm->pending_asts); |
diff --git a/fs/ocfs2/dlm/dlmmaster.c b/fs/ocfs2/dlm/dlmmaster.c index ac9ed31e5445..97133465891c 100644 --- a/fs/ocfs2/dlm/dlmmaster.c +++ b/fs/ocfs2/dlm/dlmmaster.c | |||
@@ -639,6 +639,14 @@ static void dlm_lockres_release(struct kref *kref) | |||
639 | mlog(0, "destroying lockres %.*s\n", res->lockname.len, | 639 | mlog(0, "destroying lockres %.*s\n", res->lockname.len, |
640 | res->lockname.name); | 640 | res->lockname.name); |
641 | 641 | ||
642 | if (!list_empty(&res->tracking)) | ||
643 | list_del_init(&res->tracking); | ||
644 | else { | ||
645 | mlog(ML_ERROR, "Resource %.*s not on the Tracking list\n", | ||
646 | res->lockname.len, res->lockname.name); | ||
647 | dlm_print_one_lock_resource(res); | ||
648 | } | ||
649 | |||
642 | if (!hlist_unhashed(&res->hash_node) || | 650 | if (!hlist_unhashed(&res->hash_node) || |
643 | !list_empty(&res->granted) || | 651 | !list_empty(&res->granted) || |
644 | !list_empty(&res->converting) || | 652 | !list_empty(&res->converting) || |
@@ -706,6 +714,7 @@ static void dlm_init_lockres(struct dlm_ctxt *dlm, | |||
706 | INIT_LIST_HEAD(&res->dirty); | 714 | INIT_LIST_HEAD(&res->dirty); |
707 | INIT_LIST_HEAD(&res->recovering); | 715 | INIT_LIST_HEAD(&res->recovering); |
708 | INIT_LIST_HEAD(&res->purge); | 716 | INIT_LIST_HEAD(&res->purge); |
717 | INIT_LIST_HEAD(&res->tracking); | ||
709 | atomic_set(&res->asts_reserved, 0); | 718 | atomic_set(&res->asts_reserved, 0); |
710 | res->migration_pending = 0; | 719 | res->migration_pending = 0; |
711 | res->inflight_locks = 0; | 720 | res->inflight_locks = 0; |
@@ -721,6 +730,8 @@ static void dlm_init_lockres(struct dlm_ctxt *dlm, | |||
721 | 730 | ||
722 | res->last_used = 0; | 731 | res->last_used = 0; |
723 | 732 | ||
733 | list_add_tail(&res->tracking, &dlm->tracking_list); | ||
734 | |||
724 | memset(res->lvb, 0, DLM_LVB_LEN); | 735 | memset(res->lvb, 0, DLM_LVB_LEN); |
725 | memset(res->refmap, 0, sizeof(res->refmap)); | 736 | memset(res->refmap, 0, sizeof(res->refmap)); |
726 | } | 737 | } |