2005-04-26 09:54:30 +00:00
|
|
|
--- net-tools-1.60/statistics.c.tcpdata 2005-04-26 10:38:10.000000000 +0200
|
|
|
|
+++ net-tools-1.60/statistics.c 2005-04-26 10:36:19.000000000 +0200
|
|
|
|
@@ -1,6 +1,6 @@
|
|
|
|
/*
|
|
|
|
* Copyright 1997,1999,2000 Andi Kleen. Subject to the GPL.
|
|
|
|
- * $Id: statistics.c,v 1.14 2001/02/02 18:01:23 pb Exp $
|
|
|
|
+ * $Id: statistics.c,v 1.17 2002/04/28 15:41:01 ak Exp $
|
|
|
|
* 19980630 - i18n - Arnaldo Carvalho de Melo <acme@conectiva.com.br>
|
|
|
|
* 19981113 - i18n fixes - Arnaldo Carvalho de Melo <acme@conectiva.com.br>
|
|
|
|
* 19990101 - added net/netstat, -t, -u, -w supprt - Bernd Eckenfels
|
|
|
|
@@ -185,6 +185,44 @@
|
|
|
|
"directly queued to user"), opt_number },
|
|
|
|
{ "SockMallocOOM", N_("Ran %lu times out of system memory during "
|
|
|
|
"packet sending"), opt_number },
|
|
|
|
+ { "TCPPureAcks", N_("%u acknowledgments not containing data received"), opt_number },
|
|
|
|
+ { "TCPHPAcks", N_("%u predicted acknowledgments"), opt_number },
|
|
|
|
+ { "TCPRenoRecovery", N_("%u times recovered from packet loss due to fast retransmit"), opt_number },
|
|
|
|
+ { "TCPSackRecovery", N_("%u times recovered from packet loss due to SACK data"), opt_number },
|
|
|
|
+ { "TCPSACKReneging", N_("%u bad SACKs received"), opt_number },
|
|
|
|
+ { "TCPFACKReorder", N_("Detected reordering %u times using FACK"), opt_number },
|
|
|
|
+ { "TCPSACKReorder", N_("Detected reordering %u times using SACK"), opt_number },
|
|
|
|
+ { "TCPTSReorder", N_("Detected reordering %u times using time stamp"), opt_number },
|
|
|
|
+ { "TCPRenoReorder", N_("Detected reordering %u times using reno fast retransmit"), opt_number },
|
|
|
|
+ { "TCPFullUndo", N_("%u congestion windows fully recovered"), opt_number },
|
|
|
|
+ { "TCPPartialUndo", N_("%u congestion windows partially recovered using Hoe heuristic"), opt_number },
|
|
|
|
+ { "TCPDSackUndo", N_("%u congestion window recovered using DSACK"), opt_number },
|
|
|
|
+ { "TCPLossUndo", N_("%u congestion windows recovered after partial ack"), opt_number },
|
|
|
|
+ { "TCPLostRetransmits", N_("%u retransmits lost"), opt_number },
|
|
|
|
+ { "TCPRenoFailures", N_("%u timeouts after reno fast retransmit"), opt_number },
|
|
|
|
+ { "TCPSackFailures", N_("%u timeouts after SACK recovery"), opt_number },
|
|
|
|
+ { "TCPLossFailures", N_("%u timeouts in loss state"), opt_number },
|
|
|
|
+ { "TCPFastRetrans", N_("%u fast retransmits"), opt_number },
|
|
|
|
+ { "TCPForwardRetrans", N_("%u forward retransmits"), opt_number },
|
|
|
|
+ { "TCPSlowStartRetrans", N_("%u retransmits in slow start"), opt_number },
|
|
|
|
+ { "TCPTimeouts", N_("%u other TCP timeouts"), opt_number },
|
|
|
|
+ { "TCPRenoRecoveryFailed", N_("%u reno fast retransmits failed"), opt_number },
|
|
|
|
+ { "TCPSackRecoveryFail", N_("%u sack retransmits failed"), opt_number },
|
|
|
|
+ { "TCPSchedulerFailed", N_("%u times receiver scheduled too late for direct processing"), opt_number },
|
|
|
|
+ { "TCPRcvCollapsed", N_("%u packets collapsed in receive queue due to low socket buffer"), opt_number },
|
|
|
|
+ { "TCPDSACKOldSent", N_("%u DSACKs sent for old packets"), opt_number },
|
|
|
|
+ { "TCPDSACKOfoSent", N_("%u DSACKs sent for out of order packets"), opt_number },
|
|
|
|
+ { "TCPDSACKRecv", N_("%u DSACKs received"), opt_number },
|
|
|
|
+ { "TCPDSACKOfoRecv", N_("%u DSACKs for out of order packets received"), opt_number },
|
|
|
|
+ { "TCPAbortOnSyn", N_("%u connections reset due to unexpected SYN"), opt_number },
|
|
|
|
+ { "TCPAbortOnData", N_("%u connections reset due to unexpected data"), opt_number },
|
|
|
|
+ { "TCPAbortOnClose", N_("%u connections reset due to early user close"), opt_number },
|
|
|
|
+ { "TCPAbortOnMemory", N_("%u connections aborted due to memory pressure"), opt_number },
|
|
|
|
+ { "TCPAbortOnTimeout", N_("%u connections aborted due to timeout"), opt_number },
|
|
|
|
+ { "TCPAbortOnLinger", N_("%u connections aborted after user close in linger timeout"), opt_number },
|
2010-04-07 11:40:25 +00:00
|
|
|
+ { "TCPAbortFailed", N_("%u times unable to send RST due to no memory"), opt_number },
|
2005-04-26 09:54:30 +00:00
|
|
|
+ { "TCPMemoryPressures", N_("TCP ran low on memory %u times"), opt_number },
|
|
|
|
+ { "TCPLoss", N_("%u TCP data loss events") },
|
|
|
|
};
|
|
|
|
|
|
|
|
struct tabtab {
|
|
|
|
@@ -222,7 +260,8 @@
|
|
|
|
ent = bsearch(&key, tab->tab, tab->size / sizeof(struct entry),
|
|
|
|
sizeof(struct entry), cmpentries);
|
|
|
|
if (!ent) { /* try our best */
|
|
|
|
- printf("%*s%s: %d\n", states[state].indent, "", title, val);
|
|
|
|
+ if (val)
|
|
|
|
+ printf("%*s%s: %d\n", states[state].indent, "", title, val);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
type = ent->type;
|