netstat.h revision 1.34 1 /* $NetBSD: netstat.h,v 1.34 2006/05/23 14:31:11 rpaulo 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
36 int Aflag; /* show addresses of protocol control block */
37 int aflag; /* show all sockets (including servers) */
38 int Bflag; /* show Berkeley Packet Filter information */
39 int bflag; /* show i/f byte stats */
40 int dflag; /* show i/f dropped packets */
41 #ifndef SMALL
42 int gflag; /* show group (multicast) routing or stats */
43 #endif
44 int iflag; /* show interfaces */
45 int Lflag; /* don't show LLINFO entries */
46 int lflag; /* show routing table with use and ref */
47 int mflag; /* show memory stats */
48 int numeric_addr; /* show addresses numerically */
49 int numeric_port; /* show ports numerically */
50 int Pflag; /* dump a PCB */
51 int pflag; /* show given protocol */
52 int qflag; /* show softintrq */
53 int rflag; /* show routing tables (or routing stats) */
54 int sflag; /* show protocol statistics */
55 int tflag; /* show i/f watchdog timers */
56 int vflag; /* verbose route information or don't truncate names */
57
58 int interval; /* repeat interval for i/f stats */
59
60 char *interface; /* desired i/f for stats, or NULL for all i/fs */
61
62 int af; /* address family */
63 int use_sysctl; /* use sysctl instead of kmem */
64
65
66 int kread __P((u_long addr, char *buf, int size));
67 char *plural __P((int));
68 char *plurales __P((int));
69 int get_hardticks __P((void));
70
71 void protopr __P((u_long, char *));
72 void tcp_stats __P((u_long, char *));
73 void tcp_dump __P((u_long));
74 void udp_stats __P((u_long, char *));
75 void ip_stats __P((u_long, char *));
76 void icmp_stats __P((u_long, char *));
77 void igmp_stats __P((u_long, char *));
78 void pim_stats __P((u_long, char *));
79 void arp_stats __P((u_long, char *));
80 void carp_stats __P((u_long, char *));
81 #ifdef IPSEC
82 /* run-time selector for which implementation (KAME, FAST_IPSEC) to show */
83 void ipsec_switch __P((u_long, char *));
84 /* KAME ipsec version */
85 void ipsec_stats __P((u_long, char *));
86 /* FAST_IPSEC version */
87 void fast_ipsec_stats __P((u_long, char *));
88 #endif
89
90 #ifdef INET6
91 struct sockaddr_in6;
92 struct in6_addr;
93 void ip6protopr __P((u_long, char *));
94 void tcp6_stats __P((u_long, char *));
95 void tcp6_dump __P((u_long));
96 void udp6_stats __P((u_long, char *));
97 void ip6_stats __P((u_long, char *));
98 void ip6_ifstats __P((char *));
99 void icmp6_stats __P((u_long, char *));
100 void icmp6_ifstats __P((char *));
101 void pim6_stats __P((u_long, char *));
102 void rip6_stats __P((u_long, char *));
103 void mroute6pr __P((u_long, u_long, u_long));
104 void mrt6_stats __P((u_long, u_long));
105 char *routename6 __P((struct sockaddr_in6 *));
106 #endif /*INET6*/
107
108 #ifdef IPSEC
109 void pfkey_stats __P((u_long, char *));
110 #endif
111
112 void mbpr(u_long, u_long, u_long, u_long, u_long);
113
114 void hostpr __P((u_long, u_long));
115 void impstats __P((u_long, u_long));
116
117 void pr_rthdr __P((int));
118 void pr_family __P((int));
119 void rt_stats __P((u_long));
120 char *ns_phost __P((struct sockaddr *));
121 void upHex __P((char *));
122
123 char *routename __P((u_int32_t));
124 char *netname __P((u_int32_t, u_int32_t));
125 #ifdef INET6
126 char *netname6 __P((struct sockaddr_in6 *, struct in6_addr *));
127 #endif
128 char *atalk_print __P((const struct sockaddr *, int));
129 char *atalk_print2 __P((const struct sockaddr *, const struct sockaddr *,
130 int));
131 char *ns_print __P((struct sockaddr *));
132 void routepr __P((u_long));
133
134 void nsprotopr __P((u_long, char *));
135 void spp_stats __P((u_long, char *));
136 void idp_stats __P((u_long, char *));
137 void nserr_stats __P((u_long, char *));
138
139 void atalkprotopr __P((u_long, char *));
140 void ddp_stats __P((u_long, char *));
141
142 void intpr __P((int, u_long, void (*) __P((char *))));
143
144 void unixpr __P((u_long));
145
146 void esis_stats __P((u_long, char *));
147 void clnp_stats __P((u_long, char *));
148 void cltp_stats __P((u_long, char *));
149 void iso_protopr __P((u_long, char *));
150 void iso_protopr1 __P((u_long, int));
151 void tp_protopr __P((u_long, char *));
152 void tp_inproto __P((u_long));
153 void tp_stats __P((u_long, caddr_t));
154
155 void mroutepr __P((u_long, u_long, u_long, u_long));
156 void mrt_stats __P((u_long, u_long));
157
158 void bpf_stats(void);
159 void bpf_dump(char *);
160