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