osaf/services/saf/amf/amfd/include/sg.h      |   1 +
 osaf/services/saf/amf/amfd/sg_nwayact_fsm.cc |  43 ++++++++++++++++++++++++++++
 2 files changed, 44 insertions(+), 0 deletions(-)


Handles modification of assignments in SU of NWay_Active SG
because of lock or shutdown operation on Node group.
If SU does not have any SIs assigned to it, AMF will try
to instantiate new SUs in the SG. If SU has assignments,
then depending upon lock or shutdown operation, quiesced
or quiescing state will be sent for the SU.

diff --git a/osaf/services/saf/amf/amfd/include/sg.h 
b/osaf/services/saf/amf/amfd/include/sg.h
--- a/osaf/services/saf/amf/amfd/include/sg.h
+++ b/osaf/services/saf/amf/amfd/include/sg.h
@@ -506,6 +506,7 @@ public:
                struct avd_su_si_rel_tag *susi, AVSV_SUSI_ACT act, 
SaAmfHAStateT state);
        uint32_t susi_failed(AVD_CL_CB *cb, AVD_SU *su,
                struct avd_su_si_rel_tag *susi, AVSV_SUSI_ACT act, 
SaAmfHAStateT state);
+       void ng_admin(AVD_SU *su, AVD_AMF_NG *ng);
 };
 
 /**
diff --git a/osaf/services/saf/amf/amfd/sg_nwayact_fsm.cc 
b/osaf/services/saf/amf/amfd/sg_nwayact_fsm.cc
--- a/osaf/services/saf/amf/amfd/sg_nwayact_fsm.cc
+++ b/osaf/services/saf/amf/amfd/sg_nwayact_fsm.cc
@@ -1938,6 +1938,49 @@ done:
 
        return;
 }
+/*
+ * @brief      Handles modification of assignments in SU of NWay_Active SG
+ *             because of lock or shutdown operation on Node group.
+ *             If SU does not have any SIs assigned to it, AMF will try
+ *             to instantiate new SUs in the SG. If SU has assignments,
+ *             then depending upon lock or shutdown operation, quiesced
+ *             or quiescing state will be sent for the SU.
+ *
+ * @param[in]  ptr to SU
+ * @param[in]  ptr to nodegroup AVD_AMF_NG.
+ */
+void SG_NACV::ng_admin(AVD_SU *su, AVD_AMF_NG *ng) 
+{
+       TRACE_ENTER2("'%s', sg_fsm_state:%u",su->name.value,
+                       su->sg_of_su->sg_fsm_state);
+
+       if (su->list_of_susi == NULL) {
+               avd_sg_app_su_inst_func(avd_cb, su->sg_of_su);
+               return;
+       }
+       SaAmfHAStateT ha_state;
+       if (ng->saAmfNGAdminState == SA_AMF_ADMIN_SHUTTING_DOWN)
+               ha_state = SA_AMF_HA_QUIESCING;
+       else
+               ha_state = SA_AMF_HA_QUIESCED;
+
+       //change the state for all assignments to quiescing/quiesced.
+       if (avd_sg_su_si_mod_snd(avd_cb, su, ha_state) == NCSCC_RC_FAILURE) {
+               LOG_ER("quiescing state transtion failed for 
'%s'",su->name.value);
+               return ;
+       }
+
+       avd_sg_su_oper_list_add(avd_cb, su, false);
+       su->sg_of_su->set_fsm_state(AVD_SG_FSM_SG_REALIGN);
+       //Increment node counter for tracking status of ng operation.
+       if (su->any_susi_fsm_in_modify() == true) {
+               su->su_on_node->su_cnt_admin_oper++;
+               TRACE("node:%s, su_cnt_admin_oper:%u", 
su->su_on_node->name.value,
+                               su->su_on_node->su_cnt_admin_oper);
+       }
+       TRACE_LEAVE();
+       return;
+}
 
 SG_NACV::~SG_NACV() {
 }

------------------------------------------------------------------------------
Dive into the World of Parallel Programming The Go Parallel Website, sponsored
by Intel and developed in partnership with Slashdot Media, is your hub for all
things parallel software development, from weekly thought leadership blogs to
news, videos, case studies, tutorials and more. Take a look and join the 
conversation now. http://goparallel.sourceforge.net/
_______________________________________________
Opensaf-devel mailing list
Opensaf-devel@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/opensaf-devel

Reply via email to