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 * @(#)spray.x 1.2 87/09/18 Copyr 1987 Sun Micro 30 * @(#)spray.x 2.1 88/08/01 4.0 RPCSRC 31 * $FreeBSD: src/include/rpcsvc/spray.x,v 1.6 1999/08/27 23:45:11 peter Exp $ 32 * $DragonFly: src/include/rpcsvc/spray.x,v 1.2 2003/06/17 04:25:58 dillon Exp $ 33 */ 34 35 /* 36 * Spray a server with packets 37 * Useful for testing flakiness of network interfaces 38 */ 39 40 const SPRAYMAX = 8845; /* max amount can spray */ 41 42 /* 43 * GMT since 0:00, 1 January 1970 44 */ 45 struct spraytimeval { 46 unsigned int sec; 47 unsigned int usec; 48 }; 49 50 /* 51 * spray statistics 52 */ 53 struct spraycumul { 54 unsigned int counter; 55 spraytimeval clock; 56 }; 57 58 /* 59 * spray data 60 */ 61 typedef opaque sprayarr<SPRAYMAX>; 62 63 program SPRAYPROG { 64 version SPRAYVERS { 65 /* 66 * Just throw away the data and increment the counter 67 * This call never returns, so the client should always 68 * time it out. 69 */ 70 void 71 SPRAYPROC_SPRAY(sprayarr) = 1; 72 73 /* 74 * Get the value of the counter and elapsed time since 75 * last CLEAR. 76 */ 77 spraycumul 78 SPRAYPROC_GET(void) = 2; 79 80 /* 81 * Clear the counter and reset the elapsed time 82 */ 83 void 84 SPRAYPROC_CLEAR(void) = 3; 85 } = 1; 86 } = 100012; 87