-# $OpenBSD: Makefile,v 1.23 2009/06/19 07:48:45 jasper Exp $
+# $OpenBSD: Makefile,v 1.24 2010/07/22 12:33:29 giovanni Exp $
PROG= systat
CFLAGS+=-DNOKVM
CPPFLAGS+=-I${.CURDIR}/../../usr.bin/vmstat
CPPFLAGS+=-I${.CURDIR}/../../sbin/pfctl
-SRCS= dkstats.c engine.c if.c iostat.c main.c mbufs.c netstat.c \
+SRCS= dkstats.c engine.c if.c inetname.c iostat.c main.c mbufs.c netstat.c \
nfs.c pigs.c sensors.c swap.c vmstat.c pftop.c cache.c pf.c \
pool.c malloc.c
--- /dev/null
+/* $OpenBSD: inetname.c,v 1.1 2010/07/22 12:33:29 giovanni Exp $ */
+
+/*-
+ * Copyright (c) 1980, 1992, 1993
+ * The Regents of the University of California. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ * 3. Neither the name of the University nor the names of its contributors
+ * may be used to endorse or promote products derived from this software
+ * without specific prior written permission.
+ *
+ * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
+ * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
+ * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
+ * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
+ * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
+ * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
+ * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
+ * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
+ * SUCH DAMAGE.
+ */
+
+#include <sys/param.h>
+#include <sys/socket.h>
+
+#include <netinet/in.h>
+
+#include <netdb.h>
+#include <stdlib.h>
+#include <string.h>
+
+#include "systat.h"
+
+const char *
+inet6name(struct in6_addr *in6)
+{
+ static char line[NI_MAXHOST];
+ struct sockaddr_in6 sin6;
+ int flags;
+
+ flags = nflag ? NI_NUMERICHOST : 0;
+ if (IN6_IS_ADDR_UNSPECIFIED(in6))
+ return "*";
+ memset(&sin6, 0, sizeof(sin6));
+ sin6.sin6_family = AF_INET6;
+ sin6.sin6_len = sizeof(struct sockaddr_in6);
+ sin6.sin6_addr = *in6;
+ if (getnameinfo((struct sockaddr *)&sin6, sin6.sin6_len,
+ line, sizeof(line), NULL, 0, flags) == 0)
+ return line;
+ return "?";
+}
+
+const char *
+inetname(struct in_addr in)
+{
+ static char line[NI_MAXHOST];
+ struct sockaddr_in si;
+ int flags, e;
+
+ flags = nflag ? NI_NUMERICHOST : 0;
+ if (in.s_addr == INADDR_ANY)
+ return "*";
+
+ memset(&si, 0, sizeof(si));
+ si.sin_family = AF_INET;
+ si.sin_len = sizeof(struct sockaddr_in);
+ si.sin_addr = in;
+
+ e = getnameinfo((struct sockaddr *)&si, si.sin_len,
+ line, sizeof(line), NULL, 0, flags);
+
+ if (e == 0)
+ return line;
+
+ error("Lookup: %s", gai_strerror(e));
+
+ return "?";
+}
-/* $OpenBSD: netstat.c,v 1.32 2008/12/07 02:56:06 canacar Exp $ */
+/* $OpenBSD: netstat.c,v 1.33 2010/07/22 12:33:29 giovanni Exp $ */
/* $NetBSD: netstat.c,v 1.3 1995/06/18 23:53:07 cgd Exp $ */
/*-
#define nif_faddr6 f.nif_faddr6
static void enter(struct inpcb *, struct socket *, int, char *);
-static const char *inetname(struct in_addr);
static void inetprint(struct in_addr *, int, char *, field_def *);
-static const char *inet6name(struct in6_addr *);
static void inet6print(struct in6_addr *, int, char *, field_def *);
static void shownetstat(struct netinfo *p);
print_fld_tb(fld);
}
-static const char *
-inet6name(struct in6_addr *in6)
-{
- static char line[NI_MAXHOST];
- struct sockaddr_in6 sin6;
- int flags;
-
- flags = nflag ? NI_NUMERICHOST : 0;
- if (IN6_IS_ADDR_UNSPECIFIED(in6))
- return "*";
- memset(&sin6, 0, sizeof(sin6));
- sin6.sin6_family = AF_INET6;
- sin6.sin6_len = sizeof(struct sockaddr_in6);
- sin6.sin6_addr = *in6;
- if (getnameinfo((struct sockaddr *)&sin6, sin6.sin6_len,
- line, sizeof(line), NULL, 0, flags) == 0)
- return line;
- return "?";
-}
-
-static const char *
-inetname(struct in_addr in)
-{
- static char line[NI_MAXHOST];
- struct sockaddr_in si;
- int flags, e;
-
- flags = nflag ? NI_NUMERICHOST : 0;
- if (in.s_addr == INADDR_ANY)
- return "*";
-
- memset(&si, 0, sizeof(si));
- si.sin_family = AF_INET;
- si.sin_len = sizeof(struct sockaddr_in);
- si.sin_addr = in;
-
- e = getnameinfo((struct sockaddr *)&si, si.sin_len,
- line, sizeof(line), NULL, 0, flags);
-
- if (e == 0)
- return line;
-
- error("Lookup: %s", gai_strerror(e));
-
- return "?";
-}
-
int
kvm_ckread(void *a, void *b, size_t l)
{
-/* $Id: pftop.c,v 1.14 2009/11/23 21:30:14 henning Exp $ */
+/* $Id: pftop.c,v 1.15 2010/07/22 12:33:29 giovanni Exp $ */
/*
* Copyright (c) 2001, 2007 Can Erkin Acar
* Copyright (c) 2001 Daniel Hartmeier
void
tb_print_addr(struct pf_addr * addr, struct pf_addr * mask, int af)
{
- static char buf[48];
- const char *bf;
-
- bf = inet_ntop(af, addr, buf, sizeof(buf));
- tbprintf("%s", bf);
+ switch (af) {
+ case AF_INET: {
+ tbprintf("%s", inetname(addr->v4));
+ break;
+ }
+ case AF_INET6: {
+ tbprintf("%s", inet6name(&addr->v6));
+ break;
+ }
+ }
if (mask != NULL) {
if (!PF_AZERO(mask, af))
-/* $OpenBSD: systat.h,v 1.14 2009/08/13 23:45:35 deraadt Exp $ */
+/* $OpenBSD: systat.h,v 1.15 2010/07/22 12:33:29 giovanni Exp $ */
/* $NetBSD: systat.h,v 1.2 1995/01/20 08:52:14 jtc Exp $ */
/*-
#ifndef _SYSTAT_H_
#define _SYSTAT_H_
+#include <netinet/in.h>
#include <sys/cdefs.h>
#include <fcntl.h>
#include <kvm.h>
void error(const char *fmt, ...);
void nlisterr(struct nlist []);
+const char *inetname(struct in_addr);
+const char *inet6name(struct in6_addr *);
+
#endif
struct ifcount {