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 * @(#)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 */ 33 34 /* 35 * Spray a server with packets 36 * Useful for testing flakiness of network interfaces 37 */ 38 39 const SPRAYMAX = 8845; /* max amount can spray */ 40 41 /* 42 * GMT since 0:00, 1 January 1970 43 */ 44 struct spraytimeval { 45 unsigned int sec; 46 unsigned int usec; 47 }; 48 49 /* 50 * spray statistics 51 */ 52 struct spraycumul { 53 unsigned int counter; 54 spraytimeval clock; 55 }; 56 57 /* 58 * spray data 59 */ 60 typedef opaque sprayarr<SPRAYMAX>; 61 62 program SPRAYPROG { 63 version SPRAYVERS { 64 /* 65 * Just throw away the data and increment the counter 66 * This call never returns, so the client should always 67 * time it out. 68 */ 69 void 70 SPRAYPROC_SPRAY(sprayarr) = 1; 71 72 /* 73 * Get the value of the counter and elapsed time since 74 * last CLEAR. 75 */ 76 spraycumul 77 SPRAYPROC_GET(void) = 2; 78 79 /* 80 * Clear the counter and reset the elapsed time 81 */ 82 void 83 SPRAYPROC_CLEAR(void) = 3; 84 } = 1; 85 } = 100012; 86