1a9643ea8Slogwang /*-
2*22ce4affSfengbojiang * SPDX-License-Identifier: BSD-2-Clause-FreeBSD
3*22ce4affSfengbojiang *
4a9643ea8Slogwang * Copyright (c) 2010 Bjoern A. Zeeb <[email protected]>
5a9643ea8Slogwang * All rights reserved.
6a9643ea8Slogwang *
7a9643ea8Slogwang * Redistribution and use in source and binary forms, with or without
8a9643ea8Slogwang * modification, are permitted provided that the following conditions
9a9643ea8Slogwang * are met:
10a9643ea8Slogwang * 1. Redistributions of source code must retain the above copyright
11a9643ea8Slogwang * notice, this list of conditions and the following disclaimer.
12a9643ea8Slogwang * 2. Redistributions in binary form must reproduce the above copyright
13a9643ea8Slogwang * notice, this list of conditions and the following disclaimer in the
14a9643ea8Slogwang * documentation and/or other materials provided with the distribution.
15a9643ea8Slogwang *
16a9643ea8Slogwang * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
17a9643ea8Slogwang * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18a9643ea8Slogwang * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19a9643ea8Slogwang * ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
20a9643ea8Slogwang * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
21a9643ea8Slogwang * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
22a9643ea8Slogwang * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
23a9643ea8Slogwang * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
24a9643ea8Slogwang * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
25a9643ea8Slogwang * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26a9643ea8Slogwang * SUCH DAMAGE.
27a9643ea8Slogwang */
28a9643ea8Slogwang
29a9643ea8Slogwang #include <sys/cdefs.h>
30a9643ea8Slogwang __FBSDID("$FreeBSD$");
31a9643ea8Slogwang
32a9643ea8Slogwang #include "opt_ddb.h"
33a9643ea8Slogwang
34a9643ea8Slogwang #include <sys/param.h>
35a9643ea8Slogwang #include <sys/socket.h>
36a9643ea8Slogwang #include <sys/types.h>
37a9643ea8Slogwang
38a9643ea8Slogwang #ifdef DDB
39a9643ea8Slogwang #include <ddb/ddb.h>
40a9643ea8Slogwang #endif
41a9643ea8Slogwang
42a9643ea8Slogwang #include <net/if.h>
43a9643ea8Slogwang #include <net/if_types.h>
44a9643ea8Slogwang #include <net/if_var.h>
45a9643ea8Slogwang #include <net/vnet.h>
46a9643ea8Slogwang
47a9643ea8Slogwang #ifdef DDB
48a9643ea8Slogwang struct ifindex_entry {
49a9643ea8Slogwang struct ifnet *ife_ifnet;
50a9643ea8Slogwang };
51a9643ea8Slogwang VNET_DECLARE(struct ifindex_entry *, ifindex_table);
52a9643ea8Slogwang #define V_ifindex_table VNET(ifindex_table)
53a9643ea8Slogwang
54a9643ea8Slogwang static void
if_show_ifnet(struct ifnet * ifp)55a9643ea8Slogwang if_show_ifnet(struct ifnet *ifp)
56a9643ea8Slogwang {
57a9643ea8Slogwang
58a9643ea8Slogwang if (ifp == NULL)
59a9643ea8Slogwang return;
60a9643ea8Slogwang db_printf("%s:\n", ifp->if_xname);
61a9643ea8Slogwang #define IF_DB_PRINTF(f, e) db_printf(" %s = " f "\n", #e, ifp->e);
62a9643ea8Slogwang IF_DB_PRINTF("%s", if_dname);
63a9643ea8Slogwang IF_DB_PRINTF("%d", if_dunit);
64a9643ea8Slogwang IF_DB_PRINTF("%s", if_description);
65a9643ea8Slogwang IF_DB_PRINTF("%u", if_index);
66a9643ea8Slogwang IF_DB_PRINTF("%u", if_refcount);
67a9643ea8Slogwang IF_DB_PRINTF("%d", if_index_reserved);
68a9643ea8Slogwang IF_DB_PRINTF("%p", if_softc);
69a9643ea8Slogwang IF_DB_PRINTF("%p", if_l2com);
70a9643ea8Slogwang IF_DB_PRINTF("%p", if_llsoftc);
71a9643ea8Slogwang IF_DB_PRINTF("%d", if_amcount);
72a9643ea8Slogwang IF_DB_PRINTF("%p", if_addr);
73a9643ea8Slogwang IF_DB_PRINTF("%p", if_broadcastaddr);
74a9643ea8Slogwang IF_DB_PRINTF("%p", if_afdata);
75a9643ea8Slogwang IF_DB_PRINTF("%d", if_afdata_initialized);
76a9643ea8Slogwang IF_DB_PRINTF("%u", if_fib);
77a9643ea8Slogwang IF_DB_PRINTF("%p", if_vnet);
78a9643ea8Slogwang IF_DB_PRINTF("%p", if_home_vnet);
79a9643ea8Slogwang IF_DB_PRINTF("%p", if_vlantrunk);
80a9643ea8Slogwang IF_DB_PRINTF("%p", if_bpf);
81a9643ea8Slogwang IF_DB_PRINTF("%u", if_pcount);
82a9643ea8Slogwang IF_DB_PRINTF("%p", if_bridge);
83a9643ea8Slogwang IF_DB_PRINTF("%p", if_lagg);
84a9643ea8Slogwang IF_DB_PRINTF("%p", if_pf_kif);
85a9643ea8Slogwang IF_DB_PRINTF("%p", if_carp);
86a9643ea8Slogwang IF_DB_PRINTF("%p", if_label);
87a9643ea8Slogwang IF_DB_PRINTF("%p", if_netmap);
88a9643ea8Slogwang IF_DB_PRINTF("0x%08x", if_flags);
89a9643ea8Slogwang IF_DB_PRINTF("0x%08x", if_drv_flags);
90a9643ea8Slogwang IF_DB_PRINTF("0x%08x", if_capabilities);
91a9643ea8Slogwang IF_DB_PRINTF("0x%08x", if_capenable);
92a9643ea8Slogwang IF_DB_PRINTF("%p", if_snd.ifq_head);
93a9643ea8Slogwang IF_DB_PRINTF("%p", if_snd.ifq_tail);
94a9643ea8Slogwang IF_DB_PRINTF("%d", if_snd.ifq_len);
95a9643ea8Slogwang IF_DB_PRINTF("%d", if_snd.ifq_maxlen);
96a9643ea8Slogwang IF_DB_PRINTF("%p", if_snd.ifq_drv_head);
97a9643ea8Slogwang IF_DB_PRINTF("%p", if_snd.ifq_drv_tail);
98a9643ea8Slogwang IF_DB_PRINTF("%d", if_snd.ifq_drv_len);
99a9643ea8Slogwang IF_DB_PRINTF("%d", if_snd.ifq_drv_maxlen);
100a9643ea8Slogwang IF_DB_PRINTF("%d", if_snd.altq_type);
101a9643ea8Slogwang IF_DB_PRINTF("%x", if_snd.altq_flags);
102a9643ea8Slogwang #undef IF_DB_PRINTF
103a9643ea8Slogwang }
104a9643ea8Slogwang
DB_SHOW_COMMAND(ifnet,db_show_ifnet)105a9643ea8Slogwang DB_SHOW_COMMAND(ifnet, db_show_ifnet)
106a9643ea8Slogwang {
107a9643ea8Slogwang
108a9643ea8Slogwang if (!have_addr) {
109a9643ea8Slogwang db_printf("usage: show ifnet <struct ifnet *>\n");
110a9643ea8Slogwang return;
111a9643ea8Slogwang }
112a9643ea8Slogwang
113a9643ea8Slogwang if_show_ifnet((struct ifnet *)addr);
114a9643ea8Slogwang }
115a9643ea8Slogwang
DB_SHOW_ALL_COMMAND(ifnets,db_show_all_ifnets)116a9643ea8Slogwang DB_SHOW_ALL_COMMAND(ifnets, db_show_all_ifnets)
117a9643ea8Slogwang {
118a9643ea8Slogwang VNET_ITERATOR_DECL(vnet_iter);
119a9643ea8Slogwang struct ifnet *ifp;
120a9643ea8Slogwang u_short idx;
121a9643ea8Slogwang
122a9643ea8Slogwang VNET_FOREACH(vnet_iter) {
123a9643ea8Slogwang CURVNET_SET_QUIET(vnet_iter);
124a9643ea8Slogwang #ifdef VIMAGE
125a9643ea8Slogwang db_printf("vnet=%p\n", curvnet);
126a9643ea8Slogwang #endif
127a9643ea8Slogwang for (idx = 1; idx <= V_if_index; idx++) {
128a9643ea8Slogwang ifp = V_ifindex_table[idx].ife_ifnet;
129a9643ea8Slogwang if (ifp == NULL)
130a9643ea8Slogwang continue;
131a9643ea8Slogwang db_printf( "%20s ifp=%p\n", ifp->if_xname, ifp);
132a9643ea8Slogwang if (db_pager_quit)
133a9643ea8Slogwang break;
134a9643ea8Slogwang }
135a9643ea8Slogwang CURVNET_RESTORE();
136a9643ea8Slogwang }
137a9643ea8Slogwang }
138a9643ea8Slogwang #endif
139