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 * $DragonFly: src/include/rpc/types.h,v 1.2 2003/06/17 04:25:58 dillon Exp $ 34 */ 35 36 /* 37 * Rpc additions to <sys/types.h> 38 */ 39 #ifndef _RPC_TYPES_H 40 #define _RPC_TYPES_H 41 42 #include <sys/types.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 #ifndef NULL 63 # define NULL 0 64 #endif 65 66 #define mem_alloc(bsize) calloc(1, bsize) 67 #define mem_free(ptr, bsize) free(ptr) 68 69 #include <sys/time.h> 70 #include <netconfig.h> 71 72 /* 73 * The netbuf structure is defined here, because FreeBSD / NetBSD only use 74 * it inside the RPC code. It's in <xti.h> on SVR4, but it would be confusing 75 * to have an xti.h, since FreeBSD / NetBSD does not support XTI/TLI. 76 */ 77 78 /* 79 * The netbuf structure is used for transport-independent address storage. 80 */ 81 struct netbuf { 82 unsigned int maxlen; 83 unsigned int len; 84 void *buf; 85 }; 86 87 /* 88 * The format of the addres and options arguments of the XTI t_bind call. 89 * Only provided for compatibility, it should not be used. 90 */ 91 92 struct t_bind { 93 struct netbuf addr; 94 unsigned int qlen; 95 }; 96 97 /* 98 * Internal library and rpcbind use. This is not an exported interface, do 99 * not use. 100 */ 101 struct __rpc_sockinfo { 102 int si_af; 103 int si_proto; 104 int si_socktype; 105 int si_alen; 106 }; 107 108 #endif /* !_RPC_TYPES_H */ 109