1 /* $NetBSD: svc_soc.h,v 1.1 2000/06/02 22:57:57 fvdl Exp $ */
2 /* $FreeBSD: src/include/rpc/svc_soc.h,v 1.2 2002/03/23 17:24:55 imp Exp $ */
5 * Copyright (c) 2009, Sun Microsystems, Inc.
8 * Redistribution and use in source and binary forms, with or without
9 * modification, are permitted provided that the following conditions are met:
10 * - Redistributions of source code must retain the above copyright notice,
11 * this list of conditions and the following disclaimer.
12 * - Redistributions in binary form must reproduce the above copyright notice,
13 * this list of conditions and the following disclaimer in the documentation
14 * and/or other materials provided with the distribution.
15 * - Neither the name of Sun Microsystems, Inc. nor the names of its
16 * contributors may be used to endorse or promote products derived
17 * from this software without specific prior written permission.
19 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
20 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
23 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
24 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29 * POSSIBILITY OF SUCH DAMAGE.
32 * Copyright (c) 1986 - 1991 by Sun Microsystems, Inc.
36 * svc.h, Server-side remote procedure call interface.
39 #ifndef _RPC_SVC_SOC_H
40 #define _RPC_SVC_SOC_H
41 #include <sys/cdefs.h>
43 /* #pragma ident "@(#)svc_soc.h 1.11 94/04/25 SMI" */
44 /* svc_soc.h 1.8 89/05/01 SMI */
47 * All the following declarations are only for backward compatibility
52 * Approved way of getting address of caller
54 #define svc_getcaller(x) (&(x)->xp_raddr)
55 /* Getting address of a caller using netbuf xp_rtaddr */
56 #define svc_getcaller_netbuf(x) (&(x)->xp_rtaddr)
58 * Service registration
60 * svc_register(xprt, prog, vers, dispatch, protocol)
65 * int protocol; like TCP or UDP, zero means do not register
68 extern bool_t svc_register(SVCXPRT *, u_long, u_long,
69 void (*)(struct svc_req *, SVCXPRT *), int);
73 * Service un-registration
75 * svc_unregister(prog, vers)
80 extern void svc_unregister(u_long, u_long);
85 * Memory based rpc for testing and timing.
88 extern SVCXPRT *svcraw_create(void);
96 extern SVCXPRT *svcudp_create(int);
97 extern SVCXPRT *svcudp_bufcreate(int, u_int, u_int);
98 extern int svcudp_enablecache(SVCXPRT *, u_long);
99 extern SVCXPRT *svcudp6_create(int);
100 extern SVCXPRT *svcudp6_bufcreate(int, u_int, u_int);
108 extern SVCXPRT *svctcp_create(int, u_int, u_int);
109 extern SVCXPRT *svctcp6_create(int, u_int, u_int);
116 extern SVCXPRT *svcfd_create(int, u_int, u_int);
119 #endif /* !_RPC_SVC_SOC_H */