xref: /csrg-svn/sys/netns/spp_var.h (revision 63231)
123216Smckusick /*
2*63231Sbostic  * Copyright (c) 1984, 1985, 1986, 1987, 1993
3*63231Sbostic  *	The Regents of the University of California.  All rights reserved.
423216Smckusick  *
544508Sbostic  * %sccs.include.redist.c%
633371Ssklower  *
7*63231Sbostic  *	@(#)spp_var.h	8.1 (Berkeley) 06/10/93
823216Smckusick  */
921497Ssklower 
1021497Ssklower /*
1121497Ssklower  * Sp control block, one per connection
1221497Ssklower  */
1321497Ssklower struct sppcb {
1421497Ssklower 	struct	spidp_q	s_q;		/* queue for out-of-order receipt */
1521497Ssklower 	struct	nspcb	*s_nspcb;	/* backpointer to internet pcb */
1621497Ssklower 	u_char	s_state;
1721497Ssklower 	u_char	s_flags;
1832597Ssklower #define	SF_ACKNOW	0x01		/* Ack peer immediately */
1932597Ssklower #define	SF_DELACK	0x02		/* Ack, but try to delay it */
2032597Ssklower #define	SF_HI	0x04			/* Show headers on input */
2132597Ssklower #define	SF_HO	0x08			/* Show headers on output */
2232597Ssklower #define	SF_PI	0x10			/* Packet (datagram) interface */
2332597Ssklower #define SF_WIN	0x20			/* Window info changed */
2432597Ssklower #define SF_RXT	0x40			/* Rxt info changed */
2532597Ssklower #define SF_RVD	0x80			/* Calling from read usrreq routine */
2621497Ssklower 	u_short s_mtu;			/* Max packet size for this stream */
2721497Ssklower /* use sequence fields in headers to store sequence numbers for this
2821497Ssklower    connection */
2932597Ssklower 	struct	idp	*s_idp;
3032597Ssklower 	struct	sphdr	s_shdr;		/* prototype header to transmit */
3132597Ssklower #define s_cc s_shdr.sp_cc		/* connection control (for EM bit) */
3232597Ssklower #define s_dt s_shdr.sp_dt		/* datastream type */
3332597Ssklower #define s_sid s_shdr.sp_sid		/* source connection identifier */
3432597Ssklower #define s_did s_shdr.sp_did		/* destination connection identifier */
3532597Ssklower #define s_seq s_shdr.sp_seq		/* sequence number */
3632597Ssklower #define s_ack s_shdr.sp_ack		/* acknowledge number */
3732597Ssklower #define s_alo s_shdr.sp_alo		/* allocation number */
3832597Ssklower #define s_dport s_idp->idp_dna.x_port	/* where we are sending */
3921497Ssklower 	struct sphdr s_rhdr;		/* last received header (in effect!)*/
4021497Ssklower 	u_short s_rack;			/* their acknowledge number */
4121497Ssklower 	u_short s_ralo;			/* their allocation number */
4232597Ssklower 	u_short s_smax;			/* highest packet # we have sent */
4332597Ssklower 	u_short	s_snxt;			/* which packet to send next */
4421497Ssklower 
4532597Ssklower /* congestion control */
4632597Ssklower #define	CUNIT	1024			/* scaling for ... */
4732597Ssklower 	int	s_cwnd;			/* Congestion-controlled window */
4832597Ssklower 					/* in packets * CUNIT */
4932597Ssklower 	short	s_swnd;			/* == tcp snd_wnd, in packets */
5032597Ssklower 	short	s_smxw;			/* == tcp max_sndwnd */
5132597Ssklower 					/* difference of two spp_seq's can be
5232597Ssklower 					   no bigger than a short */
5332597Ssklower 	u_short	s_swl1;			/* == tcp snd_wl1 */
5432597Ssklower 	u_short	s_swl2;			/* == tcp snd_wl2 */
5532597Ssklower 	int	s_cwmx;			/* max allowable cwnd */
5632597Ssklower 	int	s_ssthresh;		/* s_cwnd size threshhold for
5732597Ssklower 					 * slow start exponential-to-
5832597Ssklower 					 * linear switch */
5932597Ssklower /* transmit timing stuff
6032597Ssklower  * srtt and rttvar are stored as fixed point, for convenience in smoothing.
6132597Ssklower  * srtt has 3 bits to the right of the binary point, rttvar has 2.
6232597Ssklower  */
6321497Ssklower 	short	s_idle;			/* time idle */
6433719Skarels 	short	s_timer[SPPT_NTIMERS];	/* timers */
6521497Ssklower 	short	s_rxtshift;		/* log(2) of rexmt exp. backoff */
6632597Ssklower 	short	s_rxtcur;		/* current retransmit value */
6721497Ssklower 	u_short	s_rtseq;		/* packet being timed */
6821497Ssklower 	short	s_rtt;			/* timer for round trips */
6921497Ssklower 	short	s_srtt;			/* averaged timer */
7032597Ssklower 	short	s_rttvar;		/* variance in round trip time */
7121497Ssklower 	char	s_force;		/* which timer expired */
7232597Ssklower 	char	s_dupacks;		/* counter to intuit xmt loss */
7321497Ssklower 
7421497Ssklower /* out of band data */
7521497Ssklower 	char	s_oobflags;
7621497Ssklower #define SF_SOOB	0x08			/* sending out of band data */
7721497Ssklower #define SF_IOOB 0x10			/* receiving out of band data */
7821497Ssklower 	char	s_iobc;			/* input characters */
7921497Ssklower /* debug stuff */
8021497Ssklower 	u_short	s_want;			/* Last candidate for sending */
8132597Ssklower 	char	s_outx;			/* exit taken from spp_output */
8232597Ssklower 	char	s_inx;			/* exit taken from spp_input */
8337473Ssklower 	u_short	s_flags2;		/* more flags for testing */
8437473Ssklower #define SF_NEWCALL	0x100		/* for new_recvmsg */
8537473Ssklower #define SO_NEWCALL	10		/* for new_recvmsg */
8621497Ssklower };
8721497Ssklower 
8821497Ssklower #define	nstosppcb(np)	((struct sppcb *)(np)->nsp_pcb)
8921497Ssklower #define	sotosppcb(so)	(nstosppcb(sotonspcb(so)))
9021497Ssklower 
9132597Ssklower struct	sppstat {
9232597Ssklower 	long	spps_connattempt;	/* connections initiated */
9332597Ssklower 	long	spps_accepts;		/* connections accepted */
9432597Ssklower 	long	spps_connects;		/* connections established */
9532597Ssklower 	long	spps_drops;		/* connections dropped */
9632597Ssklower 	long	spps_conndrops;		/* embryonic connections dropped */
9732597Ssklower 	long	spps_closed;		/* conn. closed (includes drops) */
9832597Ssklower 	long	spps_segstimed;		/* segs where we tried to get rtt */
9932597Ssklower 	long	spps_rttupdated;	/* times we succeeded */
10032597Ssklower 	long	spps_delack;		/* delayed acks sent */
10132597Ssklower 	long	spps_timeoutdrop;	/* conn. dropped in rxmt timeout */
10232597Ssklower 	long	spps_rexmttimeo;	/* retransmit timeouts */
10332597Ssklower 	long	spps_persisttimeo;	/* persist timeouts */
10432597Ssklower 	long	spps_keeptimeo;		/* keepalive timeouts */
10532597Ssklower 	long	spps_keepprobe;		/* keepalive probes sent */
10632597Ssklower 	long	spps_keepdrops;		/* connections dropped in keepalive */
10732597Ssklower 
10832597Ssklower 	long	spps_sndtotal;		/* total packets sent */
10932597Ssklower 	long	spps_sndpack;		/* data packets sent */
11032597Ssklower 	long	spps_sndbyte;		/* data bytes sent */
11132597Ssklower 	long	spps_sndrexmitpack;	/* data packets retransmitted */
11232597Ssklower 	long	spps_sndrexmitbyte;	/* data bytes retransmitted */
11332597Ssklower 	long	spps_sndacks;		/* ack-only packets sent */
11432597Ssklower 	long	spps_sndprobe;		/* window probes sent */
11532597Ssklower 	long	spps_sndurg;		/* packets sent with URG only */
11632597Ssklower 	long	spps_sndwinup;		/* window update-only packets sent */
11732597Ssklower 	long	spps_sndctrl;		/* control (SYN|FIN|RST) packets sent */
11832597Ssklower 	long	spps_sndvoid;		/* couldn't find requested packet*/
11932597Ssklower 
12032597Ssklower 	long	spps_rcvtotal;		/* total packets received */
12132597Ssklower 	long	spps_rcvpack;		/* packets received in sequence */
12232597Ssklower 	long	spps_rcvbyte;		/* bytes received in sequence */
12332597Ssklower 	long	spps_rcvbadsum;		/* packets received with ccksum errs */
12432597Ssklower 	long	spps_rcvbadoff;		/* packets received with bad offset */
12532597Ssklower 	long	spps_rcvshort;		/* packets received too short */
12632597Ssklower 	long	spps_rcvduppack;	/* duplicate-only packets received */
12732597Ssklower 	long	spps_rcvdupbyte;	/* duplicate-only bytes received */
12832597Ssklower 	long	spps_rcvpartduppack;	/* packets with some duplicate data */
12932597Ssklower 	long	spps_rcvpartdupbyte;	/* dup. bytes in part-dup. packets */
13032597Ssklower 	long	spps_rcvoopack;		/* out-of-order packets received */
13132597Ssklower 	long	spps_rcvoobyte;		/* out-of-order bytes received */
13232597Ssklower 	long	spps_rcvpackafterwin;	/* packets with data after window */
13332597Ssklower 	long	spps_rcvbyteafterwin;	/* bytes rcvd after window */
13432597Ssklower 	long	spps_rcvafterclose;	/* packets rcvd after "close" */
13532597Ssklower 	long	spps_rcvwinprobe;	/* rcvd window probe packets */
13632597Ssklower 	long	spps_rcvdupack;		/* rcvd duplicate acks */
13732597Ssklower 	long	spps_rcvacktoomuch;	/* rcvd acks for unsent data */
13832597Ssklower 	long	spps_rcvackpack;	/* rcvd ack packets */
13932597Ssklower 	long	spps_rcvackbyte;	/* bytes acked by rcvd acks */
14032597Ssklower 	long	spps_rcvwinupd;		/* rcvd window update packets */
14132597Ssklower };
14221497Ssklower struct	spp_istat {
14321497Ssklower 	short	hdrops;
14421497Ssklower 	short	badsum;
14521497Ssklower 	short	badlen;
14621497Ssklower 	short	slotim;
14721497Ssklower 	short	fastim;
14821497Ssklower 	short	nonucn;
14921497Ssklower 	short	noconn;
15021497Ssklower 	short	notme;
15121497Ssklower 	short	wrncon;
15221497Ssklower 	short	bdreas;
15321497Ssklower 	short	gonawy;
15423978Ssklower 	short	notyet;
15523978Ssklower 	short	lstdup;
15632597Ssklower 	struct sppstat newstats;
15721497Ssklower };
15821497Ssklower 
15921497Ssklower #ifdef KERNEL
16021497Ssklower struct spp_istat spp_istat;
16132597Ssklower 
16232597Ssklower /* Following was struct sppstat sppstat; */
16332597Ssklower #ifndef sppstat
16432597Ssklower #define sppstat spp_istat.newstats
16532597Ssklower #endif
16632597Ssklower 
16721497Ssklower u_short spp_iss;
16821497Ssklower extern struct sppcb *spp_close(), *spp_disconnect(),
16921497Ssklower 	*spp_usrclosed(), *spp_timers(), *spp_drop();
17021497Ssklower #endif
17121497Ssklower 
17221497Ssklower #define	SPP_ISSINCR	128
17321497Ssklower /*
17421497Ssklower  * SPP sequence numbers are 16 bit integers operated
17521497Ssklower  * on with modular arithmetic.  These macros can be
17621497Ssklower  * used to compare such integers.
17721497Ssklower  */
17832597Ssklower #ifdef sun
17932597Ssklower short xnsCbug;
18032597Ssklower #define	SSEQ_LT(a,b)	((xnsCbug = (short)((a)-(b))) < 0)
18132597Ssklower #define	SSEQ_LEQ(a,b)	((xnsCbug = (short)((a)-(b))) <= 0)
18232597Ssklower #define	SSEQ_GT(a,b)	((xnsCbug = (short)((a)-(b))) > 0)
18332597Ssklower #define	SSEQ_GEQ(a,b)	((xnsCbug = (short)((a)-(b))) >= 0)
18432597Ssklower #else
18521497Ssklower #define	SSEQ_LT(a,b)	(((short)((a)-(b))) < 0)
18621497Ssklower #define	SSEQ_LEQ(a,b)	(((short)((a)-(b))) <= 0)
18721497Ssklower #define	SSEQ_GT(a,b)	(((short)((a)-(b))) > 0)
18821497Ssklower #define	SSEQ_GEQ(a,b)	(((short)((a)-(b))) >= 0)
18932597Ssklower #endif
190