xref: /netbsd-src/usr.bin/netstat/netstat.h (revision a2d67661ff7cb14122e6fe3215b43539a215c137)
1 /*	$NetBSD: netstat.h,v 1.54 2023/08/18 13:18:17 martin 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 extern int	Aflag;		/* show addresses of protocol control block */
38 extern int	aflag;		/* show all sockets (including servers) */
39 extern int	Bflag;		/* show Berkeley Packet Filter information */
40 extern int	bflag;		/* show i/f byte stats */
41 extern int	dflag;		/* show i/f dropped packets */
42 #ifndef SMALL
43 extern int	gflag;		/* show group (multicast) routing or stats */
44 #endif
45 extern int	hflag;		/* humanize byte counts */
46 extern int	iflag;		/* show interfaces */
47 extern int	Lflag;		/* don't show LLINFO entries */
48 extern int	lflag;		/* show routing table with use and ref */
49 extern int	mflag;		/* show memory stats */
50 extern int	numeric_addr;	/* show addresses numerically */
51 extern int	numeric_port;	/* show ports numerically */
52 extern int	nflag;		/* same as above, for show.c compat */
53 extern int	Pflag;		/* dump a PCB */
54 extern int	pflag;		/* show given protocol */
55 extern int	qflag;		/* show softintrq */
56 extern int	rflag;		/* show routing tables (or routing stats) */
57 extern int	sflag;		/* show protocol statistics */
58 extern int	tagflag;	/* show route tags */
59 extern int	tflag;		/* show i/f watchdog timers */
60 extern int	Vflag;	       /* show Vestigial TIME_WAIT (VTW) information */
61 extern int	vflag;	/* verbose route information or don't truncate names */
62 
63 extern char	*interface;   /* desired i/f for stats, or NULL for all i/fs */
64 
65 extern int	af;		/* address family */
66 extern int	use_sysctl;	/* use sysctl instead of kmem */
67 extern 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	nsbpf_stats(void);
141 void	nsbpf_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