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