This patch still has the problem

Bring SC-2 as standby ( With this patch ) & Brint SC-1 Active ( With out 
this patch )

And run following test case on SC-2    ( With this patch node )

1) Init with general callback
2) Asynchrously opened ckpt

====================================================================================================

SC-1:/var/crash/opensaf # Aug 16 13:38:41 SC-1 osafimmnd[3583]: NO 
Implementer (applier) connected: 16 (@safAmfService2010f) <126, 2010f>
Aug 16 13:38:42 SC-1 osafimmnd[3583]: NO Implementer (applier) 
connected: 17 (@OpenSafImmReplicatorB) <170, 2010f>
Aug 16 13:38:42 SC-1 osafntfimcnd[3789]: NO Started
Aug 16 13:38:44 SC-1 osafamfd[3623]: NO Cold sync complete!
Aug 16 13:39:10 SC-1 osafimmnd[3583]: NO Ccb 2 COMMITTED (immcfg_PL-4_9452)
Aug 16 13:39:10 SC-1 osafimmnd[3583]: NO Ccb 3 COMMITTED (safImmService)
Aug 16 13:39:12 SC-1 sudo:      tet : TTY=unknown ; PWD=/tmp/03805aa ; 
USER=root ; COMMAND=/usr/bin/pkill -u root -P 1 mqsv_a
Aug 16 13:39:12 SC-1 osafckptd[3659]: hj_enc.c:311: 
decode_flatten_space: Assertion 'p8' failed.
Aug 16 13:39:12 SC-1 osafamfnd[3633]: NO 
'safComp=CPD,safSu=SC-1,safSg=2N,safApp=OpenSAF' faulted due to 
'avaDown' : Recovery is 'nodeFailfast'
Aug 16 13:39:12 SC-1 osafamfnd[3633]: ER 
safComp=CPD,safSu=SC-1,safSg=2N,safApp=OpenSAF Faulted due to:avaDown 
Recovery is:nodeFailfast
Aug 16 13:39:12 SC-1 osafamfnd[3633]: Rebooting OpenSAF NodeId = 131343 
EE Name = , Reason: Component faulted: recovery is node failfast, 
OwnNodeId = 131343, SupervisionTime = 60
Aug 16 13:39:12 SC-1 opensaf_reboot: Rebooting local node; timeout=60
Aug 16 13:39:13 SC-1 sudo:      tet : TTY=unknown ; PWD=/tmp/03805aa ; 
USER=root ; COMMA

=============================================================================================

-AVM

On 8/12/2016 11:41 AM, Vo Minh Hoang wrote:
> Dear Mahesh,
>
> Thank you very much for your help.
> I send the attached patch that fix missing in encode/decode function.
>
> Thank you and best regards,
> Hoang
>
> -----Original Message-----
> From: A V Mahesh [mailto:mahesh.va...@oracle.com]
> Sent: Friday, August 12, 2016 10:15 AM
> To: Vo Minh Hoang <hoang.m...@dektech.com.au>
> Cc: opensaf-devel@lists.sourceforge.net
> Subject: Re: [PATCH 1 of 1] cpsv: To update checkpoint user number for each
> node [#1669] V4
>
> I will test for you send the patch.
>
> -AVM
>
>
> On 8/11/2016 3:38 PM, Vo Minh Hoang wrote:
>> Dear Mahesh,
>>
>> Would you please tell me the case that produce this error?
>> I review source code and found that encode/decode function missed 1
>> attribute.
>> But running test in our environment could not reproduce this problem.
>>
>> Thank you and best regards,
>> Hoang
>>
>> -----Original Message-----
>> From: A V Mahesh [mailto:mahesh.va...@oracle.com]
>> Sent: Tuesday, August 9, 2016 4:35 PM
>> To: Hoang Vo <hoang.m...@dektech.com.au>
>> Cc: opensaf-devel@lists.sourceforge.net
>> Subject: Re: [PATCH 1 of 1] cpsv: To update checkpoint user number for
>> each node [#1669] V4
>>
>> Hi Hoang ,
>>
>> Please hold on pushing.
>>
>> On new node we have see some issue please check CPD enode and decode
>> once ( new patch node ) .
>>
>> Aug  9 14:23:01 SC-1 osafckptd[20478]: hj_enc.c:311:
>> decode_flatten_space: Assertion 'p8' failed.
>> Aug  9 14:23:01 SC-1 osafamfnd[20439]: NO
>> 'safComp=CPD,safSu=SC-1,safSg=2N,safApp=OpenSAF' faulted due to 'avaDown'
> :
>> Recovery is 'nodeFailfast'
>>
>> -AVM
>>
>>
>>
>> On 8/9/2016 2:09 PM, A V Mahesh wrote:
>>> ACK,
>>>
>>> -AVM
>>>
>>>
>>> On 8/3/2016 4:02 PM, Hoang Vo wrote:
>>>>     osaf/libs/common/cpsv/include/cpd_cb.h |    2 +
>>>>     osaf/libs/common/cpsv/include/cpd_proc.h |    3 +
>>>>     osaf/libs/common/cpsv/include/cpd_red.h  |   13 ++
>>>>     osaf/libs/common/cpsv/include/cpsv_evt.h |    8 +
>>>>     osaf/services/saf/cpsv/cpd/cpd_db.c      |   14 ++-
>>>>     osaf/services/saf/cpsv/cpd/cpd_evt.c     |    8 +
>>>>     osaf/services/saf/cpsv/cpd/cpd_mbcsv.c   |   96 ++++++++++++++++---
>>>>     osaf/services/saf/cpsv/cpd/cpd_proc.c    |  148
>>>> +++++++++++++++++++++++++++++++
>>>>     osaf/services/saf/cpsv/cpd/cpd_red.c     |   30 ++++-
>>>>     osaf/services/saf/cpsv/cpd/cpd_sbevt.c   |   57 +++++++++--
>>>>     10 files changed, 344 insertions(+), 35 deletions(-)
>>>>
>>>>
>>>> Problem:
>>>> -------
>>>> The saCkptCheckpointNumOpeners is not updated when a node which has
>>>> a checkpoint client restarts.
>>>>
>>>> Solution:
>>>> --------
>>>> Currently CPD doesn't store number of user on each node. This patch
>>>> updates CPD to update information about users on each node for each
>>>> checkpoint. When a node restarts, the CPD update the total number of
>>>> users for a checkpoint accordingly. This is reflected on
>>>> saCkptCheckpointNumOpeners attribute correctly.
>>>>
>>>> diff --git a/osaf/libs/common/cpsv/include/cpd_cb.h
>>>> b/osaf/libs/common/cpsv/include/cpd_cb.h
>>>> --- a/osaf/libs/common/cpsv/include/cpd_cb.h
>>>> +++ b/osaf/libs/common/cpsv/include/cpd_cb.h
>>>> @@ -92,6 +92,8 @@ typedef struct cpd_ckpt_info_node {
>>>>         uint32_t num_users;
>>>>         uint32_t num_readers;
>>>>         uint32_t num_writers;
>>>> +    uint32_t node_users_cnt;
>>>> +    CPD_NODE_USER_INFO *node_users;
>>>>           /* for imm */
>>>>         SaUint32T ckpt_used_size;
>>>> diff --git a/osaf/libs/common/cpsv/include/cpd_proc.h
>>>> b/osaf/libs/common/cpsv/include/cpd_proc.h
>>>> --- a/osaf/libs/common/cpsv/include/cpd_proc.h
>>>> +++ b/osaf/libs/common/cpsv/include/cpd_proc.h
>>>> @@ -108,5 +108,8 @@ uint32_t cpd_mbcsv_enc_async_update(CPD_
>>>>     uint32_t cpd_mbcsv_close(CPD_CB *cb);
>>>>     bool cpd_is_noncollocated_replica_present_on_payload(CPD_CB *cb,
>>>> CPD_CKPT_INFO_NODE *ckpt_node);
>>>>     uint32_t cpd_ckpt_reploc_imm_object_delete(CPD_CB *cb,
>>>> CPD_CKPT_REPLOC_INFO *ckpt_reploc_node ,bool is_unlink_set);
>>>> +void cpd_proc_increase_node_user_info(CPD_CKPT_INFO_NODE
>>>> +*ckpt_node,
>>>> MDS_DEST cpnd_dest, SaCkptCheckpointOpenFlagsT open_flags);
>>>> +void cpd_proc_decrease_node_user_info(CPD_CKPT_INFO_NODE
>>>> +*ckpt_node,
>>>> MDS_DEST cpnd_dest, SaCkptCheckpointOpenFlagsT open_flags);
>>>> +void cpd_proc_update_user_info_when_node_down(CPD_CB *cb, NODE_ID
>>>> node_id);
>>>>     uint32_t cpd_proc_ckpt_update_post(CPD_CB *cb);
>>>>     #endif
>>>> diff --git a/osaf/libs/common/cpsv/include/cpd_red.h
>>>> b/osaf/libs/common/cpsv/include/cpd_red.h
>>>> --- a/osaf/libs/common/cpsv/include/cpd_red.h
>>>> +++ b/osaf/libs/common/cpsv/include/cpd_red.h
>>>> @@ -64,6 +64,18 @@ typedef struct cpd_a2s_ckpt_usr_info {
>>>>       } CPD_A2S_CKPT_USR_INFO;
>>>>     +typedef struct cpd_a2s_ckpt_usr_info_2 {
>>>> +    SaCkptCheckpointHandleT ckpt_id;
>>>> +    uint32_t num_user;
>>>> +    uint32_t num_writer;
>>>> +    uint32_t num_reader;
>>>> +    uint32_t num_sections;
>>>> +    uint32_t ckpt_on_scxb1;
>>>> +    uint32_t ckpt_on_scxb2;
>>>> +    uint32_t node_users_cnt;
>>>> +    CPD_NODE_USER_INFO *node_list;
>>>> +} CPD_A2S_CKPT_USR_INFO_2;
>>>> +
>>>>     typedef struct cpd_mbcsv_msg {
>>>>         CPD_MBCSV_MSG_TYPE type;
>>>>         union {
>>>> @@ -76,6 +88,7 @@ typedef struct cpd_mbcsv_msg {
>>>>             CPD_A2S_CKPT_UNLINK ckpt_ulink;
>>>>             CPD_A2S_CKPT_USR_INFO usr_info;
>>>>             CPSV_CKPT_DEST_INFO dest_down;
>>>> +        CPD_A2S_CKPT_USR_INFO_2 usr_info_2;
>>>>         } info;
>>>>     } CPD_MBCSV_MSG;
>>>>     diff --git a/osaf/libs/common/cpsv/include/cpsv_evt.h
>>>> b/osaf/libs/common/cpsv/include/cpsv_evt.h
>>>> --- a/osaf/libs/common/cpsv/include/cpsv_evt.h
>>>> +++ b/osaf/libs/common/cpsv/include/cpsv_evt.h
>>>> @@ -840,6 +840,14 @@ typedef struct cpd_tmr_info {
>>>>         } info;
>>>>     } CPD_TMR_INFO;
>>>>     +typedef struct cpd_node_user_info {
>>>> +    MDS_DEST dest;
>>>> +    uint32_t num_users;
>>>> +    uint32_t num_writers;
>>>> +    uint32_t num_readers;
>>>> +    struct cpd_node_user_info *next; } CPD_NODE_USER_INFO;
>>>> +
>>>>
>> /*********************************************************************
>> ******
>> ***
>>>>      CPD Event Data Structures
>>>> ********************************************************************
>>>> * *********/ diff --git a/osaf/services/saf/cpsv/cpd/cpd_db.c
>>>> b/osaf/services/saf/cpsv/cpd/cpd_db.c
>>>> --- a/osaf/services/saf/cpsv/cpd/cpd_db.c
>>>> +++ b/osaf/services/saf/cpsv/cpd/cpd_db.c
>>>> @@ -137,6 +137,7 @@ uint32_t cpd_ckpt_node_delete(CPD_CB *cb
>>>>     {
>>>>         uint32_t rc = NCSCC_RC_SUCCESS;
>>>>         CPD_NODE_REF_INFO *nref_info, *next_info;
>>>> +    CPD_NODE_USER_INFO *node_user, *next_node_user;
>>>>           TRACE_ENTER();
>>>>     @@ -153,6 +154,13 @@ uint32_t cpd_ckpt_node_delete(CPD_CB *cb
>>>>             nref_info = next_info;
>>>>         }
>>>>     +    node_user = ckpt_node->node_users;
>>>> +    while (node_user) {
>>>> +        next_node_user = node_user->next;
>>>> +        free(node_user);
>>>> +        node_user = next_node_user;
>>>> +    }
>>>> +
>>>>         /* delete imm ckpt runtime object */
>>>>         if ((cb->ha_state == SA_AMF_HA_ACTIVE) &&
>>>> (ckpt_node->is_unlink_set != true)) {
>>>>             if (immutil_saImmOiRtObjectDelete(cb->immOiHandle,
>>>> &ckpt_node->ckpt_name) != SA_AIS_OK) { @@ -1258,8 +1266,11 @@ void
>>>> cpd_clm_cluster_track_cb(const SaCl
>>>>             /* 2. Check the HA_STATE */
>>>>             for (counter = 0; counter <
>>>> notificationBuffer->numberOfItems; counter++) {
>>>>                 if
>>>> (notificationBuffer->notification[counter].clusterChange ==
>>>> SA_CLM_NODE_LEFT) {
>>>> +                node_id =
>>>> notificationBuffer->notification[counter].clusterNode.nodeId;
>>>> +
>>>> +                cpd_proc_update_user_info_when_node_down(cb,
>>>> + node_id);
>>>> +
>>>>                     if (cb->ha_state == SA_AMF_HA_ACTIVE) {
>>>> -                    node_id =
>>>> notificationBuffer->notification[counter].clusterNode.nodeId;
>>>>                         key = node_id;
>>>>                         cpnd_info_node = (CPD_CPND_INFO_NODE *)
>>>> ncs_patricia_tree_get(&cb->cpnd_tree, (uint8_t *)&key); @@ -1267,7
>>>> +1278,6 @@ void cpd_clm_cluster_track_cb(const SaCl
>>>>                             cpd_process_cpnd_down(cb,
>>>> &cpnd_info_node->cpnd_dest);
>>>>                         }
>>>>                     } else if (cb->ha_state == SA_AMF_HA_STANDBY) {
>>>> -                    node_id =
>>>> notificationBuffer->notification[counter].clusterNode.nodeId;
>>>>                         key = node_id;
>>>>                         cpnd_info_node = (CPD_CPND_INFO_NODE *)
>>>> ncs_patricia_tree_get(&cb->cpnd_tree, (uint8_t *)&key); diff --git
>>>> a/osaf/services/saf/cpsv/cpd/cpd_evt.c
>>>> b/osaf/services/saf/cpsv/cpd/cpd_evt.c
>>>> --- a/osaf/services/saf/cpsv/cpd/cpd_evt.c
>>>> +++ b/osaf/services/saf/cpsv/cpd/cpd_evt.c
>>>> @@ -249,6 +249,7 @@ static uint32_t cpd_evt_proc_ckpt_create
>>>>             ckpt_node->num_writers++;
>>>>           ckpt_node->num_users++;
>>>> +    cpd_proc_increase_node_user_info(ckpt_node, sinfo->dest,
>>>> ckpt_create->ckpt_flags);
>>>>           cb->is_db_upd = true;
>>>>     @@ -447,6 +448,8 @@ static uint32_t cpd_evt_proc_ckpt_usr_in
>>>>                 ckpt_node->num_readers++;
>>>>             if (evt->info.ckpt_usr_info.ckpt_flags &
>>>> SA_CKPT_CHECKPOINT_WRITE)
>>>>                 ckpt_node->num_writers++;
>>>> +
>>>> +        cpd_proc_increase_node_user_info(ckpt_node, sinfo->dest,
>>>> evt->info.ckpt_usr_info.ckpt_flags);
>>>>         }
>>>>         else if (evt->info.ckpt_usr_info.info_type ==
>>>> CPSV_USR_INFO_CKPT_OPEN) {
>>>>     @@ -456,6 +459,8 @@ static uint32_t cpd_evt_proc_ckpt_usr_in
>>>>                 ckpt_node->num_readers++;
>>>>             if (evt->info.ckpt_usr_info.ckpt_flags &
>>>> SA_CKPT_CHECKPOINT_WRITE)
>>>>                 ckpt_node->num_writers++;
>>>> +
>>>> +        cpd_proc_increase_node_user_info(ckpt_node, sinfo->dest,
>>>> evt->info.ckpt_usr_info.ckpt_flags);
>>>>         }
>>>>
>>>>         if (evt->info.ckpt_usr_info.info_type ==
>>>> CPSV_USR_INFO_CKPT_CLOSE_LAST) {
>>>> @@ -493,6 +498,8 @@ static uint32_t cpd_evt_proc_ckpt_usr_in
>>>>                 ckpt_node->num_readers--;
>>>>             if (evt->info.ckpt_usr_info.ckpt_flags &
>>>> SA_CKPT_CHECKPOINT_WRITE)
>>>>                 ckpt_node->num_writers--;
>>>> +
>>>> +        cpd_proc_decrease_node_user_info(ckpt_node, sinfo->dest,
>>>> evt->info.ckpt_usr_info.ckpt_flags);
>>>>         }
>>>>         else if (evt->info.ckpt_usr_info.info_type ==
>>>> CPSV_USR_INFO_CKPT_CLOSE) {
>>>>     @@ -503,6 +510,7 @@ static uint32_t cpd_evt_proc_ckpt_usr_in
>>>>             if (evt->info.ckpt_usr_info.ckpt_flags &
>>>> SA_CKPT_CHECKPOINT_WRITE)
>>>>                 ckpt_node->num_writers--;
>>>>     +        cpd_proc_decrease_node_user_info(ckpt_node, sinfo->dest,
>>>> evt->info.ckpt_usr_info.ckpt_flags);
>>>>         }
>>>>           cpd_a2s_ckpt_usr_info(cb, ckpt_node); diff --git
>>>> a/osaf/services/saf/cpsv/cpd/cpd_mbcsv.c
>>>> b/osaf/services/saf/cpsv/cpd/cpd_mbcsv.c
>>>> --- a/osaf/services/saf/cpsv/cpd/cpd_mbcsv.c
>>>> +++ b/osaf/services/saf/cpsv/cpd/cpd_mbcsv.c
>>>> @@ -24,6 +24,10 @@
>>>>       #include "cpd.h"
>>>>     +static void cpd_mbcsv_enc_a2s_usr_info_2(NCS_UBAID *io_uba,
>>>> CPD_A2S_CKPT_USR_INFO_2 *usr_info);
>>>> +static void cpd_mbcsv_dec_a2s_usr_info_2(NCS_UBAID *io_uba,
>>>> CPD_A2S_CKPT_USR_INFO_2 *usr_info);
>>>> +
>>>> +
>>>>
>> /*********************************************************************
>> ******
>> *******************
>>>>      * Name                   : cpd_mbcsv_async_update
>>>>      *
>>>> @@ -439,12 +443,7 @@ uint32_t cpd_mbcsv_enc_async_update(CPD_
>>>>           case CPD_A2S_MSG_CKPT_USR_INFO:
>>>>             cpd_msg = (CPD_MBCSV_MSG
>>>> *)NCS_INT64_TO_PTR_CAST(arg->info.encode.io_reo_hdl);
>>>> -        rc = m_NCS_EDU_EXEC(&cb->edu_hdl,
>>>> FUNC_NAME(CPD_A2S_CKPT_USR_INFO), &arg->info.encode.io_uba,
>>>> -                    EDP_OP_TYPE_ENC, &cpd_msg->info.usr_info,
>>>> &ederror);
>>>> -        if (rc != NCSCC_RC_SUCCESS) {
>>>> -            TRACE_4("edu exec async userinfo failed ");
>>>> -            rc = NCSCC_RC_FAILURE;
>>>> -        }
>>>> + cpd_mbcsv_enc_a2s_usr_info_2(&arg->info.encode.io_uba,
>>>> &cpd_msg->info.usr_info_2);
>>>>             break;
>>>>           case CPD_A2S_MSG_CKPT_DEST_DOWN:
>>>> @@ -744,7 +743,6 @@ uint32_t cpd_mbcsv_dec_async_update(CPD_
>>>>         CPSV_CKPT_DEST_INFO *ckpt_dest_add = NULL;
>>>>         CPSV_CKPT_DEST_INFO *ckpt_dest_del = NULL;
>>>>         CPSV_CKPT_DEST_INFO *ckpt_dest_down = NULL;
>>>> -    CPD_A2S_CKPT_USR_INFO *ckpt_usr_info = NULL;
>>>>         uint32_t evt_type, rc = NCSCC_RC_SUCCESS;
>>>>         EDU_ERR ederror = 0;
>>>>     @@ -889,16 +887,8 @@ uint32_t cpd_mbcsv_dec_async_update(CPD_
>>>>             break;
>>>>           case CPD_A2S_MSG_CKPT_USR_INFO:
>>>> -        ckpt_usr_info = &cpd_msg->info.usr_info;
>>>> -        rc = m_NCS_EDU_EXEC(&cb->edu_hdl,
>>>> FUNC_NAME(CPD_A2S_CKPT_USR_INFO), &arg->info.decode.i_uba,
>>>> -                    EDP_OP_TYPE_DEC, &ckpt_usr_info, &ederror);
>>>> -        if (rc != NCSCC_RC_SUCCESS) {
>>>> -            TRACE_4("edu exec async dest del failed");
>>>> -            rc = NCSCC_RC_FAILURE;
>>>> -            goto end;
>>>> -        }
>>>>             cpd_msg->type = evt_type;
>>>> -        cpd_msg->info.usr_info = *ckpt_usr_info;
>>>> + cpd_mbcsv_dec_a2s_usr_info_2(&arg->info.decode.i_uba,
>>>> &cpd_msg->info.usr_info_2);
>>>>             rc = cpd_process_sb_msg(cb, cpd_msg);
>>>>               if (rc != NCSCC_RC_SUCCESS) { @@ -1154,3 +1144,77 @@
>>>> uint32_t cpd_mbcsv_decode_proc(NCS_MBCSV
>>>>         }
>>>>       }
>>>> +
>>>> +/******************************************************************
>>>> +*
>>>> +***************************
>>>>
>>>> + * Name                   : cpd_mbcsv_enc_a2s_usr_info_2
>>>> + *
>>>> + * Description            : This function encodes the message
>>>> CPD_A2S_MSG_CKPT_USR_INFO
>>>> + *
>>>> + * Return Values          : None
>>>> + *
>>>> + * Notes                  : None
>>>> +*******************************************************************
>>>> +*
>>>> +**************************/
>>>>
>>>> +void cpd_mbcsv_enc_a2s_usr_info_2(NCS_UBAID *io_uba,
>>>> CPD_A2S_CKPT_USR_INFO_2 *usr_info)
>>>> +{
>>>> +    TRACE_ENTER();
>>>> +
>>>> +    osaf_encode_uint64(io_uba, usr_info->ckpt_id);
>>>> +    osaf_encode_uint32(io_uba, usr_info->num_user);
>>>> +    osaf_encode_uint32(io_uba, usr_info->num_writer);
>>>> +    osaf_encode_uint32(io_uba, usr_info->num_reader);
>>>> +    osaf_encode_uint32(io_uba, usr_info->ckpt_on_scxb1);
>>>> +    osaf_encode_uint32(io_uba, usr_info->ckpt_on_scxb2);
>>>> +    osaf_encode_uint32(io_uba, usr_info->node_users_cnt);
>>>> +
>>>> +    int i = 0;
>>>> +    for (i = 0; i < usr_info->node_users_cnt; i++) {
>>>> +        osaf_encode_uint64(io_uba, usr_info->node_list[i].dest);
>>>> +        osaf_encode_uint32(io_uba, usr_info->node_list[i].num_users);
>>>> +        osaf_encode_uint32(io_uba, usr_info->node_list[i].num_writers);
>>>> +        osaf_encode_uint32(io_uba, usr_info->node_list[i].num_readers);
>>>> +    }
>>>> +
>>>> +    TRACE_LEAVE();
>>>> +}
>>>> +
>>>> +/******************************************************************
>>>> +*
>>>> +***************************
>>>>
>>>> + * Name                   : cpd_mbcsv_dec_a2s_usr_info_2
>>>> + *
>>>> + * Description            : This function decodes the message
>>>> CPD_A2S_MSG_CKPT_USR_INFO
>>>> + *
>>>> + *
>>>> + * Return Values          : None
>>>> + *
>>>> + * Notes                  : None
>>>> +*******************************************************************
>>>> +*
>>>> +**************************/
>>>>
>>>> +void cpd_mbcsv_dec_a2s_usr_info_2(NCS_UBAID *io_uba,
>>>> CPD_A2S_CKPT_USR_INFO_2 *usr_info)
>>>> +{
>>>> +    TRACE_ENTER();
>>>> +
>>>> +    osaf_decode_uint64(io_uba, (uint64_t *) &usr_info->ckpt_id);
>>>> +    osaf_decode_uint32(io_uba, &usr_info->num_user);
>>>> +    osaf_decode_uint32(io_uba, &usr_info->num_writer);
>>>> +    osaf_decode_uint32(io_uba, &usr_info->num_reader);
>>>> +    osaf_decode_uint32(io_uba, &usr_info->ckpt_on_scxb1);
>>>> +    osaf_decode_uint32(io_uba, &usr_info->ckpt_on_scxb2);
>>>> +    osaf_decode_uint32(io_uba, &usr_info->node_users_cnt);
>>>> +
>>>> +    // Handle old message
>>>> +    if (!usr_info->node_users_cnt) {
>>>> +        TRACE_LEAVE();
>>>> +        return;
>>>> +    }
>>>> +
>>>> +    int i = 0;
>>>> +    CPD_NODE_USER_INFO *node_list = malloc(usr_info->node_users_cnt
>>>> * sizeof(CPD_NODE_USER_INFO));
>>>> +    for (i = 0; i < usr_info->node_users_cnt; i++) {
>>>> +        osaf_decode_uint64(io_uba, &node_list[i].dest);
>>>> +        osaf_decode_uint32(io_uba, &node_list[i].num_users);
>>>> +        osaf_decode_uint32(io_uba, &node_list[i].num_writers);
>>>> +        osaf_decode_uint32(io_uba, &node_list[i].num_readers);
>>>> +    }
>>>> +
>>>> +    usr_info->node_list = node_list;
>>>> +
>>>> +    TRACE_LEAVE();
>>>> +}
>>>> diff --git a/osaf/services/saf/cpsv/cpd/cpd_proc.c
>>>> b/osaf/services/saf/cpsv/cpd/cpd_proc.c
>>>> --- a/osaf/services/saf/cpsv/cpd/cpd_proc.c
>>>> +++ b/osaf/services/saf/cpsv/cpd/cpd_proc.c
>>>> @@ -1581,3 +1581,151 @@ void cpd_proc_broadcast_rdset_stop(SaCkp
>>>>         send_evt.info.cpnd.info.rdset.type = CPSV_CKPT_RDSET_STOP;
>>>>         cpd_mds_bcast_send(cb, &send_evt, NCSMDS_SVC_ID_CPND);
>>>>     }
>>>> +
>>>> +/******************************************************************
>>>> +*
>>>> +***********************
>>>>
>>>> + * Name          : cpd_proc_increase_node_ref_user_info
>>>> + *
>>>> + * Description   : This routine increases number of user, writer and
>>>> reader for
>>>> + *                 the specified cpnd node reference
>>>> + *
>>>> + * Return Values : None
>>>> + *
>>>> + * Notes         : None
>>>> +*******************************************************************
>>>> +*
>>>> +**********************/
>>>>
>>>> +void cpd_proc_increase_node_user_info(CPD_CKPT_INFO_NODE
>>>> +*ckpt_node,
>>>> MDS_DEST cpnd_dest,
>>>> +        SaCkptCheckpointOpenFlagsT open_flags) {
>>>> +    CPD_NODE_USER_INFO *node_user = ckpt_node->node_users;
>>>> +    CPD_NODE_USER_INFO *last_node_user = NULL;
>>>> +
>>>> +    TRACE_ENTER();
>>>> +
>>>> +    if (ckpt_node->node_users_cnt == 0) {
>>>> +        node_user = malloc(sizeof(CPD_NODE_USER_INFO));
>>>> +        memset(node_user, 0, sizeof(CPD_NODE_USER_INFO));
>>>> +        node_user->dest = cpnd_dest;
>>>> +
>>>> +        if (open_flags & SA_CKPT_CHECKPOINT_READ)
>>>> +            node_user->num_readers++;
>>>> +        if (open_flags & SA_CKPT_CHECKPOINT_WRITE)
>>>> +            node_user->num_writers++;
>>>> +
>>>> +        node_user->num_users++;
>>>> +        node_user->next = NULL;
>>>> +        ckpt_node->node_users = node_user;
>>>> +        ckpt_node->node_users_cnt++;
>>>> +        TRACE_LEAVE();
>>>> +        return;
>>>> +    }
>>>> +
>>>> +    while (node_user) {
>>>> +        if (node_user->dest == cpnd_dest) {
>>>> +            if (open_flags & SA_CKPT_CHECKPOINT_READ)
>>>> +                node_user->num_readers++;
>>>> +            if (open_flags & SA_CKPT_CHECKPOINT_WRITE)
>>>> +                node_user->num_writers++;
>>>> +
>>>> +            node_user->num_users++;
>>>> +            TRACE_LEAVE();
>>>> +            return;
>>>> +        }
>>>> +        last_node_user = node_user;
>>>> +        node_user = node_user->next;
>>>> +    }
>>>> +
>>>> +    /* Add node user */
>>>> +    node_user = malloc(sizeof(CPD_NODE_USER_INFO));
>>>> +    memset(node_user, 0, sizeof(CPD_NODE_USER_INFO));
>>>> +    node_user->dest = cpnd_dest;
>>>> +
>>>> +    if (open_flags & SA_CKPT_CHECKPOINT_READ)
>>>> +        node_user->num_readers++;
>>>> +    if (open_flags & SA_CKPT_CHECKPOINT_WRITE)
>>>> +        node_user->num_writers++;
>>>> +
>>>> +    node_user->num_users++;
>>>> +    node_user->next = NULL;
>>>> +    last_node_user->next = node_user;
>>>> +    ckpt_node->node_users_cnt++;
>>>> +
>>>> +    TRACE_LEAVE();
>>>> +}
>>>> +
>>>> +/******************************************************************
>>>> +*
>>>> +***********************
>>>>
>>>> + * Name          : cpd_proc_decrease_node_ref_user_info
>>>> + *
>>>> + * Description   : This routine decreases number of user, writer and
>>>> reader for
>>>> + *                 the specified cpnd node reference
>>>> + *
>>>> + * Return Values : None
>>>> + *
>>>> + * Notes         : None
>>>> +*******************************************************************
>>>> +*
>>>> +**********************/
>>>>
>>>> +void cpd_proc_decrease_node_user_info(CPD_CKPT_INFO_NODE
>>>> +*ckpt_node,
>>>> MDS_DEST cpnd_dest,
>>>> +        SaCkptCheckpointOpenFlagsT open_flags) {
>>>> +    CPD_NODE_USER_INFO *node_user = ckpt_node->node_users;
>>>> +
>>>> +    TRACE_ENTER();
>>>> +
>>>> +    while (node_user) {
>>>> +        if (node_user->dest == cpnd_dest) {
>>>> +            if (node_user->num_users == 0) {
>>>> +                LOG_ER("cpd_proc_decrease_node_user_info failed -
>>>> + no
>>>> user on node id 0x%X",
>>>> + m_NCS_NODE_ID_FROM_MDS_DEST(cpnd_dest));
>>>> +                TRACE_LEAVE();
>>>> +                return;
>>>> +            }
>>>> +
>>>> +            if (open_flags & SA_CKPT_CHECKPOINT_READ)
>>>> +                node_user->num_readers--;
>>>> +            if (open_flags & SA_CKPT_CHECKPOINT_WRITE)
>>>> +                node_user->num_writers--;
>>>> +
>>>> +            node_user->num_users--;
>>>> +            TRACE_LEAVE();
>>>> +            return;
>>>> +        }
>>>> +        node_user = node_user->next;
>>>> +    }
>>>> +
>>>> +    TRACE_LEAVE();
>>>> +}
>>>> +
>>>> +/******************************************************************
>>>> +*
>>>> +***********************
>>>>
>>>> + * Name          : cpd_proc_update_user_info_when_node_down
>>>> + *
>>>> + * Description   : This routine updates number of user, writer and
>>>> reader in case node down
>>>> + *
>>>> + * Return Values : None
>>>> + *
>>>> + * Notes         : None
>>>> +*******************************************************************
>>>> +*
>>>> +**********************/
>>>>
>>>> +void cpd_proc_update_user_info_when_node_down(CPD_CB *cb, NODE_ID
>>>> node_id)
>>>> +{
>>>> +    CPD_CKPT_INFO_NODE *ckpt_node;
>>>> +    TRACE_ENTER();
>>>> +
>>>> +    cpd_ckpt_node_getnext(&cb->ckpt_tree, NULL, &ckpt_node);
>>>> +    while (ckpt_node) {
>>>> +        SaCkptCheckpointHandleT prev_ckpt_hdl = ckpt_node->ckpt_id;
>>>> +        CPD_NODE_USER_INFO *node_user;
>>>> +
>>>> +        for (node_user = ckpt_node->node_users; node_user != NULL;
>>>> node_user = node_user->next) {
>>>> +            if (node_id ==
>>>> m_NCS_NODE_ID_FROM_MDS_DEST(node_user->dest)) {
>>>> +                ckpt_node->num_users -= node_user->num_users;
>>>> +                ckpt_node->num_writers -= node_user->num_writers;
>>>> +                ckpt_node->num_readers -= node_user->num_readers;
>>>> +
>>>> +                node_user->num_users = 0;
>>>> +                node_user->num_writers = 0;
>>>> +                node_user->num_readers = 0;
>>>> +                break;
>>>> +            }
>>>> +        }
>>>> +
>>>> +        cpd_ckpt_node_getnext(&cb->ckpt_tree, &prev_ckpt_hdl,
>>>> &ckpt_node);
>>>> +    }
>>>> +
>>>> +    TRACE_LEAVE();
>>>> +}
>>>> diff --git a/osaf/services/saf/cpsv/cpd/cpd_red.c
>>>> b/osaf/services/saf/cpsv/cpd/cpd_red.c
>>>> --- a/osaf/services/saf/cpsv/cpd/cpd_red.c
>>>> +++ b/osaf/services/saf/cpsv/cpd/cpd_red.c
>>>> @@ -301,18 +301,34 @@ void cpd_a2s_ckpt_dest_del(CPD_CB *cb, S
>>>>     void cpd_a2s_ckpt_usr_info(CPD_CB *cb, CPD_CKPT_INFO_NODE *ckpt_node)
>>>>     {
>>>>         CPD_MBCSV_MSG cpd_msg;
>>>> +    int count = 0;
>>>>         uint32_t rc = SA_AIS_OK;
>>>>         memset(&cpd_msg, '\0', sizeof(CPD_MBCSV_MSG));
>>>>           TRACE_ENTER();
>>>>         cpd_msg.type = CPD_A2S_MSG_CKPT_USR_INFO;
>>>> -    cpd_msg.info.usr_info.ckpt_id = ckpt_node->ckpt_id;
>>>> -    cpd_msg.info.usr_info.num_user = ckpt_node->num_users;
>>>> -    cpd_msg.info.usr_info.num_writer = ckpt_node->num_writers;
>>>> -    cpd_msg.info.usr_info.num_reader = ckpt_node->num_readers;
>>>> -    cpd_msg.info.usr_info.num_sections = ckpt_node->num_sections;
>>>> -    cpd_msg.info.usr_info.ckpt_on_scxb1 = ckpt_node->ckpt_on_scxb1;
>>>> -    cpd_msg.info.usr_info.ckpt_on_scxb2 = ckpt_node->ckpt_on_scxb2;
>>>> +    cpd_msg.info.usr_info_2.ckpt_id = ckpt_node->ckpt_id;
>>>> +    cpd_msg.info.usr_info_2.num_user = ckpt_node->num_users;
>>>> +    cpd_msg.info.usr_info_2.num_writer = ckpt_node->num_writers;
>>>> +    cpd_msg.info.usr_info_2.num_reader = ckpt_node->num_readers;
>>>> +    cpd_msg.info.usr_info_2.num_sections = ckpt_node->num_sections;
>>>> +    cpd_msg.info.usr_info_2.ckpt_on_scxb1 = ckpt_node->ckpt_on_scxb1;
>>>> +    cpd_msg.info.usr_info_2.ckpt_on_scxb2 =
>>>> + ckpt_node->ckpt_on_scxb2;
>>>> +
>>>> +    if (ckpt_node->node_users_cnt) {
>>>> +        CPD_NODE_USER_INFO *node_user = ckpt_node->node_users;
>>>> +        cpd_msg.info.usr_info_2.node_users_cnt =
>>>> ckpt_node->node_users_cnt;
>>>> +        cpd_msg.info.usr_info_2.node_list =
>>>> malloc(ckpt_node->node_users_cnt * sizeof(CPD_NODE_USER_INFO));
>>>> +        memset(cpd_msg.info.usr_info_2.node_list, '\0',
>>>> (sizeof(CPD_NODE_USER_INFO) * ckpt_node->node_users_cnt));
>>>> +
>>>> +        for (count = 0; count < ckpt_node->node_users_cnt; count++) {
>>>> +            cpd_msg.info.usr_info_2.node_list[count].dest =
>>>> node_user->dest;
>>>> +            cpd_msg.info.usr_info_2.node_list[count].num_users =
>>>> node_user->num_users;
>>>> + cpd_msg.info.usr_info_2.node_list[count].num_readers =
>>>> node_user->num_readers;
>>>> + cpd_msg.info.usr_info_2.node_list[count].num_writers =
>>>> node_user->num_writers;
>>>> +            node_user = node_user->next;
>>>> +        }
>>>> +    }
>>>>           rc = cpd_mbcsv_async_update(cb, &cpd_msg);
>>>>         if (rc != SA_AIS_OK)
>>>> diff --git a/osaf/services/saf/cpsv/cpd/cpd_sbevt.c
>>>> b/osaf/services/saf/cpsv/cpd/cpd_sbevt.c
>>>> --- a/osaf/services/saf/cpsv/cpd/cpd_sbevt.c
>>>> +++ b/osaf/services/saf/cpsv/cpd/cpd_sbevt.c
>>>> @@ -549,14 +549,15 @@ uint32_t cpd_sb_proc_ckpt_dest_add(CPD_C
>>>>
>> /*********************************************************************
>> ******
>> *******
>>>>     *  Name :  cpd_sb_proc_ckpt_usrinfo
>>>>     *
>>>> -*  Description : This routine will set the active replica flag of
>>>> the checkpoint
>>>> +*  Description : This routine will update user information of the
>>>> checkpoint
>>>> +*                This version includes user information of each node
>>>>     *
>>>>     *  Arguments   : CPD_MBCSV_MSG - mbcsv message
>>>> -
>>>> +*
>>>>     *  Return Values : Success / Error
>>>> -
>>>> +*
>>>>     *  Notes : None
>>>> -
>>>> +*
>>>>
>> **********************************************************************
>> ******
>> ******/
>>>>     uint32_t cpd_sb_proc_ckpt_usrinfo(CPD_CB *cb, CPD_MBCSV_MSG *msg)
>>>>     {
>>>> @@ -569,12 +570,48 @@ uint32_t cpd_sb_proc_ckpt_usrinfo(CPD_CB
>>>>             return NCSCC_RC_FAILURE;
>>>>         }
>>>>     -    ckpt_node->num_users = msg->info.usr_info.num_user;
>>>> -    ckpt_node->num_writers = msg->info.usr_info.num_writer;
>>>> -    ckpt_node->num_readers = msg->info.usr_info.num_reader;
>>>> -    ckpt_node->num_sections = msg->info.usr_info.num_sections;
>>>> -    ckpt_node->ckpt_on_scxb1 = msg->info.usr_info.ckpt_on_scxb1;
>>>> -    ckpt_node->ckpt_on_scxb2 = msg->info.usr_info.ckpt_on_scxb2;
>>>> +    ckpt_node->num_users = msg->info.usr_info_2.num_user;
>>>> +    ckpt_node->num_writers = msg->info.usr_info_2.num_writer;
>>>> +    ckpt_node->num_readers = msg->info.usr_info_2.num_reader;
>>>> +    ckpt_node->num_sections = msg->info.usr_info_2.num_sections;
>>>> +    ckpt_node->ckpt_on_scxb1 = msg->info.usr_info_2.ckpt_on_scxb1;
>>>> +    ckpt_node->ckpt_on_scxb2 = msg->info.usr_info_2.ckpt_on_scxb2;
>>>> +
>>>> +    /* Free the old node_users */
>>>> +    CPD_NODE_USER_INFO *node_user = ckpt_node->node_users;
>>>> +    CPD_NODE_USER_INFO *prev_node_user = NULL;
>>>> +
>>>> +    while (node_user) {
>>>> +        CPD_NODE_USER_INFO *prev_node_user = node_user;
>>>> +        node_user = node_user->next;
>>>> +        free(prev_node_user);
>>>> +    }
>>>> +    ckpt_node->node_users = NULL;
>>>> +
>>>> +    if (!msg->info.usr_info_2.node_users_cnt) {
>>>> +        TRACE_LEAVE();
>>>> +        return NCSCC_RC_SUCCESS;
>>>> +    }
>>>> +
>>>> +    /* Update the node_users */
>>>> +    int i = 0;
>>>> +    for (i = 0; i < msg->info.usr_info_2.node_users_cnt; i++) {
>>>> +        CPD_NODE_USER_INFO *node_user =
>>>> malloc(sizeof(CPD_NODE_USER_INFO));
>>>> +        if (prev_node_user != NULL)
>>>> +            prev_node_user->next = node_user;
>>>> +
>>>> +        node_user->dest = msg->info.usr_info_2.node_list[i].dest;
>>>> +        node_user->num_users =
>>>> msg->info.usr_info_2.node_list[i].num_users;
>>>> +        node_user->num_readers =
>>>> msg->info.usr_info_2.node_list[i].num_readers;
>>>> +        node_user->num_writers =
>>>> msg->info.usr_info_2.node_list[i].num_writers;
>>>> +        node_user->next = NULL;
>>>> +        prev_node_user = node_user;
>>>> +
>>>> +        if (i == 0)
>>>> +            ckpt_node->node_users = node_user;
>>>> +    }
>>>> +
>>>> +    free(msg->info.usr_info_2.node_list);
>>>>           TRACE_LEAVE();
>>>>         return NCSCC_RC_SUCCESS;


------------------------------------------------------------------------------
_______________________________________________
Opensaf-devel mailing list
Opensaf-devel@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/opensaf-devel

Reply via email to