]> git.decadent.org.uk Git - nfs-utils.git/blob - support/nsm/sm_inter_svc.c
Merge branch 'sid'
[nfs-utils.git] / support / nsm / sm_inter_svc.c
1 /*
2  * Please do not edit this file.
3  * It was generated using rpcgen.
4  */
5
6 #include "sm_inter.h"
7 #include <stdio.h>
8 #include <stdlib.h>
9 #include <rpc/pmap_clnt.h>
10 #include <string.h>
11 #include <memory.h>
12 #include <sys/socket.h>
13 #include <netinet/in.h>
14
15 #ifndef SIG_PF
16 #define SIG_PF void(*)(int)
17 #endif
18 #define SM_INTER_X
19
20 void
21 sm_prog_1(struct svc_req *rqstp, register SVCXPRT *transp)
22 {
23         union {
24                 struct sm_name sm_stat_1_arg;
25                 struct mon sm_mon_1_arg;
26                 struct mon_id sm_unmon_1_arg;
27                 struct my_id sm_unmon_all_1_arg;
28                 struct stat_chge sm_notify_1_arg;
29         } argument;
30         char *result;
31         xdrproc_t _xdr_argument, _xdr_result;
32         char *(*local)(char *, struct svc_req *);
33
34         switch (rqstp->rq_proc) {
35         case NULLPROC:
36                 (void) svc_sendreply (transp, (xdrproc_t) xdr_void, (char *)NULL);
37                 return;
38
39         case SM_STAT:
40                 _xdr_argument = (xdrproc_t) xdr_sm_name;
41                 _xdr_result = (xdrproc_t) xdr_sm_stat_res;
42                 local = (char *(*)(char *, struct svc_req *)) sm_stat_1_svc;
43                 break;
44
45         case SM_MON:
46                 _xdr_argument = (xdrproc_t) xdr_mon;
47                 _xdr_result = (xdrproc_t) xdr_sm_stat_res;
48                 local = (char *(*)(char *, struct svc_req *)) sm_mon_1_svc;
49                 break;
50
51         case SM_UNMON:
52                 _xdr_argument = (xdrproc_t) xdr_mon_id;
53                 _xdr_result = (xdrproc_t) xdr_sm_stat;
54                 local = (char *(*)(char *, struct svc_req *)) sm_unmon_1_svc;
55                 break;
56
57         case SM_UNMON_ALL:
58                 _xdr_argument = (xdrproc_t) xdr_my_id;
59                 _xdr_result = (xdrproc_t) xdr_sm_stat;
60                 local = (char *(*)(char *, struct svc_req *)) sm_unmon_all_1_svc;
61                 break;
62
63         case SM_SIMU_CRASH:
64                 _xdr_argument = (xdrproc_t) xdr_void;
65                 _xdr_result = (xdrproc_t) xdr_void;
66                 local = (char *(*)(char *, struct svc_req *)) sm_simu_crash_1_svc;
67                 break;
68
69         case SM_NOTIFY:
70                 _xdr_argument = (xdrproc_t) xdr_stat_chge;
71                 _xdr_result = (xdrproc_t) xdr_void;
72                 local = (char *(*)(char *, struct svc_req *)) sm_notify_1_svc;
73                 break;
74
75         default:
76                 svcerr_noproc (transp);
77                 return;
78         }
79         memset ((char *)&argument, 0, sizeof (argument));
80         if (!svc_getargs (transp, (xdrproc_t) _xdr_argument, (caddr_t) &argument)) {
81                 svcerr_decode (transp);
82                 return;
83         }
84         result = (*local)((char *)&argument, rqstp);
85         if (result != NULL && !svc_sendreply(transp, (xdrproc_t) _xdr_result, result)) {
86                 svcerr_systemerr (transp);
87         }
88         if (!svc_freeargs (transp, (xdrproc_t) _xdr_argument, (caddr_t) &argument)) {
89                 fprintf (stderr, "%s", "unable to free arguments");
90                 exit (1);
91         }
92         return;
93 }