1630fa006SGarrett Wollman /*- 2630fa006SGarrett Wollman * Copyright (c) 1980, 1992, 1993 3630fa006SGarrett Wollman * The Regents of the University of California. All rights reserved. 4630fa006SGarrett Wollman * 5630fa006SGarrett Wollman * Redistribution and use in source and binary forms, with or without 6630fa006SGarrett Wollman * modification, are permitted provided that the following conditions 7630fa006SGarrett Wollman * are met: 8630fa006SGarrett Wollman * 1. Redistributions of source code must retain the above copyright 9630fa006SGarrett Wollman * notice, this list of conditions and the following disclaimer. 10630fa006SGarrett Wollman * 2. Redistributions in binary form must reproduce the above copyright 11630fa006SGarrett Wollman * notice, this list of conditions and the following disclaimer in the 12630fa006SGarrett Wollman * documentation and/or other materials provided with the distribution. 13630fa006SGarrett Wollman * 3. All advertising materials mentioning features or use of this software 14630fa006SGarrett Wollman * must display the following acknowledgement: 15630fa006SGarrett Wollman * This product includes software developed by the University of 16630fa006SGarrett Wollman * California, Berkeley and its contributors. 17630fa006SGarrett Wollman * 4. Neither the name of the University nor the names of its contributors 18630fa006SGarrett Wollman * may be used to endorse or promote products derived from this software 19630fa006SGarrett Wollman * without specific prior written permission. 20630fa006SGarrett Wollman * 21630fa006SGarrett Wollman * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 22630fa006SGarrett Wollman * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 23630fa006SGarrett Wollman * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 24630fa006SGarrett Wollman * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 25630fa006SGarrett Wollman * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 26630fa006SGarrett Wollman * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 27630fa006SGarrett Wollman * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 28630fa006SGarrett Wollman * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 29630fa006SGarrett Wollman * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 30630fa006SGarrett Wollman * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 31630fa006SGarrett Wollman * SUCH DAMAGE. 32630fa006SGarrett Wollman */ 33630fa006SGarrett Wollman 347501cdc8SBruce Evans #if 0 357501cdc8SBruce Evans #ifndef lint 367501cdc8SBruce Evans /* From: */ 377501cdc8SBruce Evans static char sccsid[] = "@(#)mbufs.c 8.1 (Berkeley) 6/6/93"; 387501cdc8SBruce Evans static const char rcsid[] = 397501cdc8SBruce Evans "Id: mbufs.c,v 1.5 1997/02/24 20:59:03 wollman Exp"; 407501cdc8SBruce Evans #endif /* not lint */ 417501cdc8SBruce Evans #endif 427501cdc8SBruce Evans 439ff712b0SMark Murray #include <sys/cdefs.h> 449ff712b0SMark Murray __FBSDID("$FreeBSD$"); 459ff712b0SMark Murray 46630fa006SGarrett Wollman #include <sys/param.h> 47630fa006SGarrett Wollman #include <sys/types.h> 48630fa006SGarrett Wollman #include <sys/socket.h> 49630fa006SGarrett Wollman #include <sys/sysctl.h> 50630fa006SGarrett Wollman 51630fa006SGarrett Wollman #include <netinet/in.h> 52630fa006SGarrett Wollman #include <netinet/in_systm.h> 53630fa006SGarrett Wollman #include <netinet/ip.h> 54630fa006SGarrett Wollman #include <netinet/tcp.h> 55630fa006SGarrett Wollman #include <netinet/tcp_seq.h> 56630fa006SGarrett Wollman #include <netinet/tcp_fsm.h> 57630fa006SGarrett Wollman #include <netinet/tcp_timer.h> 58630fa006SGarrett Wollman #include <netinet/tcp_var.h> 59630fa006SGarrett Wollman 60630fa006SGarrett Wollman #include <stdlib.h> 61630fa006SGarrett Wollman #include <string.h> 62630fa006SGarrett Wollman #include <paths.h> 639ff712b0SMark Murray 64630fa006SGarrett Wollman #include "systat.h" 65630fa006SGarrett Wollman #include "extern.h" 66630fa006SGarrett Wollman #include "mode.h" 67630fa006SGarrett Wollman 68630fa006SGarrett Wollman static struct tcpstat curstat, initstat, oldstat; 69630fa006SGarrett Wollman 70630fa006SGarrett Wollman /*- 71630fa006SGarrett Wollman --0 1 2 3 4 5 6 7 72630fa006SGarrett Wollman --0123456789012345678901234567890123456789012345678901234567890123456789012345 738aa22952SBruce Evans 00 TCP Connections TCP Packets 7459003696SJohn Baldwin 01999999999999 connections initiated 999999999999 total packets sent 7559003696SJohn Baldwin 02999999999999 connections accepted 999999999999 - data 7659003696SJohn Baldwin 03999999999999 connections established 999999999999 - data (retransmit by dupack) 7759003696SJohn Baldwin 04999999999999 connections dropped 999999999999 - data (retransmit by sack) 7859003696SJohn Baldwin 05999999999999 - in embryonic state 999999999999 - ack-only 7959003696SJohn Baldwin 06999999999999 - on retransmit timeout 999999999999 - window probes 8059003696SJohn Baldwin 07999999999999 - by keepalive 999999999999 - window updates 8159003696SJohn Baldwin 08999999999999 - from listen queue 999999999999 - urgent data only 8259003696SJohn Baldwin 09 999999999999 - control 8359003696SJohn Baldwin 10 999999999999 - resends by PMTU discovery 8459003696SJohn Baldwin 11 TCP Timers 999999999999 total packets received 8559003696SJohn Baldwin 12999999999999 potential rtt updates 999999999999 - in sequence 8659003696SJohn Baldwin 13999999999999 - successful 999999999999 - completely duplicate 8759003696SJohn Baldwin 14999999999999 delayed acks sent 999999999999 - with some duplicate data 8859003696SJohn Baldwin 15999999999999 retransmit timeouts 999999999999 - out-of-order 8959003696SJohn Baldwin 16999999999999 persist timeouts 999999999999 - duplicate acks 9059003696SJohn Baldwin 17999999999999 keepalive probes 999999999999 - acks 9159003696SJohn Baldwin 18999999999999 - timeouts 999999999999 - window probes 9259003696SJohn Baldwin 19 999999999999 - window updates 9359003696SJohn Baldwin 20 999999999999 - bad checksum 94630fa006SGarrett Wollman --0123456789012345678901234567890123456789012345678901234567890123456789012345 95630fa006SGarrett Wollman --0 1 2 3 4 5 6 7 96630fa006SGarrett Wollman */ 97630fa006SGarrett Wollman 98630fa006SGarrett Wollman WINDOW * 99630fa006SGarrett Wollman opentcp(void) 100630fa006SGarrett Wollman { 1018aa22952SBruce Evans return (subwin(stdscr, LINES-3-1, 0, MAINWIN_ROW, 0)); 102630fa006SGarrett Wollman } 103630fa006SGarrett Wollman 104630fa006SGarrett Wollman void 10593b9f504SXin LI closetcp(WINDOW *w) 106630fa006SGarrett Wollman { 107630fa006SGarrett Wollman if (w == NULL) 108630fa006SGarrett Wollman return; 109630fa006SGarrett Wollman wclear(w); 110630fa006SGarrett Wollman wrefresh(w); 1118aa22952SBruce Evans delwin(w); 112630fa006SGarrett Wollman } 113630fa006SGarrett Wollman 114630fa006SGarrett Wollman void 115630fa006SGarrett Wollman labeltcp(void) 116630fa006SGarrett Wollman { 117630fa006SGarrett Wollman wmove(wnd, 0, 0); wclrtoeol(wnd); 11859003696SJohn Baldwin #define L(row, str) mvwprintw(wnd, row, 13, str) 11959003696SJohn Baldwin #define R(row, str) mvwprintw(wnd, row, 51, str); 1208aa22952SBruce Evans L(0, "TCP Connections"); R(0, "TCP Packets"); 1218aa22952SBruce Evans L(1, "connections initiated"); R(1, "total packets sent"); 1228aa22952SBruce Evans L(2, "connections accepted"); R(2, "- data"); 12302a50a14SJohn Baldwin L(3, "connections established"); R(3, "- data (retransmit by dupack)"); 12402a50a14SJohn Baldwin L(4, "connections dropped"); R(4, "- data (retransmit by sack)"); 12502a50a14SJohn Baldwin L(5, "- in embryonic state"); R(5, "- ack-only"); 12602a50a14SJohn Baldwin L(6, "- on retransmit timeout"); R(6, "- window probes"); 12702a50a14SJohn Baldwin L(7, "- by keepalive"); R(7, "- window updates"); 12802a50a14SJohn Baldwin L(8, "- from listen queue"); R(8, "- urgent data only"); 12902a50a14SJohn Baldwin R(9, "- control"); 13002a50a14SJohn Baldwin R(10, "- resends by PMTU discovery"); 13102a50a14SJohn Baldwin L(11, "TCP Timers"); R(11, "total packets received"); 13202a50a14SJohn Baldwin L(12, "potential rtt updates"); R(12, "- in sequence"); 13302a50a14SJohn Baldwin L(13, "- successful"); R(13, "- completely duplicate"); 13402a50a14SJohn Baldwin L(14, "delayed acks sent"); R(14, "- with some duplicate data"); 13502a50a14SJohn Baldwin L(15, "retransmit timeouts"); R(15, "- out-of-order"); 13602a50a14SJohn Baldwin L(16, "persist timeouts"); R(16, "- duplicate acks"); 13702a50a14SJohn Baldwin L(17, "keepalive probes"); R(17, "- acks"); 13802a50a14SJohn Baldwin L(18, "- timeouts"); R(18, "- window probes"); 13902a50a14SJohn Baldwin R(19, "- window updates"); 14002a50a14SJohn Baldwin R(20, "- bad checksum"); 141630fa006SGarrett Wollman #undef L 142630fa006SGarrett Wollman #undef R 143630fa006SGarrett Wollman } 144630fa006SGarrett Wollman 145630fa006SGarrett Wollman static void 146630fa006SGarrett Wollman domode(struct tcpstat *ret) 147630fa006SGarrett Wollman { 148630fa006SGarrett Wollman const struct tcpstat *sub; 149d22889b8SDavid E. O'Brien int divisor = 1; 150630fa006SGarrett Wollman 151630fa006SGarrett Wollman switch(currentmode) { 152630fa006SGarrett Wollman case display_RATE: 153630fa006SGarrett Wollman sub = &oldstat; 154630fa006SGarrett Wollman divisor = naptime; 155630fa006SGarrett Wollman break; 156630fa006SGarrett Wollman case display_DELTA: 157630fa006SGarrett Wollman sub = &oldstat; 158630fa006SGarrett Wollman break; 159630fa006SGarrett Wollman case display_SINCE: 160630fa006SGarrett Wollman sub = &initstat; 161630fa006SGarrett Wollman break; 162630fa006SGarrett Wollman default: 163630fa006SGarrett Wollman *ret = curstat; 164630fa006SGarrett Wollman return; 165630fa006SGarrett Wollman } 166630fa006SGarrett Wollman #define DO(stat) ret->stat = (curstat.stat - sub->stat) / divisor 167630fa006SGarrett Wollman DO(tcps_connattempt); 168630fa006SGarrett Wollman DO(tcps_accepts); 169630fa006SGarrett Wollman DO(tcps_connects); 170630fa006SGarrett Wollman DO(tcps_drops); 171630fa006SGarrett Wollman DO(tcps_conndrops); 172630fa006SGarrett Wollman DO(tcps_closed); 173630fa006SGarrett Wollman DO(tcps_segstimed); 174630fa006SGarrett Wollman DO(tcps_rttupdated); 175630fa006SGarrett Wollman DO(tcps_delack); 176630fa006SGarrett Wollman DO(tcps_timeoutdrop); 177630fa006SGarrett Wollman DO(tcps_rexmttimeo); 178630fa006SGarrett Wollman DO(tcps_persisttimeo); 179630fa006SGarrett Wollman DO(tcps_keeptimeo); 180630fa006SGarrett Wollman DO(tcps_keepprobe); 181630fa006SGarrett Wollman DO(tcps_keepdrops); 182630fa006SGarrett Wollman 183630fa006SGarrett Wollman DO(tcps_sndtotal); 184630fa006SGarrett Wollman DO(tcps_sndpack); 185630fa006SGarrett Wollman DO(tcps_sndbyte); 186630fa006SGarrett Wollman DO(tcps_sndrexmitpack); 18702a50a14SJohn Baldwin DO(tcps_sack_rexmits); 188630fa006SGarrett Wollman DO(tcps_sndacks); 189630fa006SGarrett Wollman DO(tcps_sndprobe); 190630fa006SGarrett Wollman DO(tcps_sndurg); 191630fa006SGarrett Wollman DO(tcps_sndwinup); 192630fa006SGarrett Wollman DO(tcps_sndctrl); 193630fa006SGarrett Wollman 194630fa006SGarrett Wollman DO(tcps_rcvtotal); 195630fa006SGarrett Wollman DO(tcps_rcvpack); 196630fa006SGarrett Wollman DO(tcps_rcvbyte); 197630fa006SGarrett Wollman DO(tcps_rcvbadsum); 198630fa006SGarrett Wollman DO(tcps_rcvbadoff); 199630fa006SGarrett Wollman DO(tcps_rcvshort); 200630fa006SGarrett Wollman DO(tcps_rcvduppack); 201630fa006SGarrett Wollman DO(tcps_rcvdupbyte); 202630fa006SGarrett Wollman DO(tcps_rcvpartduppack); 203630fa006SGarrett Wollman DO(tcps_rcvpartdupbyte); 204630fa006SGarrett Wollman DO(tcps_rcvoopack); 205630fa006SGarrett Wollman DO(tcps_rcvoobyte); 206630fa006SGarrett Wollman DO(tcps_rcvpackafterwin); 207630fa006SGarrett Wollman DO(tcps_rcvbyteafterwin); 208630fa006SGarrett Wollman DO(tcps_rcvafterclose); 209630fa006SGarrett Wollman DO(tcps_rcvwinprobe); 210630fa006SGarrett Wollman DO(tcps_rcvdupack); 211630fa006SGarrett Wollman DO(tcps_rcvacktoomuch); 212630fa006SGarrett Wollman DO(tcps_rcvackpack); 213630fa006SGarrett Wollman DO(tcps_rcvackbyte); 214630fa006SGarrett Wollman DO(tcps_rcvwinupd); 215630fa006SGarrett Wollman DO(tcps_pawsdrop); 216630fa006SGarrett Wollman DO(tcps_predack); 217630fa006SGarrett Wollman DO(tcps_preddat); 218630fa006SGarrett Wollman DO(tcps_pcbcachemiss); 219630fa006SGarrett Wollman DO(tcps_cachedrtt); 220630fa006SGarrett Wollman DO(tcps_cachedrttvar); 221630fa006SGarrett Wollman DO(tcps_cachedssthresh); 222630fa006SGarrett Wollman DO(tcps_usedrtt); 223630fa006SGarrett Wollman DO(tcps_usedrttvar); 224630fa006SGarrett Wollman DO(tcps_usedssthresh); 225630fa006SGarrett Wollman DO(tcps_persistdrop); 226630fa006SGarrett Wollman DO(tcps_badsyn); 227630fa006SGarrett Wollman DO(tcps_mturesent); 228630fa006SGarrett Wollman DO(tcps_listendrop); 229630fa006SGarrett Wollman #undef DO 230630fa006SGarrett Wollman } 231630fa006SGarrett Wollman 232630fa006SGarrett Wollman void 233630fa006SGarrett Wollman showtcp(void) 234630fa006SGarrett Wollman { 235630fa006SGarrett Wollman struct tcpstat stats; 236630fa006SGarrett Wollman 237630fa006SGarrett Wollman memset(&stats, 0, sizeof stats); 238630fa006SGarrett Wollman domode(&stats); 239630fa006SGarrett Wollman 240630fa006SGarrett Wollman #define DO(stat, row, col) \ 24159003696SJohn Baldwin mvwprintw(wnd, row, col, "%12lu", stats.stat) 242630fa006SGarrett Wollman #define L(row, stat) DO(stat, row, 0) 24359003696SJohn Baldwin #define R(row, stat) DO(stat, row, 38) 2448aa22952SBruce Evans L(1, tcps_connattempt); R(1, tcps_sndtotal); 2458aa22952SBruce Evans L(2, tcps_accepts); R(2, tcps_sndpack); 2468aa22952SBruce Evans L(3, tcps_connects); R(3, tcps_sndrexmitpack); 24702a50a14SJohn Baldwin L(4, tcps_drops); R(4, tcps_sack_rexmits); 24802a50a14SJohn Baldwin L(5, tcps_conndrops); R(5, tcps_sndacks); 24902a50a14SJohn Baldwin L(6, tcps_timeoutdrop); R(6, tcps_sndprobe); 25002a50a14SJohn Baldwin L(7, tcps_keepdrops); R(7, tcps_sndwinup); 25102a50a14SJohn Baldwin L(8, tcps_listendrop); R(8, tcps_sndurg); 25202a50a14SJohn Baldwin R(9, tcps_sndctrl); 25302a50a14SJohn Baldwin R(10, tcps_mturesent); 25402a50a14SJohn Baldwin R(11, tcps_rcvtotal); 25502a50a14SJohn Baldwin L(12, tcps_segstimed); R(12, tcps_rcvpack); 25602a50a14SJohn Baldwin L(13, tcps_rttupdated); R(13, tcps_rcvduppack); 25702a50a14SJohn Baldwin L(14, tcps_delack); R(14, tcps_rcvpartduppack); 25802a50a14SJohn Baldwin L(15, tcps_rexmttimeo); R(15, tcps_rcvoopack); 25902a50a14SJohn Baldwin L(16, tcps_persisttimeo); R(16, tcps_rcvdupack); 26002a50a14SJohn Baldwin L(17, tcps_keepprobe); R(17, tcps_rcvackpack); 26102a50a14SJohn Baldwin L(18, tcps_keeptimeo); R(18, tcps_rcvwinprobe); 26202a50a14SJohn Baldwin R(19, tcps_rcvwinupd); 26302a50a14SJohn Baldwin R(20, tcps_rcvbadsum); 264630fa006SGarrett Wollman #undef DO 265630fa006SGarrett Wollman #undef L 266630fa006SGarrett Wollman #undef R 267630fa006SGarrett Wollman } 268630fa006SGarrett Wollman 269630fa006SGarrett Wollman int 270630fa006SGarrett Wollman inittcp(void) 271630fa006SGarrett Wollman { 272630fa006SGarrett Wollman size_t len; 273630fa006SGarrett Wollman int name[4]; 274630fa006SGarrett Wollman 275630fa006SGarrett Wollman name[0] = CTL_NET; 276630fa006SGarrett Wollman name[1] = PF_INET; 277630fa006SGarrett Wollman name[2] = IPPROTO_TCP; 278630fa006SGarrett Wollman name[3] = TCPCTL_STATS; 279630fa006SGarrett Wollman 280630fa006SGarrett Wollman len = 0; 281630fa006SGarrett Wollman if (sysctl(name, 4, 0, &len, 0, 0) < 0) { 282630fa006SGarrett Wollman error("sysctl getting tcpstat size failed"); 283630fa006SGarrett Wollman return 0; 284630fa006SGarrett Wollman } 285630fa006SGarrett Wollman if (len > sizeof curstat) { 286630fa006SGarrett Wollman error("tcpstat structure has grown--recompile systat!"); 287630fa006SGarrett Wollman return 0; 288630fa006SGarrett Wollman } 289630fa006SGarrett Wollman if (sysctl(name, 4, &initstat, &len, 0, 0) < 0) { 290630fa006SGarrett Wollman error("sysctl getting tcpstat failed"); 291630fa006SGarrett Wollman return 0; 292630fa006SGarrett Wollman } 293630fa006SGarrett Wollman oldstat = initstat; 294630fa006SGarrett Wollman return 1; 295630fa006SGarrett Wollman } 296630fa006SGarrett Wollman 297630fa006SGarrett Wollman void 298630fa006SGarrett Wollman resettcp(void) 299630fa006SGarrett Wollman { 300630fa006SGarrett Wollman size_t len; 301630fa006SGarrett Wollman int name[4]; 302630fa006SGarrett Wollman 303630fa006SGarrett Wollman name[0] = CTL_NET; 304630fa006SGarrett Wollman name[1] = PF_INET; 305630fa006SGarrett Wollman name[2] = IPPROTO_TCP; 306630fa006SGarrett Wollman name[3] = TCPCTL_STATS; 307630fa006SGarrett Wollman 308630fa006SGarrett Wollman len = sizeof initstat; 309630fa006SGarrett Wollman if (sysctl(name, 4, &initstat, &len, 0, 0) < 0) { 310630fa006SGarrett Wollman error("sysctl getting tcpstat failed"); 311630fa006SGarrett Wollman } 312630fa006SGarrett Wollman oldstat = initstat; 313630fa006SGarrett Wollman } 314630fa006SGarrett Wollman 315630fa006SGarrett Wollman void 316630fa006SGarrett Wollman fetchtcp(void) 317630fa006SGarrett Wollman { 318630fa006SGarrett Wollman int name[4]; 319630fa006SGarrett Wollman size_t len; 320630fa006SGarrett Wollman 321630fa006SGarrett Wollman oldstat = curstat; 322630fa006SGarrett Wollman name[0] = CTL_NET; 323630fa006SGarrett Wollman name[1] = PF_INET; 324630fa006SGarrett Wollman name[2] = IPPROTO_TCP; 325630fa006SGarrett Wollman name[3] = TCPCTL_STATS; 326630fa006SGarrett Wollman len = sizeof curstat; 327630fa006SGarrett Wollman 328630fa006SGarrett Wollman if (sysctl(name, 4, &curstat, &len, 0, 0) < 0) 329630fa006SGarrett Wollman return; 330630fa006SGarrett Wollman } 331630fa006SGarrett Wollman 332