/* * Please do not edit this file. * It was generated using rpcgen. */ #include "rstat.h" #include #include /* getenv, exit */ #include #include /* for pmap_unset */ #include /* strcmp */ #include /* setsid */ #include #include #include #include /* rlimit */ #include #ifndef SIG_PF #define SIG_PF void(*)(int) #endif #ifdef DEBUG #define RPC_SVC_FG #endif #define _RPCSVC_CLOSEDOWN 120 /* * Copyright (c) 1985, 1990, 1991 by Sun Microsystems, Inc. */ /* from rstat.x */ /* * Server side stub routines for the rstat daemon */ 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 */ #if defined(RPC_MSGOUT) extern void RPC_MSGOUT(const char *, ...); #else /* defined(RPC_MSGOUT) */ static void RPC_MSGOUT(const 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 rstatprog_4(struct svc_req *rqstp, register SVCXPRT *transp) { union { int fill; } argument; char *result; xdrproc_t _xdr_argument, _xdr_result; char *(*local)(char *, struct svc_req *); _rpcsvccount++; switch (rqstp->rq_proc) { case NULLPROC: (void) svc_sendreply(transp, (xdrproc_t)xdr_void, NULL); _rpcsvccount--; _rpcsvcstate = _SERVED; return; /* CSTYLED */ case RSTATPROC_STATS: _xdr_argument = (xdrproc_t) xdr_void; _xdr_result = (xdrproc_t) xdr_statsvar; local = (char *(*)(char *, struct svc_req *)) rstatproc_stats_4_svc; break; case RSTATPROC_HAVEDISK: _xdr_argument = (xdrproc_t) xdr_void; _xdr_result = (xdrproc_t) xdr_u_int; local = (char *(*)(char *, struct svc_req *)) rstatproc_havedisk_4_svc; break; default: svcerr_noproc(transp); _rpcsvccount--; _rpcsvcstate = _SERVED; return; /* CSTYLED */ } (void) memset((char *)&argument, 0, sizeof (argument)); if (!svc_getargs(transp, _xdr_argument, (caddr_t)&argument)) { svcerr_decode(transp); _rpcsvccount--; _rpcsvcstate = _SERVED; return; /* CSTYLED */ } result = (*local)((char *)&argument, rqstp); if (_xdr_result && result != NULL && !svc_sendreply(transp, _xdr_result, result)) { svcerr_systemerr(transp); } if (!svc_freeargs(transp, _xdr_argument, (caddr_t)&argument)) { RPC_MSGOUT("%s", "unable to free arguments"); exit(1); } _rpcsvccount--; _rpcsvcstate = _SERVED; return; /* CSTYLED */ } void rstatprog_3(struct svc_req *rqstp, register SVCXPRT *transp) { union { int fill; } argument; char *result; xdrproc_t _xdr_argument, _xdr_result; char *(*local)(char *, struct svc_req *); _rpcsvccount++; switch (rqstp->rq_proc) { case NULLPROC: (void) svc_sendreply(transp, (xdrproc_t)xdr_void, NULL); _rpcsvccount--; _rpcsvcstate = _SERVED; return; /* CSTYLED */ case RSTATPROC_STATS: _xdr_argument = (xdrproc_t) xdr_void; _xdr_result = (xdrproc_t) xdr_statstime; local = (char *(*)(char *, struct svc_req *)) rstatproc_stats_3_svc; break; case RSTATPROC_HAVEDISK: _xdr_argument = (xdrproc_t) xdr_void; _xdr_result = (xdrproc_t) xdr_u_int; local = (char *(*)(char *, struct svc_req *)) rstatproc_havedisk_3_svc; break; default: svcerr_noproc(transp); _rpcsvccount--; _rpcsvcstate = _SERVED; return; /* CSTYLED */ } (void) memset((char *)&argument, 0, sizeof (argument)); if (!svc_getargs(transp, _xdr_argument, (caddr_t)&argument)) { svcerr_decode(transp); _rpcsvccount--; _rpcsvcstate = _SERVED; return; /* CSTYLED */ } result = (*local)((char *)&argument, rqstp); if (_xdr_result && result != NULL && !svc_sendreply(transp, _xdr_result, result)) { svcerr_systemerr(transp); } if (!svc_freeargs(transp, _xdr_argument, (caddr_t)&argument)) { RPC_MSGOUT("%s", "unable to free arguments"); exit(1); } _rpcsvccount--; _rpcsvcstate = _SERVED; return; /* CSTYLED */ }