/* * Please do not edit this file. * It was generated using rpcgen. */ #include #include #include "mc1.h" static void mcprog_1(); static int count = 0; main() { register SVCXPRT *transp; (void) pmap_unset(MCPROG, MCVERS); transp = svcudp_create(RPC_ANYSOCK); if (transp == NULL) { fprintf(stderr, "cannot create udp service."); exit(1); } if (!svc_register(transp, MCPROG, MCVERS, mcprog_1, IPPROTO_UDP)) { fprintf(stderr, "unable to register (MCPROG, MCVERS, udp)."); exit(1); } transp = svctcp_create(RPC_ANYSOCK, 0, 0); if (transp == NULL) { fprintf(stderr, "cannot create tcp service."); exit(1); } if (!svc_register(transp, MCPROG, MCVERS, mcprog_1, IPPROTO_TCP)) { fprintf(stderr, "unable to register (MCPROG, MCVERS, tcp)."); exit(1); } svc_run(); fprintf(stderr, "svc_run returned"); exit(1); /* NOTREACHED */ } static void mcprog_1(rqstp, transp) struct svc_req *rqstp; register SVCXPRT *transp; { union { mypair add_1_arg; mypair subtract_1_arg; } argument; char *result; bool_t (*xdr_argument)(), (*xdr_result)(); char *(*local)(); switch (rqstp->rq_proc) { case NULLPROC: (void) svc_sendreply(transp, xdr_void, (char *)NULL); return; case ADD: xdr_argument = xdr_mypair; xdr_result = xdr_int; local = (char *(*)()) add_1; break; case SUBTRACT: xdr_argument = xdr_mypair; xdr_result = xdr_int; local = (char *(*)()) subtract_1; break; default: svcerr_noproc(transp); return; } bzero((char *)&argument, sizeof(argument)); if (!svc_getargs(transp, xdr_argument, &argument)) { svcerr_decode(transp); return; } count++; printf("The count is now %d\n", count); if(fork())return; /* Here the parent returns to the main routine */ /* We are now in the child process */ result = (*local)(&argument, rqstp); if (result != NULL && !svc_sendreply(transp, xdr_result, result)) { svcerr_systemerr(transp); } if (!svc_freeargs(transp, xdr_argument, &argument)) { fprintf(stderr, "unable to free arguments"); exit(1); } exit(0); }