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