Lines Matching refs:dead_node
38 static void dlm_do_local_recovery_cleanup(struct dlm_ctxt *dlm, u8 dead_node);
44 static int dlm_remaster_locks(struct dlm_ctxt *dlm, u8 dead_node);
45 static int dlm_init_recovery_area(struct dlm_ctxt *dlm, u8 dead_node);
47 u8 request_from, u8 dead_node);
65 u8 dead_node, u8 send_to);
66 static int dlm_send_begin_reco_message(struct dlm_ctxt *dlm, u8 dead_node);
68 struct list_head *list, u8 dead_node);
70 u8 dead_node, u8 new_master);
101 u8 dead_node) in dlm_set_reco_dead_node() argument
104 if (dlm->reco.dead_node != dead_node) in dlm_set_reco_dead_node()
106 dlm->name, dlm->reco.dead_node, dead_node); in dlm_set_reco_dead_node()
107 dlm->reco.dead_node = dead_node; in dlm_set_reco_dead_node()
122 clear_bit(dlm->reco.dead_node, dlm->recovery_map); in __dlm_reset_recovery()
236 dlm->reco.dead_node, dlm->reco.new_master); in dlm_print_reco_node_status()
395 dlm->reco.dead_node); in dlm_wait_for_recovery()
405 dlm->name, dlm->reco.dead_node); in dlm_begin_recovery()
424 dlm->reco.dead_node, dlm->name); in dlm_print_recovery_master()
445 dlm->reco.new_master, dlm->reco.dead_node); in dlm_do_recovery()
451 if (dlm->reco.dead_node == O2NM_INVALID_NODE_NUM) { in dlm_do_recovery()
459 } else if (!test_bit(dlm->reco.dead_node, dlm->recovery_map)) { in dlm_do_recovery()
462 dlm->reco.dead_node); in dlm_do_recovery()
466 if (dlm->reco.dead_node == O2NM_INVALID_NODE_NUM) { in dlm_do_recovery()
474 dlm->reco.dead_node); in dlm_do_recovery()
511 status = dlm_remaster_locks(dlm, dlm->reco.dead_node); in dlm_do_recovery()
515 "retrying.\n", dlm->name, status, dlm->reco.dead_node); in dlm_do_recovery()
522 dlm->name, dlm->reco.dead_node, dlm->node_num); in dlm_do_recovery()
534 static int dlm_remaster_locks(struct dlm_ctxt *dlm, u8 dead_node) in dlm_remaster_locks() argument
545 status = dlm_init_recovery_area(dlm, dead_node); in dlm_remaster_locks()
569 dead_node); in dlm_remaster_locks()
608 ndata->node_num, dead_node); in dlm_remaster_locks()
616 ndata->node_num, dead_node); in dlm_remaster_locks()
621 ndata->node_num, dead_node); in dlm_remaster_locks()
626 ndata->node_num, dead_node); in dlm_remaster_locks()
657 dead_node); in dlm_remaster_locks()
701 dlm_finish_local_lockres_recovery(dlm, dead_node, in dlm_remaster_locks()
708 jiffies, dlm->reco.dead_node, in dlm_remaster_locks()
730 static int dlm_init_recovery_area(struct dlm_ctxt *dlm, u8 dead_node) in dlm_init_recovery_area() argument
746 BUG_ON(num == dead_node); in dlm_init_recovery_area()
780 u8 dead_node) in dlm_request_all_locks() argument
790 "to %u\n", dead_node, request_from); in dlm_request_all_locks()
794 lr.dead_node = dead_node; in dlm_request_all_locks()
804 request_from, dead_node); in dlm_request_all_locks()
824 if (lr->dead_node != dlm->reco.dead_node) { in dlm_request_all_locks_handler()
827 lr->dead_node, dlm->reco.dead_node); in dlm_request_all_locks_handler()
833 BUG_ON(lr->dead_node != dlm->reco.dead_node); in dlm_request_all_locks_handler()
853 item->u.ral.dead_node = lr->dead_node; in dlm_request_all_locks_handler()
870 u8 dead_node, reco_master; in dlm_request_all_locks_worker() local
874 dead_node = item->u.ral.dead_node; in dlm_request_all_locks_worker()
879 dlm->name, dead_node, reco_master); in dlm_request_all_locks_worker()
881 if (dead_node != dlm->reco.dead_node || in dlm_request_all_locks_worker()
889 reco_master, dead_node, reco_master, in dlm_request_all_locks_worker()
890 dlm->reco.dead_node, dlm->reco.new_master); in dlm_request_all_locks_worker()
894 dlm->name, dlm->reco.dead_node, in dlm_request_all_locks_worker()
895 dlm->reco.new_master, dead_node, reco_master); in dlm_request_all_locks_worker()
906 dlm_move_reco_locks_to_list(dlm, &resources, dead_node); in dlm_request_all_locks_worker()
918 reco_master, dead_node, ret); in dlm_request_all_locks_worker()
930 ret = dlm_send_all_done_msg(dlm, dead_node, reco_master); in dlm_request_all_locks_worker()
934 dlm->name, reco_master, dead_node, ret); in dlm_request_all_locks_worker()
942 static int dlm_send_all_done_msg(struct dlm_ctxt *dlm, u8 dead_node, u8 send_to) in dlm_send_all_done_msg() argument
949 done_msg.dead_node = dead_node; in dlm_send_all_done_msg()
952 done_msg.dead_node); in dlm_send_all_done_msg()
959 dead_node); in dlm_send_all_done_msg()
981 "node_idx=%u, this node=%u\n", done->dead_node, in dlm_reco_data_done_handler()
982 dlm->reco.dead_node, done->node_idx, dlm->node_num); in dlm_reco_data_done_handler()
984 mlog_bug_on_msg((done->dead_node != dlm->reco.dead_node), in dlm_reco_data_done_handler()
986 "node_idx=%u, this node=%u\n", done->dead_node, in dlm_reco_data_done_handler()
987 dlm->reco.dead_node, done->node_idx, dlm->node_num); in dlm_reco_data_done_handler()
1036 u8 dead_node) in dlm_move_reco_locks_to_list() argument
1049 if (lock->ml.node == dead_node) { in dlm_move_reco_locks_to_list()
1053 dead_node, dlm->name); in dlm_move_reco_locks_to_list()
1066 if (res->owner == dead_node) { in dlm_move_reco_locks_to_list()
1069 dead_node); in dlm_move_reco_locks_to_list()
1073 "for node %u. sending it.\n", dead_node); in dlm_move_reco_locks_to_list()
2129 u8 dead_node, u8 new_master) in dlm_finish_local_lockres_recovery() argument
2138 if (res->owner == dead_node) { in dlm_finish_local_lockres_recovery()
2173 if (res->owner != dead_node && in dlm_finish_local_lockres_recovery()
2210 struct dlm_lock_resource *res, u8 dead_node) in dlm_revalidate_lvb() argument
2224 search_node = dead_node; in dlm_revalidate_lvb()
2247 res->lockname.len, res->lockname.name, dead_node); in dlm_revalidate_lvb()
2253 struct dlm_lock_resource *res, u8 dead_node) in dlm_free_dead_locks() argument
2270 if (lock->ml.node == dead_node) { in dlm_free_dead_locks()
2279 if (lock->ml.node == dead_node) { in dlm_free_dead_locks()
2288 if (lock->ml.node == dead_node) { in dlm_free_dead_locks()
2300 res->lockname.len, res->lockname.name, freed, dead_node); in dlm_free_dead_locks()
2301 if(!test_bit(dead_node, res->refmap)) { in dlm_free_dead_locks()
2304 res->lockname.len, res->lockname.name, freed, dead_node); in dlm_free_dead_locks()
2308 dlm_lockres_clear_refmap_bit(dlm, res, dead_node); in dlm_free_dead_locks()
2309 } else if (test_bit(dead_node, res->refmap)) { in dlm_free_dead_locks()
2312 res->lockname.len, res->lockname.name, dead_node); in dlm_free_dead_locks()
2313 dlm_lockres_clear_refmap_bit(dlm, res, dead_node); in dlm_free_dead_locks()
2320 static void dlm_do_local_recovery_cleanup(struct dlm_ctxt *dlm, u8 dead_node) in dlm_do_local_recovery_cleanup() argument
2330 dlm_clean_master_list(dlm, dead_node); in dlm_do_local_recovery_cleanup()
2355 if (lock->ml.node == dead_node) { in dlm_do_local_recovery_cleanup()
2359 dead_node, dlm->name); in dlm_do_local_recovery_cleanup()
2370 if ((res->owner == dead_node) && in dlm_do_local_recovery_cleanup()
2379 dlm_lockres_clear_refmap_bit(dlm, res, dead_node); in dlm_do_local_recovery_cleanup()
2385 dlm_revalidate_lvb(dlm, res, dead_node); in dlm_do_local_recovery_cleanup()
2386 if (res->owner == dead_node) { in dlm_do_local_recovery_cleanup()
2393 res->lockname.name, dead_node); in dlm_do_local_recovery_cleanup()
2403 dlm_free_dead_locks(dlm, res, dead_node); in dlm_do_local_recovery_cleanup()
2406 if (test_bit(dead_node, res->refmap)) { in dlm_do_local_recovery_cleanup()
2410 res->lockname.name, dead_node); in dlm_do_local_recovery_cleanup()
2411 dlm_lockres_clear_refmap_bit(dlm, res, dead_node); in dlm_do_local_recovery_cleanup()
2552 dlm->name, jiffies, dlm->reco.dead_node, dlm->node_num); in dlm_pick_recovery_master()
2579 if (dlm->reco.dead_node == O2NM_INVALID_NODE_NUM) { in dlm_pick_recovery_master()
2598 dlm->reco.dead_node, dlm->node_num); in dlm_pick_recovery_master()
2600 dlm->reco.dead_node); in dlm_pick_recovery_master()
2642 dlm->name, dlm->reco.new_master, dlm->reco.dead_node); in dlm_pick_recovery_master()
2669 static int dlm_send_begin_reco_message(struct dlm_ctxt *dlm, u8 dead_node) in dlm_send_begin_reco_message() argument
2677 mlog(0, "%s: dead node is %u\n", dlm->name, dead_node); in dlm_send_begin_reco_message()
2683 clear_bit(dead_node, iter.node_map); in dlm_send_begin_reco_message()
2687 br.dead_node = dead_node; in dlm_send_begin_reco_message()
2691 if (nodenum == dead_node) { in dlm_send_begin_reco_message()
2693 "%u\n", dead_node); in dlm_send_begin_reco_message()
2725 dead_node, nodenum); in dlm_send_begin_reco_message()
2769 dlm->name, br->node_idx, br->dead_node, in dlm_begin_reco_handler()
2770 dlm->reco.dead_node, dlm->reco.new_master); in dlm_begin_reco_handler()
2778 dlm->name, br->node_idx, br->dead_node, in dlm_begin_reco_handler()
2779 dlm->reco.dead_node, dlm->reco.new_master); in dlm_begin_reco_handler()
2781 dlm_fire_domain_eviction_callbacks(dlm, br->dead_node); in dlm_begin_reco_handler()
2796 if (dlm->reco.dead_node != O2NM_INVALID_NODE_NUM) { in dlm_begin_reco_handler()
2799 dlm->reco.dead_node, br->node_idx, br->dead_node); in dlm_begin_reco_handler()
2802 dlm_set_reco_dead_node(dlm, br->dead_node); in dlm_begin_reco_handler()
2803 if (!test_bit(br->dead_node, dlm->recovery_map)) { in dlm_begin_reco_handler()
2806 br->node_idx, br->dead_node, br->dead_node); in dlm_begin_reco_handler()
2807 if (!test_bit(br->dead_node, dlm->domain_map) || in dlm_begin_reco_handler()
2808 !test_bit(br->dead_node, dlm->live_nodes_map)) in dlm_begin_reco_handler()
2811 br->dead_node); in dlm_begin_reco_handler()
2814 set_bit(br->dead_node, dlm->domain_map); in dlm_begin_reco_handler()
2815 set_bit(br->dead_node, dlm->live_nodes_map); in dlm_begin_reco_handler()
2816 __dlm_hb_node_down(dlm, br->dead_node); in dlm_begin_reco_handler()
2823 dlm->name, br->node_idx, br->dead_node, in dlm_begin_reco_handler()
2824 dlm->reco.dead_node, dlm->reco.new_master); in dlm_begin_reco_handler()
2841 "stage %d\n", dlm->name, dlm->reco.dead_node, stage); in dlm_send_finalize_reco_message()
2850 fr.dead_node = dlm->reco.dead_node; in dlm_send_finalize_reco_message()
2903 fr->dead_node, dlm->reco.dead_node, dlm->reco.new_master); in dlm_finalize_reco_handler()
2910 fr->node_idx, dlm->reco.new_master, fr->dead_node); in dlm_finalize_reco_handler()
2913 if (dlm->reco.dead_node != fr->dead_node) { in dlm_finalize_reco_handler()
2916 fr->node_idx, fr->dead_node, dlm->reco.dead_node); in dlm_finalize_reco_handler()
2922 dlm_finish_local_lockres_recovery(dlm, fr->dead_node, fr->node_idx); in dlm_finalize_reco_handler()
2927 dlm->name, fr->node_idx, fr->dead_node); in dlm_finalize_reco_handler()
2939 dlm->name, fr->node_idx, fr->dead_node); in dlm_finalize_reco_handler()
2951 dlm->name, fr->node_idx, dlm->reco.dead_node, dlm->reco.new_master); in dlm_finalize_reco_handler()