Hi Praveen, There's a bug in V1 at AMFD side, so I floated V2. The change is commented in V2: "
This V2 avoid AMFD crash if scAbsence is not configured. V2's diff (from V1) is at avd_process_state_info_queue() " So latest patches are below: [PATCH 0 of 2] Review Request for AMF: Support admin operation continuation after headless [#1725 Part 1] V2 [PATCH 1 of 2] AMFD: Introduce new RTA states for admin operation continuation after headless [#1725 part 1] V2 [PATCH 2 of 2] AMFND: Admin operation continuation if csi callback completes during headless [#1725 part 1] V1 I also uploaded the patches V2 to ticket. Sorry for inconvenience. Thanks, Minh On 05/08/16 15:40, praveen malviya wrote: > Hi Minh, > > Not all the patches are received. Also in the two received patches > contents are same but commit messages are different. > If this because of size of the patches, please upload in the ticket. > > > Thanks, > Praveen > > On 05-Aug-16 2:50 AM, Minh Hon Chau wrote: >> osaf/services/saf/amf/amfnd/di.cc | 199 +++++++++++++++++-------- >> osaf/services/saf/amf/amfnd/include/avnd_di.h | 1 + >> 2 files changed, 134 insertions(+), 66 deletions(-) >> >> >> The patch buffers susi_resp_msg during headless stage and resend it >> to AMFD after >> headless. >> >> diff --git a/osaf/services/saf/amf/amfnd/di.cc >> b/osaf/services/saf/amf/amfnd/di.cc >> --- a/osaf/services/saf/amf/amfnd/di.cc >> +++ b/osaf/services/saf/amf/amfnd/di.cc >> @@ -804,11 +804,6 @@ uint32_t avnd_di_susi_resp_send(AVND_CB >> if (cb->term_state == AVND_TERM_STATE_OPENSAF_SHUTDOWN_STARTED) >> return rc; >> >> - if (cb->is_avd_down == true) { >> - m_AVND_SU_ALL_SI_RESET(su); >> - return rc; >> - } >> - >> // should be in assignment pending state to be here >> osafassert(m_AVND_SU_IS_ASSIGN_PEND(su)); >> >> @@ -819,64 +814,76 @@ uint32_t avnd_di_susi_resp_send(AVND_CB >> TRACE_ENTER2("Sending Resp su=%s, si=%s, curr_state=%u, >> prv_state=%u", su->name.value, >> curr_si->name.value,curr_si->curr_state,curr_si->prv_state); >> /* populate the susi resp msg */ >> msg.info.avd = new AVSV_DND_MSG(); >> - msg.type = AVND_MSG_AVD; >> - msg.info.avd->msg_type = AVSV_N2D_INFO_SU_SI_ASSIGN_MSG; >> - msg.info.avd->msg_info.n2d_su_si_assign.msg_id = >> ++(cb->snd_msg_id); >> - msg.info.avd->msg_info.n2d_su_si_assign.node_id = >> cb->node_info.nodeId; >> - if (si) { >> - msg.info.avd->msg_info.n2d_su_si_assign.single_csi = >> - ((si->single_csi_add_rem_in_si == >> AVSV_SUSI_ACT_BASE) ? false : true); >> - } >> - TRACE("curr_assign_state '%u'", curr_si->curr_assign_state); >> - msg.info.avd->msg_info.n2d_su_si_assign.msg_act = >> - (m_AVND_SU_SI_CURR_ASSIGN_STATE_IS_ASSIGNED(curr_si) || >> - m_AVND_SU_SI_CURR_ASSIGN_STATE_IS_ASSIGNING(curr_si)) ? >> - ((!curr_si->prv_state) ? AVSV_SUSI_ACT_ASGN : >> AVSV_SUSI_ACT_MOD) : AVSV_SUSI_ACT_DEL; >> - msg.info.avd->msg_info.n2d_su_si_assign.su_name = su->name; >> - if (si) { >> - msg.info.avd->msg_info.n2d_su_si_assign.si_name = si->name; >> - if (AVSV_SUSI_ACT_ASGN == >> si->single_csi_add_rem_in_si) { >> - TRACE("si->curr_assign_state '%u'", >> curr_si->curr_assign_state); >> - msg.info.avd->msg_info.n2d_su_si_assign.msg_act = >> - (m_AVND_SU_SI_CURR_ASSIGN_STATE_IS_ASSIGNED(curr_si) || >> - m_AVND_SU_SI_CURR_ASSIGN_STATE_IS_ASSIGNING(curr_si)) ? >> - AVSV_SUSI_ACT_ASGN : AVSV_SUSI_ACT_DEL; >> - } >> - } >> - msg.info.avd->msg_info.n2d_su_si_assign.ha_state = >> - (SA_AMF_HA_QUIESCING == curr_si->curr_state) ? >> SA_AMF_HA_QUIESCED : curr_si->curr_state; >> - msg.info.avd->msg_info.n2d_su_si_assign.error = >> - (m_AVND_SU_SI_CURR_ASSIGN_STATE_IS_ASSIGNED(curr_si) || >> - m_AVND_SU_SI_CURR_ASSIGN_STATE_IS_REMOVED(curr_si)) ? >> NCSCC_RC_SUCCESS : NCSCC_RC_FAILURE; >> + msg.type = AVND_MSG_AVD; >> + msg.info.avd->msg_type = AVSV_N2D_INFO_SU_SI_ASSIGN_MSG; >> + msg.info.avd->msg_info.n2d_su_si_assign.node_id = >> cb->node_info.nodeId; >> + if (si) { >> + msg.info.avd->msg_info.n2d_su_si_assign.single_csi = >> + ((si->single_csi_add_rem_in_si == >> AVSV_SUSI_ACT_BASE) ? false : true); >> + } >> + TRACE("curr_assign_state '%u'", curr_si->curr_assign_state); >> + msg.info.avd->msg_info.n2d_su_si_assign.msg_act = >> + (m_AVND_SU_SI_CURR_ASSIGN_STATE_IS_ASSIGNED(curr_si) || >> + m_AVND_SU_SI_CURR_ASSIGN_STATE_IS_ASSIGNING(curr_si)) ? >> + ((!curr_si->prv_state) ? AVSV_SUSI_ACT_ASGN : >> AVSV_SUSI_ACT_MOD) : AVSV_SUSI_ACT_DEL; >> + msg.info.avd->msg_info.n2d_su_si_assign.su_name = su->name; >> + if (si) { >> + msg.info.avd->msg_info.n2d_su_si_assign.si_name = si->name; >> + if (AVSV_SUSI_ACT_ASGN == si->single_csi_add_rem_in_si) { >> + TRACE("si->curr_assign_state '%u'", >> curr_si->curr_assign_state); >> + msg.info.avd->msg_info.n2d_su_si_assign.msg_act = >> + (m_AVND_SU_SI_CURR_ASSIGN_STATE_IS_ASSIGNED(curr_si) || >> + m_AVND_SU_SI_CURR_ASSIGN_STATE_IS_ASSIGNING(curr_si)) ? >> + AVSV_SUSI_ACT_ASGN : AVSV_SUSI_ACT_DEL; >> + } >> + } >> + msg.info.avd->msg_info.n2d_su_si_assign.ha_state = >> + (SA_AMF_HA_QUIESCING == curr_si->curr_state) ? >> SA_AMF_HA_QUIESCED : curr_si->curr_state; >> + msg.info.avd->msg_info.n2d_su_si_assign.error = >> + (m_AVND_SU_SI_CURR_ASSIGN_STATE_IS_ASSIGNED(curr_si) || >> + m_AVND_SU_SI_CURR_ASSIGN_STATE_IS_REMOVED(curr_si)) ? >> NCSCC_RC_SUCCESS : NCSCC_RC_FAILURE; >> >> - if (msg.info.avd->msg_info.n2d_su_si_assign.msg_act == >> AVSV_SUSI_ACT_ASGN) >> - osafassert(si); >> + if (msg.info.avd->msg_info.n2d_su_si_assign.msg_act == >> AVSV_SUSI_ACT_ASGN) >> + osafassert(si); >> >> - /* send the msg to AvD */ >> - TRACE("Sending. msg_id'%u', node_id'%u', msg_act'%u', >> su'%s', si'%s', ha_state'%u', error'%u', single_csi'%u'", >> - msg.info.avd->msg_info.n2d_su_si_assign.msg_id, >> msg.info.avd->msg_info.n2d_su_si_assign.node_id, >> - msg.info.avd->msg_info.n2d_su_si_assign.msg_act, >> msg.info.avd->msg_info.n2d_su_si_assign.su_name.value, >> - msg.info.avd->msg_info.n2d_su_si_assign.si_name.value, >> msg.info.avd->msg_info.n2d_su_si_assign.ha_state, >> - msg.info.avd->msg_info.n2d_su_si_assign.error, >> msg.info.avd->msg_info.n2d_su_si_assign.single_csi); >> + /* send the msg to AvD */ >> + TRACE("Sending. msg_id'%u', node_id'%u', msg_act'%u', su'%s', >> si'%s', ha_state'%u', error'%u', single_csi'%u'", >> + msg.info.avd->msg_info.n2d_su_si_assign.msg_id, >> msg.info.avd->msg_info.n2d_su_si_assign.node_id, >> + msg.info.avd->msg_info.n2d_su_si_assign.msg_act, >> msg.info.avd->msg_info.n2d_su_si_assign.su_name.value, >> + msg.info.avd->msg_info.n2d_su_si_assign.si_name.value, >> msg.info.avd->msg_info.n2d_su_si_assign.ha_state, >> + msg.info.avd->msg_info.n2d_su_si_assign.error, >> msg.info.avd->msg_info.n2d_su_si_assign.single_csi); >> >> - if ((su->si_list.n_nodes > 1) && (si == nullptr)) { >> - if (msg.info.avd->msg_info.n2d_su_si_assign.msg_act >> == AVSV_SUSI_ACT_DEL) >> - LOG_NO("Removed 'all SIs' from '%s'", >> su->name.value); >> + if ((su->si_list.n_nodes > 1) && (si == nullptr)) { >> + if (msg.info.avd->msg_info.n2d_su_si_assign.msg_act == >> AVSV_SUSI_ACT_DEL) >> + LOG_NO("Removed 'all SIs' from '%s'", su->name.value); >> >> - if (msg.info.avd->msg_info.n2d_su_si_assign.msg_act >> == AVSV_SUSI_ACT_MOD) >> - LOG_NO("Assigned 'all SIs' %s of '%s'", >> - ha_state[msg.info.avd->msg_info.n2d_su_si_assign.ha_state], >> - su->name.value); >> - } >> + if (msg.info.avd->msg_info.n2d_su_si_assign.msg_act == >> AVSV_SUSI_ACT_MOD) >> + LOG_NO("Assigned 'all SIs' %s of '%s'", >> + ha_state[msg.info.avd->msg_info.n2d_su_si_assign.ha_state], >> + su->name.value); >> + } >> >> - rc = avnd_di_msg_send(cb, &msg); >> - if (NCSCC_RC_SUCCESS == rc) >> - msg.info.avd = 0; >> - >> - /* we have completed the SU SI msg processing */ >> - if (su_assign_state_is_stable(su)) >> - m_AVND_SU_ASSIGN_PEND_RESET(su); >> - m_AVND_SU_ALL_SI_RESET(su); >> + if (cb->is_avd_down == true) { >> + // We are in headless, buffer this msg >> + msg.info.avd->msg_info.n2d_su_si_assign.msg_id = 0; >> + if (avnd_diq_rec_add(cb, &msg) == nullptr) { >> + rc = NCSCC_RC_FAILURE; >> + } >> + m_AVND_SU_ALL_SI_RESET(su); >> + LOG_NO("avnd_di_susi_resp_send() deferred as AMF director is >> offline"); >> + } else { >> + // We are in normal cluster, send msg to director >> + msg.info.avd->msg_info.n2d_su_si_assign.msg_id = >> ++(cb->snd_msg_id); >> + /* send the msg to AvD */ >> + rc = avnd_di_msg_send(cb, &msg); >> + if (NCSCC_RC_SUCCESS == rc) >> + msg.info.avd = 0; >> + /* we have completed the SU SI msg processing */ >> + if (su_assign_state_is_stable(su)) { >> + m_AVND_SU_ASSIGN_PEND_RESET(su); >> + } >> + m_AVND_SU_ALL_SI_RESET(su); >> + } >> >> /* free the contents of avnd message */ >> avnd_msg_content_free(cb, &msg); >> @@ -1255,14 +1262,7 @@ void avnd_diq_rec_del(AVND_CB *cb, AVND_ >> /* stop the AvD msg response timer */ >> if (m_AVND_TMR_IS_ACTIVE(rec->resp_tmr)) { >> m_AVND_TMR_MSG_RESP_STOP(cb, *rec); >> - // Resend msgs from queue because amfd dropped during sync >> - if ((cb->dnd_list.head != nullptr)) { >> - TRACE("retransmit message to amfd"); >> - AVND_DND_MSG_LIST *pending_rec = 0; >> - for (pending_rec = cb->dnd_list.head; pending_rec != >> nullptr; pending_rec = pending_rec->next) { >> - avnd_diq_rec_send(cb, pending_rec); >> - } >> - } >> + avnd_diq_rec_send_buffered_msg(cb); >> /* resend pg start track */ >> avnd_di_resend_pg_start_track(cb); >> } >> @@ -1275,6 +1275,73 @@ void avnd_diq_rec_del(AVND_CB *cb, AVND_ >> TRACE_LEAVE(); >> return; >> } >> +/**************************************************************************** >> >> >> + Name : avnd_diq_rec_send_buffered_msg >> + >> + Description : Resend buffered msg >> + >> + Arguments : cb - ptr to the AvND control block >> + >> + Return Values : None. >> + >> + Notes : None. >> +******************************************************************************/ >> >> >> +void avnd_diq_rec_send_buffered_msg(AVND_CB *cb) >> +{ >> + TRACE_ENTER(); >> + // Resend msgs from queue because amfnd dropped during headless >> + // or headless-synchronization >> + if ((cb->dnd_list.head != nullptr)) { >> + AVND_DND_MSG_LIST *pending_rec = 0; >> + TRACE("Attach msg_id of buffered msg"); >> + bool found = true; >> + while (found) { >> + found = false; >> + for (pending_rec = cb->dnd_list.head; pending_rec != >> nullptr; pending_rec = pending_rec->next) { >> + if (pending_rec->msg.type == AVND_MSG_AVD) { >> + // At this moment, only oper_state msg needs to >> report to director >> + if (pending_rec->msg.info.avd->msg_type == >> AVSV_N2D_INFO_SU_SI_ASSIGN_MSG && >> + pending_rec->msg.info.avd->msg_info.n2d_su_si_assign.msg_id == 0) { >> + m_AVND_DIQ_REC_POP(cb, pending_rec); >> +#if 0 >> + // only resend if this SUSI does exist >> + AVND_SU *su = m_AVND_SUDB_REC_GET(cb->sudb, >> + pending_rec->msg.info.avd->msg_info.n2d_su_si_assign.su_name); >> + if (su != nullptr && su->si_list.n_nodes > 0) { >> +#endif >> + pending_rec->msg.info.avd->msg_info.n2d_su_si_assign.msg_id = >> ++(cb->snd_msg_id); >> + m_AVND_DIQ_REC_PUSH(cb, pending_rec); >> + LOG_NO("Found and resend buffered >> su_si_assign msg for SU:'%s', " >> + "SI:'%s', ha_state:'%u', >> msg_act:'%u', single_csi:'%u', " >> + "error:'%u', msg_id:'%u'", >> + pending_rec->msg.info.avd->msg_info.n2d_su_si_assign.su_name.value, >> + pending_rec->msg.info.avd->msg_info.n2d_su_si_assign.si_name.value, >> + pending_rec->msg.info.avd->msg_info.n2d_su_si_assign.ha_state, >> + pending_rec->msg.info.avd->msg_info.n2d_su_si_assign.msg_act, >> + pending_rec->msg.info.avd->msg_info.n2d_su_si_assign.single_csi, >> + pending_rec->msg.info.avd->msg_info.n2d_su_si_assign.error, >> + pending_rec->msg.info.avd->msg_info.n2d_su_si_assign.msg_id); >> + >> +#if 0 >> + } else { >> + avnd_msg_content_free(cb, >> &pending_rec->msg); >> + delete pending_rec; >> + pending_rec = cb->dnd_list.head; >> + } >> +#endif >> + found = true; >> + } >> + } >> + } >> + } >> + TRACE("retransmit message to amfd"); >> + for (pending_rec = cb->dnd_list.head; pending_rec != >> nullptr; pending_rec = pending_rec->next) { >> + avnd_diq_rec_send(cb, pending_rec); >> + } >> + } >> + TRACE_LEAVE(); >> + return; >> +} >> >> >> /**************************************************************************** >> >> >> Name : avnd_diq_rec_send >> diff --git a/osaf/services/saf/amf/amfnd/include/avnd_di.h >> b/osaf/services/saf/amf/amfnd/include/avnd_di.h >> --- a/osaf/services/saf/amf/amfnd/include/avnd_di.h >> +++ b/osaf/services/saf/amf/amfnd/include/avnd_di.h >> @@ -79,6 +79,7 @@ void avnd_di_msg_ack_process(struct avnd >> void avnd_diq_del(struct avnd_cb_tag *); >> AVND_DND_MSG_LIST *avnd_diq_rec_add(struct avnd_cb_tag *cb, AVND_MSG >> *msg); >> void avnd_diq_rec_del(struct avnd_cb_tag *cb, AVND_DND_MSG_LIST *rec); >> +void avnd_diq_rec_send_buffered_msg(struct avnd_cb_tag *cb); >> uint32_t avnd_diq_rec_send(struct avnd_cb_tag *cb, AVND_DND_MSG_LIST >> *rec); >> uint32_t avnd_di_reg_su_rsp_snd(struct avnd_cb_tag *cb, SaNameT >> *su_name, uint32_t ret_code); >> uint32_t avnd_di_ack_nack_msg_send(struct avnd_cb_tag *cb, uint32_t >> rcv_id, uint32_t view_num); >> > ------------------------------------------------------------------------------ _______________________________________________ Opensaf-devel mailing list Opensaf-devel@lists.sourceforge.net https://lists.sourceforge.net/lists/listinfo/opensaf-devel