Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/usr.bin/netstat Don't show any of the completely and utterly...
details: https://anonhg.NetBSD.org/src/rev/985d13ed0ecb
branches: trunk
changeset: 1019214:985d13ed0ecb
user: simonb <simonb%NetBSD.org@localhost>
date: Tue Mar 02 01:02:12 2021 +0000
description:
Don't show any of the completely and utterly undocumented VTW info if
the feature isn't enabled (by checking net.inet.tcp.vtw.enable).
diffstat:
usr.bin/netstat/vtw.c | 36 ++++++++++++++++++++++++++++++++++--
1 files changed, 34 insertions(+), 2 deletions(-)
diffs (89 lines):
diff -r bc3700358615 -r 985d13ed0ecb usr.bin/netstat/vtw.c
--- a/usr.bin/netstat/vtw.c Tue Mar 02 00:28:55 2021 +0000
+++ b/usr.bin/netstat/vtw.c Tue Mar 02 01:02:12 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: vtw.c,v 1.10 2018/05/03 07:13:48 maxv Exp $ */
+/* $NetBSD: vtw.c,v 1.11 2021/03/02 01:02:12 simonb Exp $ */
/*
* Copyright (c) 2011 The NetBSD Foundation, Inc.
@@ -62,7 +62,7 @@
#if 0
static char sccsid[] = "from: @(#)inet.c 8.4 (Berkeley) 4/20/94";
#else
-__RCSID("$NetBSD: vtw.c,v 1.10 2018/05/03 07:13:48 maxv Exp $");
+__RCSID("$NetBSD: vtw.c,v 1.11 2021/03/02 01:02:12 simonb Exp $");
#endif
#endif /* not lint */
@@ -115,10 +115,28 @@
#include "vtw.h"
#include "prog_ops.h"
+static bool vtw_enabled(void);
static void snarf(const void *, void *, size_t);
static void *lookup(const char *);
static void process_vtw(const vtw_ctl_t *, void (*)(const vtw_t *));
+static bool
+vtw_enabled(void)
+{
+
+ if (use_sysctl) {
+ int enabled;
+ size_t size = sizeof(enabled);
+
+ if (prog_sysctlbyname("net.inet.tcp.vtw.enable",
+ &enabled, &size, NULL, 0) == -1)
+ return true;
+ return enabled ? true : false;
+ } else {
+ return true;
+ }
+}
+
static void
snarf(const void *addr, void *buf, size_t len)
{
@@ -172,6 +190,11 @@
void *p;
struct bintime timebasebin;
+ if (!vtw_enabled()) {
+ memset(tv, 0, sizeof(*tv));
+ return;
+ }
+
p = lookup("timebasebin");
if (!p)
return;
@@ -209,6 +232,9 @@
if (!Vflag)
return;
+ if (!vtw_enabled())
+ return;
+
if ((p = lookup("vtw_stats")) == NULL)
return;
snarf(p, &stats, sizeof(stats));
@@ -248,6 +274,9 @@
int mem = 0;
void *p;
+ if (!vtw_enabled())
+ return;
+
if ((p = lookup("fat_tcpv4")) == NULL)
return;
snarf(p, &fat_tcpv4, sizeof(fat_tcpv4));
@@ -350,6 +379,9 @@
int mem = 0;
void *p;
+ if (!vtw_enabled())
+ return;
+
if ((p = lookup("fat_tcpv6")) == NULL)
return;
snarf(p, &fat_tcpv6, sizeof(fat_tcpv6));
Home |
Main Index |
Thread Index |
Old Index