summaryrefslogtreecommitdiffstats
path: root/sys/net/if.c
diff options
context:
space:
mode:
authorbz <bz@FreeBSD.org>2010-10-25 08:30:19 +0000
committerbz <bz@FreeBSD.org>2010-10-25 08:30:19 +0000
commit491af1942e7b255ff4e89c5c3e46c0cafeeb1e04 (patch)
tree6492d5d860095d5b5605d6ca31fd08cda152419a /sys/net/if.c
parent7844c829a46403931997ca16c550800610c96029 (diff)
downloadFreeBSD-src-491af1942e7b255ff4e89c5c3e46c0cafeeb1e04.zip
FreeBSD-src-491af1942e7b255ff4e89c5c3e46c0cafeeb1e04.tar.gz
Factor out DDB commands from r204145, r204279 into if_debug.c for further
enhancements (1). Switch to a standard 2-clause BSD license for this (2). Unfortunately we have to un-static the ifindex_table for this but do not publicly export it. Suggested by: rwatson (1) a while back. Approved by: thompsa (2) for the change from r204279. MFC after: 6 days
Diffstat (limited to 'sys/net/if.c')
-rw-r--r--sys/net/if.c83
1 files changed, 1 insertions, 82 deletions
diff --git a/sys/net/if.c b/sys/net/if.c
index 3c8486a..17f01e9 100644
--- a/sys/net/if.c
+++ b/sys/net/if.c
@@ -33,7 +33,6 @@
#include "opt_compat.h"
#include "opt_inet6.h"
#include "opt_inet.h"
-#include "opt_ddb.h"
#include <sys/param.h>
#include <sys/types.h>
@@ -62,10 +61,6 @@
#include <machine/stdarg.h>
#include <vm/uma.h>
-#ifdef DDB
-#include <ddb/ddb.h>
-#endif
-
#include <net/if.h>
#include <net/if_arp.h>
#include <net/if_clone.h>
@@ -191,7 +186,7 @@ VNET_DEFINE(struct ifgrouphead, ifg_head);
static VNET_DEFINE(int, if_indexlim) = 8;
/* Table of ifnet by index. */
-static VNET_DEFINE(struct ifindex_entry *, ifindex_table);
+VNET_DEFINE(struct ifindex_entry *, ifindex_table);
#define V_if_indexlim VNET(if_indexlim)
#define V_ifindex_table VNET(ifindex_table)
@@ -3366,79 +3361,3 @@ if_deregister_com_alloc(u_char type)
if_com_alloc[type] = NULL;
if_com_free[type] = NULL;
}
-
-#ifdef DDB
-static void
-if_show_ifnet(struct ifnet *ifp)
-{
-
- if (ifp == NULL)
- return;
- db_printf("%s:\n", ifp->if_xname);
-#define IF_DB_PRINTF(f, e) db_printf(" %s = " f "\n", #e, ifp->e);
- IF_DB_PRINTF("%s", if_dname);
- IF_DB_PRINTF("%d", if_dunit);
- IF_DB_PRINTF("%s", if_description);
- IF_DB_PRINTF("%u", if_index);
- IF_DB_PRINTF("%u", if_refcount);
- IF_DB_PRINTF("%d", if_index_reserved);
- IF_DB_PRINTF("%p", if_softc);
- IF_DB_PRINTF("%p", if_l2com);
- IF_DB_PRINTF("%p", if_vnet);
- IF_DB_PRINTF("%p", if_home_vnet);
- IF_DB_PRINTF("%p", if_addr);
- IF_DB_PRINTF("%p", if_llsoftc);
- IF_DB_PRINTF("%p", if_label);
- IF_DB_PRINTF("%u", if_pcount);
- IF_DB_PRINTF("0x%08x", if_flags);
- IF_DB_PRINTF("0x%08x", if_drv_flags);
- IF_DB_PRINTF("0x%08x", if_capabilities);
- IF_DB_PRINTF("0x%08x", if_capenable);
- IF_DB_PRINTF("%p", if_snd.ifq_head);
- IF_DB_PRINTF("%p", if_snd.ifq_tail);
- IF_DB_PRINTF("%d", if_snd.ifq_len);
- IF_DB_PRINTF("%d", if_snd.ifq_maxlen);
- IF_DB_PRINTF("%d", if_snd.ifq_drops);
- IF_DB_PRINTF("%p", if_snd.ifq_drv_head);
- IF_DB_PRINTF("%p", if_snd.ifq_drv_tail);
- IF_DB_PRINTF("%d", if_snd.ifq_drv_len);
- IF_DB_PRINTF("%d", if_snd.ifq_drv_maxlen);
- IF_DB_PRINTF("%d", if_snd.altq_type);
- IF_DB_PRINTF("%x", if_snd.altq_flags);
-#undef IF_DB_PRINTF
-}
-
-DB_SHOW_COMMAND(ifnet, db_show_ifnet)
-{
-
- if (!have_addr) {
- db_printf("usage: show ifnet <struct ifnet *>\n");
- return;
- }
-
- if_show_ifnet((struct ifnet *)addr);
-}
-
-DB_SHOW_ALL_COMMAND(ifnets, db_show_all_ifnets)
-{
- VNET_ITERATOR_DECL(vnet_iter);
- struct ifnet *ifp;
- u_short idx;
-
- VNET_FOREACH(vnet_iter) {
- CURVNET_SET_QUIET(vnet_iter);
-#ifdef VIMAGE
- db_printf("vnet=%p\n", curvnet);
-#endif
- for (idx = 1; idx <= V_if_index; idx++) {
- ifp = V_ifindex_table[idx].ife_ifnet;
- if (ifp == NULL)
- continue;
- db_printf( "%20s ifp=%p\n", ifp->if_xname, ifp);
- if (db_pager_quit)
- break;
- }
- CURVNET_RESTORE();
- }
-}
-#endif
OpenPOWER on IntegriCloud