1 /* $NetBSD: svc_soc.h,v 1.1 2000/06/02 22:57:57 fvdl Exp $ */ 2 /* $FreeBSD$ */ 3 4 /* 5 * Sun RPC is a product of Sun Microsystems, Inc. and is provided for 6 * unrestricted use provided that this legend is included on all tape 7 * media and as a part of the software program in whole or part. Users 8 * may copy or modify Sun RPC without charge, but are not authorized 9 * to license or distribute it to anyone else except as part of a product or 10 * program developed by the user. 11 * 12 * SUN RPC IS PROVIDED AS IS WITH NO WARRANTIES OF ANY KIND INCLUDING THE 13 * WARRANTIES OF DESIGN, MERCHANTIBILITY AND FITNESS FOR A PARTICULAR 14 * PURPOSE, OR ARISING FROM A COURSE OF DEALING, USAGE OR TRADE PRACTICE. 15 * 16 * Sun RPC is provided with no support and without any obligation on the 17 * part of Sun Microsystems, Inc. to assist in its use, correction, 18 * modification or enhancement. 19 * 20 * SUN MICROSYSTEMS, INC. SHALL HAVE NO LIABILITY WITH RESPECT TO THE 21 * INFRINGEMENT OF COPYRIGHTS, TRADE SECRETS OR ANY PATENTS BY SUN RPC 22 * OR ANY PART THEREOF. 23 * 24 * In no event will Sun Microsystems, Inc. be liable for any lost revenue 25 * or profits or other special, indirect and consequential damages, even if 26 * Sun has been advised of the possibility of such damages. 27 * 28 * Sun Microsystems, Inc. 29 * 2550 Garcia Avenue 30 * Mountain View, California 94043 31 */ 32 /* 33 * Copyright (c) 1986 - 1991 by Sun Microsystems, Inc. 34 */ 35 36 /* 37 * svc.h, Server-side remote procedure call interface. 38 */ 39 40 #ifndef _RPC_SVC_SOC_H 41 #define _RPC_SVC_SOC_H 42 #include <sys/cdefs.h> 43 44 /* #pragma ident "@(#)svc_soc.h 1.11 94/04/25 SMI" */ 45 /* svc_soc.h 1.8 89/05/01 SMI */ 46 47 /* 48 * All the following declarations are only for backward compatibility 49 * with TS-RPC 50 */ 51 52 /* 53 * Approved way of getting address of caller 54 */ 55 #define svc_getcaller(x) (&(x)->xp_raddr) 56 57 /* 58 * Service registration 59 * 60 * svc_register(xprt, prog, vers, dispatch, protocol) 61 * SVCXPRT *xprt; 62 * u_long prog; 63 * u_long vers; 64 * void (*dispatch)(); 65 * int protocol; like TCP or UDP, zero means do not register 66 */ 67 __BEGIN_DECLS 68 extern bool_t svc_register(SVCXPRT *, u_long, u_long, 69 void (*)(struct svc_req *, SVCXPRT *), int); 70 __END_DECLS 71 72 /* 73 * Service un-registration 74 * 75 * svc_unregister(prog, vers) 76 * u_long prog; 77 * u_long vers; 78 */ 79 __BEGIN_DECLS 80 extern void svc_unregister(u_long, u_long); 81 __END_DECLS 82 83 84 /* 85 * Memory based rpc for testing and timing. 86 */ 87 __BEGIN_DECLS 88 extern SVCXPRT *svcraw_create(void); 89 __END_DECLS 90 91 92 /* 93 * Udp based rpc. 94 */ 95 __BEGIN_DECLS 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 __END_DECLS 100 101 102 /* 103 * Tcp based rpc. 104 */ 105 __BEGIN_DECLS 106 extern SVCXPRT *svctcp_create(int, u_int, u_int); 107 __END_DECLS 108 109 /* 110 * Fd based rpc. 111 */ 112 __BEGIN_DECLS 113 extern SVCXPRT *svcfd_create(int, u_int, u_int); 114 __END_DECLS 115 116 #endif /* !_RPC_SVC_SOC_H */ 117