xref: /minix/usr.bin/netstat/netstat.h (revision d642636d)
1 /*	$NetBSD: netstat.h,v 1.51 2014/11/06 21:30:09 christos Exp $	*/
2 
3 /*
4  * Copyright (c) 1992, 1993
5  *	Regents of the University of California.  All rights reserved.
6  *
7  * Redistribution and use in source and binary forms, with or without
8  * modification, are permitted provided that the following conditions
9  * are met:
10  * 1. Redistributions of source code must retain the above copyright
11  *    notice, this list of conditions and the following disclaimer.
12  * 2. Redistributions in binary form must reproduce the above copyright
13  *    notice, this list of conditions and the following disclaimer in the
14  *    documentation and/or other materials provided with the distribution.
15  * 3. Neither the name of the University nor the names of its contributors
16  *    may be used to endorse or promote products derived from this software
17  *    without specific prior written permission.
18  *
19  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
20  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
21  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
22  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
23  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
24  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
25  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
26  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
27  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
28  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
29  * SUCH DAMAGE.
30  *
31  *	from: @(#)netstat.h	8.2 (Berkeley) 1/4/94
32  */
33 
34 #include <sys/cdefs.h>
35 #include <kvm.h>
36 
37 int	Aflag;		/* show addresses of protocol control block */
38 int	aflag;		/* show all sockets (including servers) */
39 int	Bflag;		/* show Berkeley Packet Filter information */
40 int	bflag;		/* show i/f byte stats */
41 int	dflag;		/* show i/f dropped packets */
42 #ifndef SMALL
43 int	gflag;		/* show group (multicast) routing or stats */
44 #endif
45 int	hflag;		/* humanize byte counts */
46 int	iflag;		/* show interfaces */
47 int	Lflag;		/* don't show LLINFO entries */
48 int	lflag;		/* show routing table with use and ref */
49 int	mflag;		/* show memory stats */
50 int	numeric_addr;	/* show addresses numerically */
51 int	numeric_port;	/* show ports numerically */
52 int	nflag;		/* same as above, for show.c compat */
53 int	Pflag;		/* dump a PCB */
54 int	pflag;		/* show given protocol */
55 int	qflag;		/* show softintrq */
56 int	rflag;		/* show routing tables (or routing stats) */
57 int	sflag;		/* show protocol statistics */
58 int	tagflag;	/* show route tags */
59 int	tflag;		/* show i/f watchdog timers */
60 int	Vflag;		/* show Vestigial TIME_WAIT (VTW) information */
61 int	vflag;		/* verbose route information or don't truncate names */
62 
63 char	*interface;	/* desired i/f for stats, or NULL for all i/fs */
64 
65 int	af;		/* address family */
66 int	use_sysctl;	/* use sysctl instead of kmem */
67 int	force_sysctl;	/* force use of sysctl (or exit) - for testing */
68 
69 
70 int	kread(u_long addr, char *buf, int size);
71 const char *plural(int);
72 const char *plurales(int);
73 int	get_hardticks(void);
74 
75 void	protopr(u_long, const char *);
76 void	tcp_stats(u_long, const char *);
77 void	tcp_dump(u_long, const char *, u_long);
78 void	udp_stats(u_long, const char *);
79 void	ip_stats(u_long, const char *);
80 void	icmp_stats(u_long, const char *);
81 void	igmp_stats(u_long, const char *);
82 void	pim_stats(u_long, const char *);
83 void	arp_stats(u_long, const char *);
84 void	carp_stats(u_long, const char *);
85 void	pfsync_stats(u_long, const char*);
86 #ifdef IPSEC
87 void	fast_ipsec_stats(u_long, const char *);
88 #endif
89 
90 #ifdef INET6
91 struct sockaddr_in6;
92 struct in6_addr;
93 void	ip6protopr(u_long, const char *);
94 void	tcp6_stats(u_long, const char *);
95 void	tcp6_dump(u_long, const char *, u_long);
96 void	udp6_stats(u_long, const char *);
97 void	ip6_stats(u_long, const char *);
98 void	ip6_ifstats(const char *);
99 void	icmp6_stats(u_long, const char *);
100 void	icmp6_ifstats(const char *);
101 void	pim6_stats(u_long, const char *);
102 void	rip6_stats(u_long, const char *);
103 void	mroute6pr(u_long, u_long, u_long);
104 void	mrt6_stats(u_long, u_long);
105 #endif /*INET6*/
106 
107 #ifdef IPSEC
108 void	pfkey_stats(u_long, const char *);
109 #endif
110 
111 void	mbpr(u_long, u_long, u_long, u_long, u_long);
112 
113 void	hostpr(u_long, u_long);
114 void	impstats(u_long, u_long);
115 
116 void	rt_stats(u_long);
117 char	*ns_phost(struct sockaddr *);
118 
119 const char *atalk_print(const struct sockaddr *, int);
120 const char *atalk_print2(const struct sockaddr *, const struct sockaddr *,
121     int);
122 char	*ns_print(struct sockaddr *);
123 
124 void	nsprotopr(u_long, const char *);
125 void	spp_stats(u_long, const char *);
126 void	idp_stats(u_long, const char *);
127 void	nserr_stats(u_long, const char *);
128 
129 void	atalkprotopr(u_long, const char *);
130 void	ddp_stats(u_long, const char *);
131 
132 void	intpr(int, u_long, void (*)(const char *));
133 
134 void	unixpr(u_long);
135 
136 void	routepr(u_long);
137 void	mroutepr(u_long, u_long, u_long, u_long);
138 void	mrt_stats(u_long, u_long);
139 
140 void	bpf_stats(void);
141 void	bpf_dump(const char *);
142 
143 kvm_t *get_kvmd(void);
144 
145 char	*mpls_ntoa(const struct sockaddr *);
146 
147 struct kinfo_pcb *getpcblist_sysctl(const char *, size_t *);
148 
149 #define PLEN    (LONG_BIT / 4 + 2)
150