1/*-
2 * Copyright (c) 2008 Isilon Inc http://www.isilon.com/
3 * Authors: Doug Rabson <dfr@rabson.org>
4 * Developed with Red Inc: Alfred Perlstein <alfred@freebsd.org>
5 *
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that the following conditions
8 * are met:
9 * 1. Redistributions of source code must retain the above copyright
10 *    notice, this list of conditions and the following disclaimer.
11 * 2. Redistributions in binary form must reproduce the above copyright
12 *    notice, this list of conditions and the following disclaimer in the
13 *    documentation and/or other materials provided with the distribution.
14 *
15 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
16 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
17 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
18 * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
19 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
20 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
21 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
22 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
23 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
24 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
25 * SUCH DAMAGE.
26 */
27
28#include <sys/param.h>
29#include <sys/systm.h>
30
31#include <nlm/nlm_prot.h>
32#include <nlm/nlm.h>
33
34#include <sys/cdefs.h>
35#ifndef lint
36/*static char sccsid[] = "from: @(#)nlm_prot.x 1.8 87/09/21 Copyr 1987 Sun Micro";*/
37/*static char sccsid[] = "from: * @(#)nlm_prot.x	2.1 88/08/01 4.0 RPCSRC";*/
38__RCSID("$NetBSD: nlm_prot.x,v 1.6 2000/06/07 14:30:15 bouyer Exp $");
39#endif /* not lint */
40__FBSDID("$FreeBSD$");
41
42void nlm_prog_0(struct svc_req *rqstp, SVCXPRT *transp);
43void nlm_prog_1(struct svc_req *rqstp, SVCXPRT *transp);
44void nlm_prog_3(struct svc_req *rqstp, SVCXPRT *transp);
45void nlm_prog_4(struct svc_req *rqstp, SVCXPRT *transp);
46
47void
48nlm_prog_0(struct svc_req *rqstp, SVCXPRT *transp)
49{
50	union {
51		struct nlm_sm_status nlm_sm_notify_0_arg;
52	} argument;
53	char result;
54	bool_t retval;
55	xdrproc_t xdr_argument, xdr_result;
56	bool_t (*local)(char *, void *, struct svc_req *);
57
58	switch (rqstp->rq_proc) {
59	case NULLPROC:
60		(void) svc_sendreply(rqstp,
61			(xdrproc_t) xdr_void, (char *)NULL);
62		svc_freereq(rqstp);
63		return;
64
65	case NLM_SM_NOTIFY:
66		xdr_argument = (xdrproc_t) xdr_nlm_sm_status;
67		xdr_result = (xdrproc_t) xdr_void;
68		local = (bool_t (*) (char *,  void *,  struct svc_req *))nlm_sm_notify_0_svc;
69		break;
70
71	default:
72		svcerr_noproc(rqstp);
73		svc_freereq(rqstp);
74		return;
75	}
76	(void) memset((char *)&argument, 0, sizeof (argument));
77	if (!svc_getargs(rqstp, xdr_argument, (char *)(caddr_t) &argument)) {
78		svcerr_decode(rqstp);
79		svc_freereq(rqstp);
80		return;
81	}
82	retval = (bool_t) (*local)((char *)&argument, (void *)&result, rqstp);
83	if (retval > 0 && !svc_sendreply(rqstp, xdr_result, (char *)&result)) {
84		svcerr_systemerr(rqstp);
85	}
86	if (!svc_freeargs(rqstp, xdr_argument, (char *)(caddr_t) &argument)) {
87		printf("unable to free arguments");
88		//exit(1);
89	}
90	svc_freereq(rqstp);
91
92	return;
93}
94
95void
96nlm_prog_1(struct svc_req *rqstp, SVCXPRT *transp)
97{
98	union {
99		struct nlm_testargs nlm_test_1_arg;
100		struct nlm_lockargs nlm_lock_1_arg;
101		struct nlm_cancargs nlm_cancel_1_arg;
102		struct nlm_unlockargs nlm_unlock_1_arg;
103		struct nlm_testargs nlm_granted_1_arg;
104		struct nlm_testargs nlm_test_msg_1_arg;
105		struct nlm_lockargs nlm_lock_msg_1_arg;
106		struct nlm_cancargs nlm_cancel_msg_1_arg;
107		struct nlm_unlockargs nlm_unlock_msg_1_arg;
108		struct nlm_testargs nlm_granted_msg_1_arg;
109		nlm_testres nlm_test_res_1_arg;
110		nlm_res nlm_lock_res_1_arg;
111		nlm_res nlm_cancel_res_1_arg;
112		nlm_res nlm_unlock_res_1_arg;
113		nlm_res nlm_granted_res_1_arg;
114	} argument;
115	union {
116		nlm_testres nlm_test_1_res;
117		nlm_res nlm_lock_1_res;
118		nlm_res nlm_cancel_1_res;
119		nlm_res nlm_unlock_1_res;
120		nlm_res nlm_granted_1_res;
121	} result;
122	bool_t retval;
123	xdrproc_t xdr_argument, xdr_result;
124	bool_t (*local)(char *, void *, struct svc_req *);
125
126	switch (rqstp->rq_proc) {
127	case NULLPROC:
128		(void) svc_sendreply(rqstp,
129			(xdrproc_t) xdr_void, (char *)NULL);
130		svc_freereq(rqstp);
131		return;
132
133	case NLM_TEST:
134		xdr_argument = (xdrproc_t) xdr_nlm_testargs;
135		xdr_result = (xdrproc_t) xdr_nlm_testres;
136		local = (bool_t (*) (char *,  void *,  struct svc_req *))nlm_test_1_svc;
137		break;
138
139	case NLM_LOCK:
140		xdr_argument = (xdrproc_t) xdr_nlm_lockargs;
141		xdr_result = (xdrproc_t) xdr_nlm_res;
142		local = (bool_t (*) (char *,  void *,  struct svc_req *))nlm_lock_1_svc;
143		break;
144
145	case NLM_CANCEL:
146		xdr_argument = (xdrproc_t) xdr_nlm_cancargs;
147		xdr_result = (xdrproc_t) xdr_nlm_res;
148		local = (bool_t (*) (char *,  void *,  struct svc_req *))nlm_cancel_1_svc;
149		break;
150
151	case NLM_UNLOCK:
152		xdr_argument = (xdrproc_t) xdr_nlm_unlockargs;
153		xdr_result = (xdrproc_t) xdr_nlm_res;
154		local = (bool_t (*) (char *,  void *,  struct svc_req *))nlm_unlock_1_svc;
155		break;
156
157	case NLM_GRANTED:
158		xdr_argument = (xdrproc_t) xdr_nlm_testargs;
159		xdr_result = (xdrproc_t) xdr_nlm_res;
160		local = (bool_t (*) (char *,  void *,  struct svc_req *))nlm_granted_1_svc;
161		break;
162
163	case NLM_TEST_MSG:
164		xdr_argument = (xdrproc_t) xdr_nlm_testargs;
165		xdr_result = (xdrproc_t) xdr_void;
166		local = (bool_t (*) (char *,  void *,  struct svc_req *))nlm_test_msg_1_svc;
167		break;
168
169	case NLM_LOCK_MSG:
170		xdr_argument = (xdrproc_t) xdr_nlm_lockargs;
171		xdr_result = (xdrproc_t) xdr_void;
172		local = (bool_t (*) (char *,  void *,  struct svc_req *))nlm_lock_msg_1_svc;
173		break;
174
175	case NLM_CANCEL_MSG:
176		xdr_argument = (xdrproc_t) xdr_nlm_cancargs;
177		xdr_result = (xdrproc_t) xdr_void;
178		local = (bool_t (*) (char *,  void *,  struct svc_req *))nlm_cancel_msg_1_svc;
179		break;
180
181	case NLM_UNLOCK_MSG:
182		xdr_argument = (xdrproc_t) xdr_nlm_unlockargs;
183		xdr_result = (xdrproc_t) xdr_void;
184		local = (bool_t (*) (char *,  void *,  struct svc_req *))nlm_unlock_msg_1_svc;
185		break;
186
187	case NLM_GRANTED_MSG:
188		xdr_argument = (xdrproc_t) xdr_nlm_testargs;
189		xdr_result = (xdrproc_t) xdr_void;
190		local = (bool_t (*) (char *,  void *,  struct svc_req *))nlm_granted_msg_1_svc;
191		break;
192
193	case NLM_TEST_RES:
194		xdr_argument = (xdrproc_t) xdr_nlm_testres;
195		xdr_result = (xdrproc_t) xdr_void;
196		local = (bool_t (*) (char *,  void *,  struct svc_req *))nlm_test_res_1_svc;
197		break;
198
199	case NLM_LOCK_RES:
200		xdr_argument = (xdrproc_t) xdr_nlm_res;
201		xdr_result = (xdrproc_t) xdr_void;
202		local = (bool_t (*) (char *,  void *,  struct svc_req *))nlm_lock_res_1_svc;
203		break;
204
205	case NLM_CANCEL_RES:
206		xdr_argument = (xdrproc_t) xdr_nlm_res;
207		xdr_result = (xdrproc_t) xdr_void;
208		local = (bool_t (*) (char *,  void *,  struct svc_req *))nlm_cancel_res_1_svc;
209		break;
210
211	case NLM_UNLOCK_RES:
212		xdr_argument = (xdrproc_t) xdr_nlm_res;
213		xdr_result = (xdrproc_t) xdr_void;
214		local = (bool_t (*) (char *,  void *,  struct svc_req *))nlm_unlock_res_1_svc;
215		break;
216
217	case NLM_GRANTED_RES:
218		xdr_argument = (xdrproc_t) xdr_nlm_res;
219		xdr_result = (xdrproc_t) xdr_void;
220		local = (bool_t (*) (char *,  void *,  struct svc_req *))nlm_granted_res_1_svc;
221		break;
222
223	default:
224		svcerr_noproc(rqstp);
225		svc_freereq(rqstp);
226		return;
227	}
228	(void) memset((char *)&argument, 0, sizeof (argument));
229	if (!svc_getargs(rqstp, xdr_argument, (char *)(caddr_t) &argument)) {
230		svcerr_decode(rqstp);
231		svc_freereq(rqstp);
232		return;
233	}
234	retval = (bool_t) (*local)((char *)&argument, (void *)&result, rqstp);
235	if (retval > 0 && !svc_sendreply(rqstp, xdr_result, (char *)&result)) {
236		svcerr_systemerr(rqstp);
237	}
238	if (!svc_freeargs(rqstp, xdr_argument, (char *)(caddr_t) &argument)) {
239		printf("unable to free arguments");
240		//exit(1);
241	}
242	svc_freereq(rqstp);
243	if (!nlm_prog_1_freeresult(transp, xdr_result, (caddr_t) &result))
244		printf("unable to free results");
245
246	return;
247}
248
249void
250nlm_prog_3(struct svc_req *rqstp, SVCXPRT *transp)
251{
252	union {
253		nlm_shareargs nlm_share_3_arg;
254		nlm_shareargs nlm_unshare_3_arg;
255		nlm_lockargs nlm_nm_lock_3_arg;
256		nlm_notify nlm_free_all_3_arg;
257	} argument;
258	union {
259		nlm_shareres nlm_share_3_res;
260		nlm_shareres nlm_unshare_3_res;
261		nlm_res nlm_nm_lock_3_res;
262	} result;
263	bool_t retval;
264	xdrproc_t xdr_argument, xdr_result;
265	bool_t (*local)(char *, void *, struct svc_req *);
266
267	switch (rqstp->rq_proc) {
268	case NULLPROC:
269		(void) svc_sendreply(rqstp,
270			(xdrproc_t) xdr_void, (char *)NULL);
271		svc_freereq(rqstp);
272		return;
273
274	case NLM_TEST:
275	case NLM_LOCK:
276	case NLM_CANCEL:
277	case NLM_UNLOCK:
278	case NLM_GRANTED:
279	case NLM_TEST_MSG:
280	case NLM_LOCK_MSG:
281	case NLM_CANCEL_MSG:
282	case NLM_UNLOCK_MSG:
283	case NLM_GRANTED_MSG:
284	case NLM_TEST_RES:
285	case NLM_LOCK_RES:
286	case NLM_CANCEL_RES:
287	case NLM_UNLOCK_RES:
288	case NLM_GRANTED_RES:
289		nlm_prog_1(rqstp, transp);
290		return;
291
292	case NLM_SHARE:
293		xdr_argument = (xdrproc_t) xdr_nlm_shareargs;
294		xdr_result = (xdrproc_t) xdr_nlm_shareres;
295		local = (bool_t (*) (char *,  void *,  struct svc_req *))nlm_share_3_svc;
296		break;
297
298	case NLM_UNSHARE:
299		xdr_argument = (xdrproc_t) xdr_nlm_shareargs;
300		xdr_result = (xdrproc_t) xdr_nlm_shareres;
301		local = (bool_t (*) (char *,  void *,  struct svc_req *))nlm_unshare_3_svc;
302		break;
303
304	case NLM_NM_LOCK:
305		xdr_argument = (xdrproc_t) xdr_nlm_lockargs;
306		xdr_result = (xdrproc_t) xdr_nlm_res;
307		local = (bool_t (*) (char *,  void *,  struct svc_req *))nlm_nm_lock_3_svc;
308		break;
309
310	case NLM_FREE_ALL:
311		xdr_argument = (xdrproc_t) xdr_nlm_notify;
312		xdr_result = (xdrproc_t) xdr_void;
313		local = (bool_t (*) (char *,  void *,  struct svc_req *))nlm_free_all_3_svc;
314		break;
315
316	default:
317		svcerr_noproc(rqstp);
318		svc_freereq(rqstp);
319		return;
320	}
321	(void) memset((char *)&argument, 0, sizeof (argument));
322	if (!svc_getargs(rqstp, xdr_argument, (char *)(caddr_t) &argument)) {
323		svcerr_decode(rqstp);
324		svc_freereq(rqstp);
325		return;
326	}
327	retval = (bool_t) (*local)((char *)&argument, (void *)&result, rqstp);
328	if (retval > 0 && !svc_sendreply(rqstp, xdr_result, (char *)&result)) {
329		svcerr_systemerr(rqstp);
330	}
331	if (!svc_freeargs(rqstp, xdr_argument, (char *)(caddr_t) &argument)) {
332		printf("unable to free arguments");
333		//exit(1);
334	}
335	svc_freereq(rqstp);
336	if (!nlm_prog_3_freeresult(transp, xdr_result, (caddr_t) &result))
337		printf("unable to free results");
338
339	return;
340}
341
342void
343nlm_prog_4(struct svc_req *rqstp, SVCXPRT *transp)
344{
345	union {
346		nlm4_testargs nlm4_test_4_arg;
347		nlm4_lockargs nlm4_lock_4_arg;
348		nlm4_cancargs nlm4_cancel_4_arg;
349		nlm4_unlockargs nlm4_unlock_4_arg;
350		nlm4_testargs nlm4_granted_4_arg;
351		nlm4_testargs nlm4_test_msg_4_arg;
352		nlm4_lockargs nlm4_lock_msg_4_arg;
353		nlm4_cancargs nlm4_cancel_msg_4_arg;
354		nlm4_unlockargs nlm4_unlock_msg_4_arg;
355		nlm4_testargs nlm4_granted_msg_4_arg;
356		nlm4_testres nlm4_test_res_4_arg;
357		nlm4_res nlm4_lock_res_4_arg;
358		nlm4_res nlm4_cancel_res_4_arg;
359		nlm4_res nlm4_unlock_res_4_arg;
360		nlm4_res nlm4_granted_res_4_arg;
361		nlm4_shareargs nlm4_share_4_arg;
362		nlm4_shareargs nlm4_unshare_4_arg;
363		nlm4_lockargs nlm4_nm_lock_4_arg;
364		nlm4_notify nlm4_free_all_4_arg;
365	} argument;
366	union {
367		nlm4_testres nlm4_test_4_res;
368		nlm4_res nlm4_lock_4_res;
369		nlm4_res nlm4_cancel_4_res;
370		nlm4_res nlm4_unlock_4_res;
371		nlm4_res nlm4_granted_4_res;
372		nlm4_shareres nlm4_share_4_res;
373		nlm4_shareres nlm4_unshare_4_res;
374		nlm4_res nlm4_nm_lock_4_res;
375	} result;
376	bool_t retval;
377	xdrproc_t xdr_argument, xdr_result;
378	bool_t (*local)(char *, void *, struct svc_req *);
379
380	switch (rqstp->rq_proc) {
381	case NULLPROC:
382		(void) svc_sendreply(rqstp,
383			(xdrproc_t) xdr_void, (char *)NULL);
384		svc_freereq(rqstp);
385		return;
386
387	case NLM4_TEST:
388		xdr_argument = (xdrproc_t) xdr_nlm4_testargs;
389		xdr_result = (xdrproc_t) xdr_nlm4_testres;
390		local = (bool_t (*) (char *,  void *,  struct svc_req *))nlm4_test_4_svc;
391		break;
392
393	case NLM4_LOCK:
394		xdr_argument = (xdrproc_t) xdr_nlm4_lockargs;
395		xdr_result = (xdrproc_t) xdr_nlm4_res;
396		local = (bool_t (*) (char *,  void *,  struct svc_req *))nlm4_lock_4_svc;
397		break;
398
399	case NLM4_CANCEL:
400		xdr_argument = (xdrproc_t) xdr_nlm4_cancargs;
401		xdr_result = (xdrproc_t) xdr_nlm4_res;
402		local = (bool_t (*) (char *,  void *,  struct svc_req *))nlm4_cancel_4_svc;
403		break;
404
405	case NLM4_UNLOCK:
406		xdr_argument = (xdrproc_t) xdr_nlm4_unlockargs;
407		xdr_result = (xdrproc_t) xdr_nlm4_res;
408		local = (bool_t (*) (char *,  void *,  struct svc_req *))nlm4_unlock_4_svc;
409		break;
410
411	case NLM4_GRANTED:
412		xdr_argument = (xdrproc_t) xdr_nlm4_testargs;
413		xdr_result = (xdrproc_t) xdr_nlm4_res;
414		local = (bool_t (*) (char *,  void *,  struct svc_req *))nlm4_granted_4_svc;
415		break;
416
417	case NLM4_TEST_MSG:
418		xdr_argument = (xdrproc_t) xdr_nlm4_testargs;
419		xdr_result = (xdrproc_t) xdr_void;
420		local = (bool_t (*) (char *,  void *,  struct svc_req *))nlm4_test_msg_4_svc;
421		break;
422
423	case NLM4_LOCK_MSG:
424		xdr_argument = (xdrproc_t) xdr_nlm4_lockargs;
425		xdr_result = (xdrproc_t) xdr_void;
426		local = (bool_t (*) (char *,  void *,  struct svc_req *))nlm4_lock_msg_4_svc;
427		break;
428
429	case NLM4_CANCEL_MSG:
430		xdr_argument = (xdrproc_t) xdr_nlm4_cancargs;
431		xdr_result = (xdrproc_t) xdr_void;
432		local = (bool_t (*) (char *,  void *,  struct svc_req *))nlm4_cancel_msg_4_svc;
433		break;
434
435	case NLM4_UNLOCK_MSG:
436		xdr_argument = (xdrproc_t) xdr_nlm4_unlockargs;
437		xdr_result = (xdrproc_t) xdr_void;
438		local = (bool_t (*) (char *,  void *,  struct svc_req *))nlm4_unlock_msg_4_svc;
439		break;
440
441	case NLM4_GRANTED_MSG:
442		xdr_argument = (xdrproc_t) xdr_nlm4_testargs;
443		xdr_result = (xdrproc_t) xdr_void;
444		local = (bool_t (*) (char *,  void *,  struct svc_req *))nlm4_granted_msg_4_svc;
445		break;
446
447	case NLM4_TEST_RES:
448		xdr_argument = (xdrproc_t) xdr_nlm4_testres;
449		xdr_result = (xdrproc_t) xdr_void;
450		local = (bool_t (*) (char *,  void *,  struct svc_req *))nlm4_test_res_4_svc;
451		break;
452
453	case NLM4_LOCK_RES:
454		xdr_argument = (xdrproc_t) xdr_nlm4_res;
455		xdr_result = (xdrproc_t) xdr_void;
456		local = (bool_t (*) (char *,  void *,  struct svc_req *))nlm4_lock_res_4_svc;
457		break;
458
459	case NLM4_CANCEL_RES:
460		xdr_argument = (xdrproc_t) xdr_nlm4_res;
461		xdr_result = (xdrproc_t) xdr_void;
462		local = (bool_t (*) (char *,  void *,  struct svc_req *))nlm4_cancel_res_4_svc;
463		break;
464
465	case NLM4_UNLOCK_RES:
466		xdr_argument = (xdrproc_t) xdr_nlm4_res;
467		xdr_result = (xdrproc_t) xdr_void;
468		local = (bool_t (*) (char *,  void *,  struct svc_req *))nlm4_unlock_res_4_svc;
469		break;
470
471	case NLM4_GRANTED_RES:
472		xdr_argument = (xdrproc_t) xdr_nlm4_res;
473		xdr_result = (xdrproc_t) xdr_void;
474		local = (bool_t (*) (char *,  void *,  struct svc_req *))nlm4_granted_res_4_svc;
475		break;
476
477	case NLM4_SHARE:
478		xdr_argument = (xdrproc_t) xdr_nlm4_shareargs;
479		xdr_result = (xdrproc_t) xdr_nlm4_shareres;
480		local = (bool_t (*) (char *,  void *,  struct svc_req *))nlm4_share_4_svc;
481		break;
482
483	case NLM4_UNSHARE:
484		xdr_argument = (xdrproc_t) xdr_nlm4_shareargs;
485		xdr_result = (xdrproc_t) xdr_nlm4_shareres;
486		local = (bool_t (*) (char *,  void *,  struct svc_req *))nlm4_unshare_4_svc;
487		break;
488
489	case NLM4_NM_LOCK:
490		xdr_argument = (xdrproc_t) xdr_nlm4_lockargs;
491		xdr_result = (xdrproc_t) xdr_nlm4_res;
492		local = (bool_t (*) (char *,  void *,  struct svc_req *))nlm4_nm_lock_4_svc;
493		break;
494
495	case NLM4_FREE_ALL:
496		xdr_argument = (xdrproc_t) xdr_nlm4_notify;
497		xdr_result = (xdrproc_t) xdr_void;
498		local = (bool_t (*) (char *,  void *,  struct svc_req *))nlm4_free_all_4_svc;
499		break;
500
501	default:
502		svcerr_noproc(rqstp);
503		svc_freereq(rqstp);
504		return;
505	}
506	(void) memset((char *)&argument, 0, sizeof (argument));
507	if (!svc_getargs(rqstp, xdr_argument, (char *)(caddr_t) &argument)) {
508		svcerr_decode(rqstp);
509		svc_freereq(rqstp);
510		return;
511	}
512	retval = (bool_t) (*local)((char *)&argument, (void *)&result, rqstp);
513	if (retval > 0 && !svc_sendreply(rqstp, xdr_result, (char *)&result)) {
514		svcerr_systemerr(rqstp);
515	}
516	if (!svc_freeargs(rqstp, xdr_argument, (char *)(caddr_t) &argument)) {
517		printf("unable to free arguments");
518		//exit(1);
519	}
520	svc_freereq(rqstp);
521	if (!nlm_prog_4_freeresult(transp, xdr_result, (caddr_t) &result))
522		printf("unable to free results");
523
524	return;
525}
526