Do not display expired or reclaimed vestigial TIME_WAIT entries.

This commit is contained in:
dyoung 2011-05-03 23:36:26 +00:00
parent 0471a19395
commit 7f40ffb8aa
2 changed files with 28 additions and 14 deletions

View File

@ -1,4 +1,4 @@
/* $NetBSD: inet.c,v 1.96 2011/05/03 18:28:46 dyoung Exp $ */ /* $NetBSD: inet.c,v 1.97 2011/05/03 23:36:26 dyoung Exp $ */
/* /*
* Copyright (c) 1983, 1988, 1993 * Copyright (c) 1983, 1988, 1993
@ -34,7 +34,7 @@
#if 0 #if 0
static char sccsid[] = "from: @(#)inet.c 8.4 (Berkeley) 4/20/94"; static char sccsid[] = "from: @(#)inet.c 8.4 (Berkeley) 4/20/94";
#else #else
__RCSID("$NetBSD: inet.c,v 1.96 2011/05/03 18:28:46 dyoung Exp $"); __RCSID("$NetBSD: inet.c,v 1.97 2011/05/03 23:36:26 dyoung Exp $");
#endif #endif
#endif /* not lint */ #endif /* not lint */
@ -162,14 +162,15 @@ protopr0(intptr_t ppcb, u_long rcv_sb_cc, u_long snd_sb_cc,
tcpstates[t_state]); tcpstates[t_state]);
} }
if (Vflag && expires != NULL) { if (Vflag && expires != NULL) {
if (expires->tv_sec != 0 || expires->tv_usec != -1) { if (expires->tv_sec == 0 && expires->tv_usec == -1)
printf(" reclaimed");
else {
struct timeval delta; struct timeval delta;
timersub(expires, &now, &delta); timersub(expires, &now, &delta);
printf(" %.3fms", printf(" %.3fms",
delta.tv_sec * 1000.0 + delta.tv_usec / 1000.0); delta.tv_sec * 1000.0 + delta.tv_usec / 1000.0);
} else }
printf(" expired");
} }
putchar('\n'); putchar('\n');
} }
@ -187,6 +188,7 @@ print_vtw_v4(const vtw_t *vtw)
struct timeval delta; struct timeval delta;
struct in_addr la, fa; struct in_addr la, fa;
char buf[2][32]; char buf[2][32];
static const struct timeval zero = {.tv_sec = 0, .tv_usec = 0};
la.s_addr = v4->laddr; la.s_addr = v4->laddr;
fa.s_addr = v4->faddr; fa.s_addr = v4->faddr;
@ -197,14 +199,19 @@ print_vtw_v4(const vtw_t *vtw)
timersub(&vtw->expire, &now, &delta); timersub(&vtw->expire, &now, &delta);
if (vtw->expire.tv_sec == 0 && vtw->expire.tv_usec == -1) { if (vtw->expire.tv_sec == 0 && vtw->expire.tv_usec == -1) {
dbg_printf("%15.15s:%d %15.15s:%d expired\n" dbg_printf("%15.15s:%d %15.15s:%d reclaimed\n"
,buf[0], ntohs(v4->lport) ,buf[0], ntohs(v4->lport)
,buf[1], ntohs(v4->fport)); ,buf[1], ntohs(v4->fport));
if (!(Vflag && vflag)) if (!(Vflag && vflag))
return; return;
} else if (vtw->expire.tv_sec == 0) } else if (vtw->expire.tv_sec == 0)
return; return;
else { else if (timercmp(&delta, &zero, <) && !(Vflag && vflag)) {
dbg_printf("%15.15s:%d %15.15s:%d expired\n"
,buf[0], ntohs(v4->lport)
,buf[1], ntohs(v4->fport));
return;
} else {
dbg_printf("%15.15s:%d %15.15s:%d expires in %.3fms\n" dbg_printf("%15.15s:%d %15.15s:%d expires in %.3fms\n"
,buf[0], ntohs(v4->lport) ,buf[0], ntohs(v4->lport)
,buf[1], ntohs(v4->fport) ,buf[1], ntohs(v4->fport)

View File

@ -1,4 +1,4 @@
/* $NetBSD: inet6.c,v 1.54 2011/05/03 18:28:46 dyoung Exp $ */ /* $NetBSD: inet6.c,v 1.55 2011/05/03 23:36:26 dyoung Exp $ */
/* BSDI inet.c,v 2.3 1995/10/24 02:19:29 prb Exp */ /* BSDI inet.c,v 2.3 1995/10/24 02:19:29 prb Exp */
/* /*
@ -64,7 +64,7 @@
#if 0 #if 0
static char sccsid[] = "@(#)inet.c 8.4 (Berkeley) 4/20/94"; static char sccsid[] = "@(#)inet.c 8.4 (Berkeley) 4/20/94";
#else #else
__RCSID("$NetBSD: inet6.c,v 1.54 2011/05/03 18:28:46 dyoung Exp $"); __RCSID("$NetBSD: inet6.c,v 1.55 2011/05/03 23:36:26 dyoung Exp $");
#endif #endif
#endif /* not lint */ #endif /* not lint */
@ -217,14 +217,15 @@ ip6protopr0(intptr_t ppcb, u_long rcv_sb_cc, u_long snd_sb_cc,
#endif #endif
} }
if (Vflag && expires != NULL) { if (Vflag && expires != NULL) {
if (expires->tv_sec != 0 || expires->tv_usec != -1) { if (expires->tv_sec == 0 && expires->tv_usec == -1)
printf(" reclaimed");
else {
struct timeval delta; struct timeval delta;
timersub(expires, &now, &delta); timersub(expires, &now, &delta);
printf(" %.3fms", printf(" %.3fms",
delta.tv_sec * 1000.0 + delta.tv_usec / 1000.0); delta.tv_sec * 1000.0 + delta.tv_usec / 1000.0);
} else }
printf(" expired");
} }
putchar('\n'); putchar('\n');
} }
@ -241,6 +242,7 @@ print_vtw_v6(const vtw_t *vtw)
const vtw_v6_t *v6 = (const vtw_v6_t *)vtw; const vtw_v6_t *v6 = (const vtw_v6_t *)vtw;
struct timeval delta; struct timeval delta;
char buf[2][128]; char buf[2][128];
static const struct timeval zero = {.tv_sec = 0, .tv_usec = 0};
inet_ntop(AF_INET6, &v6->laddr, buf[0], sizeof(buf[0])); inet_ntop(AF_INET6, &v6->laddr, buf[0], sizeof(buf[0]));
inet_ntop(AF_INET6, &v6->faddr, buf[1], sizeof(buf[1])); inet_ntop(AF_INET6, &v6->faddr, buf[1], sizeof(buf[1]));
@ -248,14 +250,19 @@ print_vtw_v6(const vtw_t *vtw)
timersub(&vtw->expire, &now, &delta); timersub(&vtw->expire, &now, &delta);
if (vtw->expire.tv_sec == 0 && vtw->expire.tv_usec == -1) { if (vtw->expire.tv_sec == 0 && vtw->expire.tv_usec == -1) {
dbg_printf("%15.15s:%d %15.15s:%d expired\n" dbg_printf("%15.15s:%d %15.15s:%d reclaimed\n"
,buf[0], ntohs(v6->lport) ,buf[0], ntohs(v6->lport)
,buf[1], ntohs(v6->fport)); ,buf[1], ntohs(v6->fport));
if (!(Vflag && vflag)) if (!(Vflag && vflag))
return; return;
} else if (vtw->expire.tv_sec == 0) } else if (vtw->expire.tv_sec == 0)
return; return;
else { else if (timercmp(&delta, &zero, <) && !(Vflag && vflag)) {
dbg_printf("%15.15s:%d %15.15s:%d expired\n"
,buf[0], ntohs(v6->lport)
,buf[1], ntohs(v6->fport));
return;
} else {
dbg_printf("%15.15s:%d %15.15s:%d expires in %.3fms\n" dbg_printf("%15.15s:%d %15.15s:%d expires in %.3fms\n"
,buf[0], ntohs(v6->lport) ,buf[0], ntohs(v6->lport)
,buf[1], ntohs(v6->fport) ,buf[1], ntohs(v6->fport)