Home | History | Annotate | Line # | Download | only in nfs
nfsrtt.h revision 1.5.34.1
      1  1.5.34.1  nathanw /*	$NetBSD: nfsrtt.h,v 1.5.34.1 2002/06/20 03:50:05 nathanw Exp $	*/
      2       1.2      cgd 
      3       1.1  mycroft /*
      4       1.1  mycroft  * Copyright (c) 1992, 1993
      5       1.1  mycroft  *	The Regents of the University of California.  All rights reserved.
      6       1.1  mycroft  *
      7       1.1  mycroft  * This code is derived from software contributed to Berkeley by
      8       1.1  mycroft  * Rick Macklem at The University of Guelph.
      9       1.1  mycroft  *
     10       1.1  mycroft  * Redistribution and use in source and binary forms, with or without
     11       1.1  mycroft  * modification, are permitted provided that the following conditions
     12       1.1  mycroft  * are met:
     13       1.1  mycroft  * 1. Redistributions of source code must retain the above copyright
     14       1.1  mycroft  *    notice, this list of conditions and the following disclaimer.
     15       1.1  mycroft  * 2. Redistributions in binary form must reproduce the above copyright
     16       1.1  mycroft  *    notice, this list of conditions and the following disclaimer in the
     17       1.1  mycroft  *    documentation and/or other materials provided with the distribution.
     18       1.1  mycroft  * 3. All advertising materials mentioning features or use of this software
     19       1.1  mycroft  *    must display the following acknowledgement:
     20       1.1  mycroft  *	This product includes software developed by the University of
     21       1.1  mycroft  *	California, Berkeley and its contributors.
     22       1.1  mycroft  * 4. Neither the name of the University nor the names of its contributors
     23       1.1  mycroft  *    may be used to endorse or promote products derived from this software
     24       1.1  mycroft  *    without specific prior written permission.
     25       1.1  mycroft  *
     26       1.1  mycroft  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
     27       1.1  mycroft  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
     28       1.1  mycroft  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     29       1.1  mycroft  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
     30       1.1  mycroft  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     31       1.1  mycroft  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     32       1.1  mycroft  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     33       1.1  mycroft  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
     34       1.1  mycroft  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     35       1.1  mycroft  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     36       1.1  mycroft  * SUCH DAMAGE.
     37       1.1  mycroft  *
     38       1.4     fvdl  *	@(#)nfsrtt.h	8.2 (Berkeley) 3/30/95
     39       1.1  mycroft  */
     40       1.1  mycroft 
     41       1.4     fvdl 
     42       1.4     fvdl #ifndef _NFS_NFSRTT_H_
     43       1.4     fvdl #define _NFS_NFSRTT_H_
     44       1.4     fvdl 
     45       1.1  mycroft /*
     46       1.1  mycroft  * Definitions for performance monitor.
     47       1.1  mycroft  * The client and server logging are turned on by setting the global
     48       1.1  mycroft  * constant "nfsrtton" to 1.
     49       1.1  mycroft  */
     50       1.1  mycroft #define	NFSRTTLOGSIZ	128
     51       1.1  mycroft 
     52       1.1  mycroft /*
     53       1.1  mycroft  * Circular log of client side rpc activity. Each log entry is for one
     54       1.1  mycroft  * rpc filled in upon completion. (ie. in order of completion)
     55       1.1  mycroft  * The "pos" is the table index for the "next" entry, therefore the
     56       1.1  mycroft  * list goes from nfsrtt.rttl[pos] --> nfsrtt.rttl[pos - 1] in
     57       1.1  mycroft  * chronological order of completion.
     58       1.1  mycroft  */
     59       1.1  mycroft struct nfsrtt {
     60       1.1  mycroft 	int pos;			/* Position in array for next entry */
     61       1.1  mycroft 	struct rttl {
     62       1.5     fvdl 		u_int32_t	proc;		/* NFS procedure number */
     63       1.5     fvdl 		int		rtt;		/* Measured round trip time */
     64       1.5     fvdl 		int		rto;		/* Round Trip Timeout */
     65       1.5     fvdl 		int		sent;		/* # rpcs in progress */
     66       1.5     fvdl 		int		cwnd;		/* Send window */
     67       1.5     fvdl 		int		srtt;		/* Ave Round Trip Time */
     68       1.5     fvdl 		int		sdrtt;		/* Ave mean deviation of RTT */
     69       1.5     fvdl 		fsid_t		fsid;		/* Fsid for mount point */
     70       1.5     fvdl 		struct timeval	tstamp;	/* Timestamp of log entry */
     71       1.1  mycroft 	} rttl[NFSRTTLOGSIZ];
     72       1.1  mycroft };
     73       1.1  mycroft 
     74       1.1  mycroft /*
     75       1.1  mycroft  * And definitions for server side performance monitor.
     76       1.1  mycroft  * The log organization is the same as above except it is filled in at the
     77       1.1  mycroft  * time the server sends the rpc reply.
     78       1.1  mycroft  */
     79       1.1  mycroft 
     80       1.1  mycroft /*
     81       1.1  mycroft  * Bits for the flags field.
     82       1.1  mycroft  */
     83       1.1  mycroft #define	DRT_NQNFS	0x01	/* Rpc used Nqnfs protocol */
     84       1.1  mycroft #define	DRT_TCP		0x02	/* Client used TCP transport */
     85       1.1  mycroft #define	DRT_CACHEREPLY	0x04	/* Reply was from recent request cache */
     86       1.1  mycroft #define	DRT_CACHEDROP	0x08	/* Rpc request dropped, due to recent reply */
     87       1.4     fvdl #define DRT_NFSV3	0x10	/* Rpc used NFS Version 3 */
     88       1.1  mycroft 
     89       1.1  mycroft /*
     90       1.1  mycroft  * Server log structure
     91       1.1  mycroft  * NB: ipadr == INADDR_ANY indicates a client using a non IP protocol.
     92       1.1  mycroft  *	(ISO perhaps?)
     93       1.1  mycroft  */
     94       1.1  mycroft struct nfsdrt {
     95       1.1  mycroft 	int pos;			/* Position of next log entry */
     96       1.1  mycroft 	struct drt {
     97       1.4     fvdl 		int       flag;		/* Bits as defined above */
     98       1.5     fvdl 		u_int32_t proc;		/* NFS procedure number */
     99       1.5     fvdl 		u_int32_t ipadr;	/* IP address of client */
    100       1.4     fvdl 		int       resptime;	/* Response time (usec) */
    101       1.1  mycroft 		struct timeval tstamp;	/* Timestamp of log entry */
    102       1.1  mycroft 	} drt[NFSRTTLOGSIZ];
    103       1.1  mycroft };
    104  1.5.34.1  nathanw 
    105  1.5.34.1  nathanw #ifdef _KERNEL
    106  1.5.34.1  nathanw extern int nfsrtton;
    107  1.5.34.1  nathanw #endif
    108       1.4     fvdl 
    109       1.4     fvdl #endif
    110