summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorjhb <jhb@FreeBSD.org>2012-06-01 15:42:37 +0000
committerjhb <jhb@FreeBSD.org>2012-06-01 15:42:37 +0000
commit65701cddc9e2eb398f8ff8c7ff23fbb5e85281b5 (patch)
treed8887e29891ce1bc3ab07b04bd400950fd30fcf8
parent9cbcc3c49217bb72870e849e6d29f60a7f7523f4 (diff)
downloadFreeBSD-src-65701cddc9e2eb398f8ff8c7ff23fbb5e85281b5.zip
FreeBSD-src-65701cddc9e2eb398f8ff8c7ff23fbb5e85281b5.tar.gz
Extend VERBOSE_SYSINIT to also print out the name of variables passed
to SYSINIT routines if they can be resolved via symbol look up in DDB. To avoid false positives, only honor a name if the symbol resolves exactly to the pointer value (no offset). MFC after: 1 week
-rw-r--r--sys/kern/init_main.c37
1 files changed, 28 insertions, 9 deletions
diff --git a/sys/kern/init_main.c b/sys/kern/init_main.c
index d6cd3d7..ba905e0 100644
--- a/sys/kern/init_main.c
+++ b/sys/kern/init_main.c
@@ -158,6 +158,24 @@ sysinit_add(struct sysinit **set, struct sysinit **set_end)
newsysinit_end = newset + count;
}
+#if defined (DDB) && defined(VERBOSE_SYSINIT)
+static const char *
+symbol_name(vm_offset_t va, db_strategy_t strategy)
+{
+ const char *name;
+ c_db_sym_t sym;
+ db_expr_t offset;
+
+ if (va == 0)
+ return (NULL);
+ sym = db_search_symbol(va, strategy, &offset);
+ if (offset != 0)
+ return (NULL);
+ db_symbol_values(sym, &name, NULL);
+ return (name);
+}
+#endif
+
/*
* System startup; initialize the world, create process 0, mount root
* filesystem, and fork to create init and pagedaemon. Most of the
@@ -238,15 +256,16 @@ restart:
}
if (verbose) {
#if defined(DDB)
- const char *name;
- c_db_sym_t sym;
- db_expr_t offset;
-
- sym = db_search_symbol((vm_offset_t)(*sipp)->func,
- DB_STGY_PROC, &offset);
- db_symbol_values(sym, &name, NULL);
- if (name != NULL)
- printf(" %s(%p)... ", name, (*sipp)->udata);
+ const char *func, *data;
+
+ func = symbol_name((vm_offset_t)(*sipp)->func,
+ DB_STGY_PROC);
+ data = symbol_name((vm_offset_t)(*sipp)->udata,
+ DB_STGY_ANY);
+ if (func != NULL && data != NULL)
+ printf(" %s(&%s)... ", func, data);
+ else if (func != NULL)
+ printf(" %s(%p)... ", func, (*sipp)->udata);
else
#endif
printf(" %p(%p)... ", (*sipp)->func,
OpenPOWER on IntegriCloud