Files
microser/mmslib/mmsle/rs_takec.c
2026-06-15 15:48:16 +08:00

343 lines
14 KiB
C

/************************************************************************/
/* SISCO SOFTWARE MODULE HEADER *****************************************/
/************************************************************************/
/* (c) Copyright Systems Integration Specialists Company, Inc., */
/* 1986 - 2001, All Rights Reserved. */
/* */
/* PROPRIETARY AND CONFIDENTIAL */
/* */
/* MODULE NAME : rs_takectrl.c */
/* PRODUCT(S) : MMSEASE, MMSEASE-LITE */
/* */
/* MODULE DESCRIPTION : */
/* This module contains the responder portion of take semaphore */
/* control. It decodes the take control request (indication) and */
/* encodes the take control response. */
/* */
/* GLOBAL FUNCTIONS DEFINED IN THIS MODULE : */
/* */
/* MODIFICATION LOG : */
/* Date Who Rev Comments */
/* -------- --- ------ ------------------------------------------- */
/* 03/11/04 GLB 08 Remove "thisFileName" */
/* 08/28/03 EJV 07 Corr spelling for 'receive'. */
/* 12/20/01 JRB 06 Converted to use ASN1R (re-entrant ASN1) */
/* 09/13/99 MDE 05 Added SD_CONST modifiers */
/* 03/23/99 MDE 04 Changes to decode buffer allocation scheme */
/* 06/15/98 MDE 03 Changes to allow compile under C++ */
/* 07/03/97 MDE 02 Op-specific info buffer handling changes */
/* 06/09/97 MDE 01 Changed op specific buffer allocation */
/* 04/02/97 DTL 7.00 MMSEASE 7.0 release. See MODL70.DOC for */
/* history. */
/************************************************************************/
#include "glbtypes.h"
#include "sysincs.h"
#include "mmsdefs.h"
#include "mms_psem.h"
#include "asn1defs.h"
/************************************************************************/
/* variables global to the DECODE portion : */
static TAKECTRL_REQ_INFO *req_info;
/************************************************************************/
/* variables global to the ENCODE portion : NONE */
static ST_VOID takectrl_get_priority (ASN1_DEC_CTXT *aCtx);
static ST_VOID takectrl_get_acc_delay (ASN1_DEC_CTXT *aCtx);
static ST_VOID takectrl_get_ctrl_timeout (ASN1_DEC_CTXT *aCtx);
static ST_VOID takectrl_get_abrt_timeout (ASN1_DEC_CTXT *aCtx);
static ST_VOID takectrl_get_rel_conn_lost (ASN1_DEC_CTXT *aCtx);
static ST_VOID takectrl_app_preempt_cstr (ASN1_DEC_CTXT *aCtx);
static ST_VOID takectrl_get_named_token (ASN1_DEC_CTXT *aCtx);
static ST_VOID takectrl_sem_name_cstr_done (ASN1_DEC_CTXT *aCtx);
static ST_VOID takectrl_objname_done (ASN1_DEC_CTXT *aCtx);
static ST_VOID takectrl_sem_name_cstr (ASN1_DEC_CTXT *aCtx);
static ST_VOID app_preempt_cstr_done (ASN1_DEC_CTXT *aCtx);
static ST_UCHAR *ar_start;
/************************************************************************/
/************************************************************************/
/* mms_takectrl_req */
/* This function is called from mmsdec when the opcode for this */
/* operation is decoded. Setup state machine function pointers, etc. */
/************************************************************************/
ST_VOID mms_takectrl_req (ASN1_DEC_CTXT *aCtx)
{
MLOG_CDEC0 ("Take Control Request");
req_info = (TAKECTRL_REQ_INFO *) _m_get_dec_buf (aCtx, sizeof (TAKECTRL_REQ_INFO));
ASN1R_TAG_ADD (aCtx, CTX |CONSTR, 0, takectrl_sem_name_cstr);
}
/************************************************************************/
/* takectrl_sem_name_cstr */
/* Decoding take control request: semaphore name constructor was */
/* encountered. */
/************************************************************************/
static ST_VOID takectrl_sem_name_cstr (ASN1_DEC_CTXT *aCtx)
{
MLOG_CDEC0 ("takectrl_sem_name_cstr");
/* get storage for request information */
req_info->priority = MMS_NORM_PRIORITY;
req_info->rel_conn_lost = SD_TRUE;
_ms_get_mms_objname (aCtx, &req_info->sem_name, takectrl_objname_done);
}
/************************************************************************/
/* takectrl_objname_done */
/* Decoding take control request: Semaphore name has been obtained */
/************************************************************************/
static ST_VOID takectrl_objname_done (ASN1_DEC_CTXT *aCtx)
{
aCtx->asn1r_c_done_fun [aCtx->asn1r_msg_level] = takectrl_sem_name_cstr_done;
}
/************************************************************************/
/* takectrl_sem_name_cstr_done */
/* Decoding take control request: semaphore name contructor done was */
/* encountered. */
/************************************************************************/
static ST_VOID takectrl_sem_name_cstr_done (ASN1_DEC_CTXT *aCtx)
{
ASN1R_TAG_ADD (aCtx, CTX, 1, takectrl_get_named_token );
ASN1R_TAG_ADD (aCtx, CTX, 2, takectrl_get_priority );
ASN1R_TAG_ADD (aCtx, CTX, 3, takectrl_get_acc_delay );
ASN1R_TAG_ADD (aCtx, CTX, 4, takectrl_get_ctrl_timeout );
ASN1R_TAG_ADD (aCtx, CTX, 5, takectrl_get_abrt_timeout);
ASN1R_TAG_ADD (aCtx, CTX, 6, takectrl_get_rel_conn_lost);
ASN1R_TAG_ADD (aCtx, CTX | CONSTR, 7, takectrl_app_preempt_cstr );
_ms_set_cs_check (aCtx); /* check for Companion Standard info */
ar_start = aCtx->asn1r_field_ptr;
}
/************************************************************************/
/* takectrl_get_named_token */
/* Decoding take control request: named token name was encountered. */
/************************************************************************/
static ST_VOID takectrl_get_named_token (ASN1_DEC_CTXT *aCtx)
{
MLOG_CDEC0 ("takectrl_get_named_token");
req_info->named_token_pres = SD_TRUE; /* set named token present */
/* read named token from received message */
if (asn1r_get_identifier (aCtx, req_info->named_token))
asn1r_set_dec_err (aCtx, REQ_BAD_VALUE);
ASN1R_TAG_ADD (aCtx, CTX, 2, takectrl_get_priority );
ASN1R_TAG_ADD (aCtx, CTX, 3, takectrl_get_acc_delay );
ASN1R_TAG_ADD (aCtx, CTX, 4, takectrl_get_ctrl_timeout );
ASN1R_TAG_ADD (aCtx, CTX, 5, takectrl_get_abrt_timeout);
ASN1R_TAG_ADD (aCtx, CTX, 6, takectrl_get_rel_conn_lost);
ASN1R_TAG_ADD (aCtx, CTX | CONSTR, 7, takectrl_app_preempt_cstr );
_ms_set_cs_check (aCtx); /* check for Companion Standard info */
ar_start = aCtx->asn1r_field_ptr;
}
/************************************************************************/
/* takectrl_get_priority */
/* Take control request: decode the priority */
/************************************************************************/
static ST_VOID takectrl_get_priority (ASN1_DEC_CTXT *aCtx)
{
MLOG_CDEC0 ("takectrl_get_priorit");
/* read the priority from the received message */
if (asn1r_get_u8 (aCtx, &(req_info->priority)))
asn1r_set_dec_err (aCtx, REQ_BAD_VALUE);
ASN1R_TAG_ADD (aCtx, CTX, 3, takectrl_get_acc_delay );
ASN1R_TAG_ADD (aCtx, CTX, 4, takectrl_get_ctrl_timeout );
ASN1R_TAG_ADD (aCtx, CTX, 5, takectrl_get_abrt_timeout);
ASN1R_TAG_ADD (aCtx, CTX, 6, takectrl_get_rel_conn_lost);
ASN1R_TAG_ADD (aCtx, CTX | CONSTR, 7, takectrl_app_preempt_cstr );
_ms_set_cs_check (aCtx); /* check for Companion Standard info */
ar_start = aCtx->asn1r_field_ptr;
}
/************************************************************************/
/* takectrl_get_acc_delay */
/* Take control request: decode acceptable delay */
/************************************************************************/
static ST_VOID takectrl_get_acc_delay (ASN1_DEC_CTXT *aCtx)
{
MLOG_CDEC0 ("takectrl_get_acc_dela");
req_info->acc_delay_pres = SD_TRUE; /* set acceptable delay present */
/* read acceptable delay from message */
if (asn1r_get_u32 (aCtx, &(req_info->acc_delay)))
asn1r_set_dec_err (aCtx, REQ_BAD_VALUE);
ASN1R_TAG_ADD (aCtx, CTX, 4, takectrl_get_ctrl_timeout );
ASN1R_TAG_ADD (aCtx, CTX, 5, takectrl_get_abrt_timeout);
ASN1R_TAG_ADD (aCtx, CTX, 6, takectrl_get_rel_conn_lost);
ASN1R_TAG_ADD (aCtx, CTX | CONSTR, 7, takectrl_app_preempt_cstr );
_ms_set_cs_check (aCtx); /* check for Companion Standard info */
ar_start = aCtx->asn1r_field_ptr;
}
/************************************************************************/
/* takectrl_get_ctrl_timeout */
/* Take control request: decode the relinquish timeout */
/************************************************************************/
static ST_VOID takectrl_get_ctrl_timeout (ASN1_DEC_CTXT *aCtx)
{
MLOG_CDEC0 ("takectrl_get_ctrl_timeou");
req_info->ctrl_timeout_pres = SD_TRUE; /* set relinquish timeout pres */
/* read relinquish timeout from message */
if (asn1r_get_u32 (aCtx, &(req_info->ctrl_timeout)))
asn1r_set_dec_err (aCtx, REQ_BAD_VALUE);
ASN1R_TAG_ADD (aCtx, CTX, 5, takectrl_get_abrt_timeout);
ASN1R_TAG_ADD (aCtx, CTX, 6, takectrl_get_rel_conn_lost);
ASN1R_TAG_ADD (aCtx, CTX | CONSTR, 7, takectrl_app_preempt_cstr );
_ms_set_cs_check (aCtx); /* check for Companion Standard info */
ar_start = aCtx->asn1r_field_ptr;
}
/************************************************************************/
/* takectrl_get_abrt_timeout */
/* Take control request: decode the relinquish if connection lost */
/************************************************************************/
static ST_VOID takectrl_get_abrt_timeout (ASN1_DEC_CTXT *aCtx)
{
MLOG_CDEC0 ("takectrl_get_abrt_timeout");
/* read access key from message */
req_info->abrt_on_timeout_pres = SD_TRUE;
if (asn1r_get_bool (aCtx, &(req_info->abrt_on_timeout)))
asn1r_set_dec_err (aCtx, REQ_BAD_VALUE);
ASN1R_TAG_ADD (aCtx, CTX, 6, takectrl_get_rel_conn_lost);
ASN1R_TAG_ADD (aCtx, CTX | CONSTR, 7, takectrl_app_preempt_cstr );
_ms_set_cs_check (aCtx); /* check for Companion Standard info */
ar_start = aCtx->asn1r_field_ptr;
}
/************************************************************************/
/* takectrl_get_rel_conn_lost */
/* Take control request: decode the relinquish if connection lost */
/************************************************************************/
static ST_VOID takectrl_get_rel_conn_lost (ASN1_DEC_CTXT *aCtx)
{
MLOG_CDEC0 ("takectrl_get_rel_conn_lost");
/* read access key from message */
if (asn1r_get_bool (aCtx, &(req_info->rel_conn_lost)))
asn1r_set_dec_err (aCtx, REQ_BAD_VALUE);
ASN1R_TAG_ADD (aCtx, CTX | CONSTR, 7, takectrl_app_preempt_cstr );
_ms_set_cs_check (aCtx); /* check for Companion Standard info */
ar_start = aCtx->asn1r_field_ptr;
}
/************************************************************************/
/* takectrl_app_preempt_cstr */
/* Decoding take control request: application to preempt constr was */
/* encountered. */
/************************************************************************/
static ST_VOID takectrl_app_preempt_cstr (ASN1_DEC_CTXT *aCtx)
{
MLOG_CDEC0 ("takectrl_app_preempt_cstr");
req_info->app_preempt_pres = SD_TRUE; /* set app preempt present */
req_info->app_preempt = ar_start; /* save_start */
*ar_start = '\x30'; /* change tag */
if (aCtx->asn1r_elmnt_len)
asn1r_parse_cstr_contents (aCtx, app_preempt_cstr_done);
else
aCtx->asn1r_c_done_fun[ aCtx->asn1r_msg_level ] = app_preempt_cstr_done;
}
/************************************************************************/
/* app_preempt_cstr_done */
/* Decoding take control request: application preempt was encountered. */
/************************************************************************/
static ST_VOID app_preempt_cstr_done (ASN1_DEC_CTXT *aCtx)
{
MLOG_CDEC0 ("app_preempt_cstr_done");
req_info->app_len = aCtx->asn1r_field_ptr - ar_start;
_ms_set_cs_check (aCtx); /* check for Companion Standard info */
}
#ifndef MMS_LITE
/************************************************************************/
/************************************************************************/
/* mp_takectrl_resp */
/* This function is called from either the application or the virtual */
/* machine to ENCODE and send the take control response. */
/************************************************************************/
ST_RET mp_takectrl_resp (MMSREQ_IND *indptr, TAKECTRL_RESP_INFO *info_ptr)
{
return (_mms_resp_send (MMSOP_TAKE_CONTROL,indptr,
M_CAST_MK_FUN (_ms_mk_takectrl_resp),
(ST_CHAR *)info_ptr));
}
#else
/************************************************************************/
/************************************************************************/
/* mpl_takectrl_resp */
/* This function is called from either the application or the virtual */
/* machine to ENCODE the take control response. */
/************************************************************************/
ST_RET mpl_takectrl_resp (ST_UINT32 invoke_id,
TAKECTRL_RESP_INFO *info_ptr)
{
return (_mms_resp_fin (MMSOP_TAKE_CONTROL,invoke_id,
M_CAST_MK_FUN (_ms_mk_takectrl_resp),
(ST_CHAR *)info_ptr));
}
#endif
/************************************************************************/
/************************************************************************/
/* _ms_mk_takectrl_resp */
/* Construct a take control response. */
/************************************************************************/
ST_VOID _ms_mk_takectrl_resp (ASN1_ENC_CTXT *aCtx, TAKECTRL_RESP_INFO *info)
{
if (info->resp_tag == SD_FALSE)
{ /* response is NULL */
asn1r_fin_prim (aCtx, 0,CTX);
}
else if (info->resp_tag == SD_TRUE)
{ /* response is a named token */
asn1r_wr_vstr (aCtx, info->named_token); /* write the named token */
asn1r_fin_prim (aCtx, 1,CTX);
}
/* write the context specific explicit tag for this opcode. */
asn1r_fin_constr (aCtx, MMSOP_TAKE_CONTROL,CTX,DEF); /* tag = opcode, ctx constr */
}