134 lines
4.4 KiB
C
134 lines
4.4 KiB
C
/************************************************************************/
|
|
/* SISCO SOFTWARE MODULE HEADER *****************************************/
|
|
/************************************************************************/
|
|
/* (c) Copyright Systems Integration Specialists Company, Inc., */
|
|
/* 1998 - 1998, All Rights Reserved */
|
|
/* */
|
|
/* MODULE NAME : c_status.c */
|
|
/* PRODUCT(S) : MMSEASE-LITE */
|
|
/* */
|
|
/* MODULE DESCRIPTION : */
|
|
/* */
|
|
/* GLOBAL FUNCTIONS DEFINED IN THIS MODULE : */
|
|
/* mvl_status */
|
|
/* mvla_status */
|
|
/* _mvl_process_status_conf */
|
|
/* */
|
|
/* MODIFICATION LOG : */
|
|
/* Date Who Rev Comments */
|
|
/* -------- --- ------ ------------------------------------------- */
|
|
/* 04/09/07 MDE 13 Enhanced filtered logging */
|
|
/* 11/01/01 JRB 12 mvl_wait_req_done now returns ST_RET. */
|
|
/* 09/21/01 JRB 11 Alloc global bufs only once at startup. */
|
|
/* 03/07/01 JRB 10 Del LOCK on sync functs: caused deadlocks. */
|
|
/* 03/08/00 JRB 09 Del #ifdef MVL_REQ_BUF_ENABLED: not used. */
|
|
/* Del mvl_free_req_ctrl call. User must call. */
|
|
/* Del invoke_id, numpend_req: see mvl_send_req.*/
|
|
/* 01/21/00 MDE 08 Now use MEM_SMEM for dynamic memory */
|
|
/* 01/21/00 MDE 07 Use '_mvl_get_req_buf' for MVL_REQ_BUF_EN.. */
|
|
/* 11/19/99 NAV 06 Add #ifdef MVL_REQ_BUF_ENABLED */
|
|
/* 10/20/99 NAV 05 Add maxpend_req support to aynsc functions */
|
|
/* 09/13/99 MDE 04 Added SD_CONST modifiers */
|
|
/* 11/17/98 MDE 03 Now use MVL_ERR_COMM_SERVE_ACTIVE error code */
|
|
/* Use MVL_SYNC_REQ_INTERFACE */
|
|
/* 11/16/98 MDE 02 Renamed internal functions (prefix '_') */
|
|
/* 10/05/98 DWL 01 Created from c_getnam.c */
|
|
/************************************************************************/
|
|
|
|
#include "glbtypes.h"
|
|
#include "sysincs.h"
|
|
#include "glbsem.h"
|
|
|
|
#include "mmsdefs.h"
|
|
#include "mms_pvmd.h"
|
|
#include "mvl_defs.h"
|
|
#include "mvl_log.h"
|
|
|
|
/************************************************************************/
|
|
/* For debug version, use a static pointer to avoid duplication of */
|
|
/* __FILE__ strings. */
|
|
/************************************************************************/
|
|
|
|
#ifdef DEBUG_SISCO
|
|
SD_CONST static ST_CHAR *SD_CONST thisFileName = __FILE__;
|
|
#endif
|
|
|
|
/************************************************************************/
|
|
/* mvl_status */
|
|
/************************************************************************/
|
|
|
|
#if defined(MVL_SYNC_REQ_INTERFACE)
|
|
|
|
ST_RET mvl_status (
|
|
MVL_NET_INFO *net_info,
|
|
STATUS_REQ_INFO *req_info,
|
|
MVL_REQ_PEND **req_out)
|
|
{
|
|
ST_RET rc;
|
|
|
|
if (_mvl_comm_serve_active == SD_TRUE)
|
|
{
|
|
MVL_LOG_NERR0 ("Error: mvl_comm_serv active");
|
|
return (MVL_ERR_COMM_SERVE_ACTIVE);
|
|
}
|
|
|
|
rc = mvla_status (net_info, req_info, req_out);
|
|
if (rc == SD_SUCCESS)
|
|
rc = mvl_wait_req_done (*req_out);
|
|
return (rc);
|
|
}
|
|
|
|
#endif
|
|
|
|
/************************************************************************/
|
|
/* mvla_status */
|
|
/************************************************************************/
|
|
|
|
ST_RET mvla_status (
|
|
MVL_NET_INFO *net_info,
|
|
STATUS_REQ_INFO *req_info,
|
|
MVL_REQ_PEND **req_out)
|
|
{
|
|
ST_RET rc;
|
|
MVL_REQ_PEND *req_pend;
|
|
|
|
*req_out = req_pend = _mvl_get_req_ctrl (net_info, MMSOP_STATUS);
|
|
if (!req_pend)
|
|
return (MVL_ERR_REQ_CONTROL);
|
|
|
|
S_LOCK_COMMON_RESOURCES ();
|
|
rc = _mvla_send_status (net_info, req_info, req_pend);
|
|
S_UNLOCK_COMMON_RESOURCES ();
|
|
return (rc);
|
|
}
|
|
|
|
/************************************************************************/
|
|
/* _mvla_send_status */
|
|
/************************************************************************/
|
|
|
|
ST_RET _mvla_send_status (MVL_NET_INFO *net_info,
|
|
STATUS_REQ_INFO *req_info,
|
|
MVL_REQ_PEND *req_pend)
|
|
{
|
|
ST_RET rc;
|
|
|
|
/* Build a getvar request */
|
|
rc = mpl_status (req_info);
|
|
if (rc == SD_SUCCESS)
|
|
mpl_req_log (req_pend, req_info);
|
|
|
|
rc = _mvl_send_req (net_info, req_pend, rc);
|
|
return (rc);
|
|
|
|
}
|
|
/************************************************************************/
|
|
/* _mvl_process_status_conf */
|
|
/************************************************************************/
|
|
|
|
ST_VOID _mvl_process_status_conf (MVL_REQ_PEND *req_pend)
|
|
{
|
|
req_pend->u.status.resp_info =
|
|
(STATUS_RESP_INFO *) req_pend->event->u.mms.dec_rslt.data_ptr;
|
|
}
|
|
|