/* * Please do not edit this file. * It was generated using rpcgen. */ #include "kwarnd.h" #include #include /* getenv, exit */ #include #include #include #include #include /* rlimit */ #include #ifdef DEBUG #define RPC_SVC_FG #endif #define _RPCSVC_CLOSEDOWN 120 /* * Copyright 1990-2002 Sun Microsystems, Inc. All rights reserved. * Use is subject to license terms. */ #include #include #include #include extern int _rpcpmstart; /* Started by a port monitor ? */ /* States a server can be in wrt request */ #define _IDLE 0 #define _SERVED 1 /* LINTED static unused if no main */ static int _rpcsvcstate = _IDLE; /* Set when a request is serviced */ static int _rpcsvccount = 0; /* Number of requests being serviced */ mutex_t _svcstate_lock; /* lock for _rpcsvcstate, _rpcsvccount */ #if defined(RPC_MSGOUT) extern void RPC_MSGOUT(); #else /* defined(RPC_MSGOUT) */ static void RPC_MSGOUT(fmt, msg) char *fmt; char *msg; { #ifdef RPC_SVC_FG if (_rpcpmstart) syslog(LOG_ERR, fmt, msg); else { (void) fprintf(stderr, fmt, msg); (void) putc('\n', stderr); } #else syslog(LOG_ERR, fmt, msg); #endif } #endif /* defined(RPC_MSGOUT) */ void kwarnprog_1(rqstp, transp) struct svc_req *rqstp; register SVCXPRT *transp; { union { kwarn_add_warning_arg kwarn_add_warning_1_arg; kwarn_del_warning_arg kwarn_del_warning_1_arg; } argument; union { kwarn_add_warning_res kwarn_add_warning_1_res; kwarn_del_warning_res kwarn_del_warning_1_res; } result; bool_t retval; bool_t (*_xdr_argument)(), (*_xdr_result)(); bool_t (*local)(); (void) mutex_lock(&_svcstate_lock); _rpcsvccount++; (void) mutex_unlock(&_svcstate_lock); switch (rqstp->rq_proc) { case NULLPROC: (void) svc_sendreply(transp, xdr_void, NULL); (void) mutex_lock(&_svcstate_lock); _rpcsvccount--; _rpcsvcstate = _SERVED; (void) mutex_unlock(&_svcstate_lock); return; /* CSTYLED */ case KWARN_ADD_WARNING: _xdr_argument = xdr_kwarn_add_warning_arg; _xdr_result = xdr_kwarn_add_warning_res; local = (bool_t (*)()) kwarn_add_warning_1_svc; break; case KWARN_DEL_WARNING: _xdr_argument = xdr_kwarn_del_warning_arg; _xdr_result = xdr_kwarn_del_warning_res; local = (bool_t (*)()) kwarn_del_warning_1_svc; break; default: svcerr_noproc(transp); (void) mutex_lock(&_svcstate_lock); _rpcsvccount--; _rpcsvcstate = _SERVED; (void) mutex_unlock(&_svcstate_lock); return; /* CSTYLED */ } (void) memset((char *)&argument, 0, sizeof (argument)); if (!svc_getargs(transp, _xdr_argument, (caddr_t)&argument)) { svcerr_decode(transp); (void) mutex_lock(&_svcstate_lock); _rpcsvccount--; _rpcsvcstate = _SERVED; (void) mutex_unlock(&_svcstate_lock); return; /* CSTYLED */ } retval = (bool_t)(*local)(&argument, &result, rqstp); if (_xdr_result && retval > 0 && !svc_sendreply(transp, _xdr_result, (char *)&result)) { svcerr_systemerr(transp); } if (!svc_freeargs(transp, _xdr_argument, (caddr_t)&argument)) { RPC_MSGOUT("%s", "unable to free arguments"); exit(1); } if (_xdr_result != NULL) { if (!kwarnprog_1_freeresult(transp, _xdr_result, (caddr_t)&result)) RPC_MSGOUT("%s", "unable to free results"); } (void) mutex_lock(&_svcstate_lock); _rpcsvccount--; _rpcsvcstate = _SERVED; (void) mutex_unlock(&_svcstate_lock); return; /* CSTYLED */ }