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, MERCHANTABILITY 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: @(#)types.h 1.18 87/07/24 SMI 30 * from: @(#)types.h 2.3 88/08/15 4.0 RPCSRC 31 * $NetBSD: types.h,v 1.13 2000/06/13 01:02:44 thorpej Exp $ 32 * $FreeBSD: src/sys/rpc/types.h,v 1.10 2001/03/19 12:49:47 alfred Exp $ 33 */ 34 35 /* 36 * Rpc additions to <sys/types.h> 37 */ 38 #ifndef _RPC_TYPES_H 39 #define _RPC_TYPES_H 40 41 #include <sys/types.h> 42 #include <sys/_null.h> 43 44 typedef int32_t bool_t; 45 typedef int32_t enum_t; 46 47 typedef u_int32_t rpcprog_t; 48 typedef u_int32_t rpcvers_t; 49 typedef u_int32_t rpcproc_t; 50 typedef u_int32_t rpcprot_t; 51 typedef u_int32_t rpcport_t; 52 typedef int32_t rpc_inline_t; 53 54 #define __dontcare__ -1 55 56 #ifndef FALSE 57 # define FALSE (0) 58 #endif 59 #ifndef TRUE 60 # define TRUE (1) 61 #endif 62 63 #define mem_alloc(bsize) calloc(1, bsize) 64 #define mem_free(ptr, bsize) free(ptr) 65 66 #include <sys/time.h> 67 #include <netconfig.h> 68 69 /* 70 * The netbuf structure is defined here, because FreeBSD / NetBSD only use 71 * it inside the RPC code. It's in <xti.h> on SVR4, but it would be confusing 72 * to have an xti.h, since FreeBSD / NetBSD does not support XTI/TLI. 73 */ 74 75 /* 76 * The netbuf structure is used for transport-independent address storage. 77 */ 78 struct netbuf { 79 unsigned int maxlen; 80 unsigned int len; 81 void *buf; 82 }; 83 84 /* 85 * The format of the addres and options arguments of the XTI t_bind call. 86 * Only provided for compatibility, it should not be used. 87 */ 88 89 struct t_bind { 90 struct netbuf addr; 91 unsigned int qlen; 92 }; 93 94 /* 95 * Internal library and rpcbind use. This is not an exported interface, do 96 * not use. 97 */ 98 struct __rpc_sockinfo { 99 int si_af; 100 int si_proto; 101 int si_socktype; 102 int si_alen; 103 }; 104 105 #endif /* !_RPC_TYPES_H */ 106