[<prev] [next>] [day] [month] [year] [list]
Message-Id: <200808160341.m7G3flp6022573@wolfmountaingroup.com>
Date: Fri, 15 Aug 2008 21:41:47 -0600
From: jmerkey@...fmountaingroup.com
To: linux-kernel@...r.kernel.org
Subject: [PATCH 2.6.27-rc3 23/28] mdb: export kallsyms functions
export the kallsyms lookup functions to the module based debugger.
add debugger specific lookup to search for matching strstr text
fragments for entered search terms.
Signed-off-by: Jeffrey Vernon Merkey (jmerkey@...fmountaingroup.com)
--- a/kernel/kallsyms.c 2008-08-15 21:26:27.000000000 -0600
+++ b/kernel/kallsyms.c 2008-08-15 15:41:57.000000000 -0600
@@ -160,6 +160,7 @@
}
return module_kallsyms_lookup_name(name);
}
+EXPORT_SYMBOL_GPL(kallsyms_lookup_name);
static unsigned long get_symbol_pos(unsigned long addr,
unsigned long *symbolsize,
@@ -262,6 +263,7 @@
namebuf);
return NULL;
}
+EXPORT_SYMBOL_GPL(kallsyms_lookup);
int lookup_symbol_name(unsigned long addr, char *symname)
{
@@ -477,5 +479,49 @@
}
__initcall(kallsyms_init);
+#if defined(CONFIG_MDB) || defined(CONFIG_MDB_MODULE)
+struct kallsym_iter mdb_iter;
+int mdb_kallsyms(char *str, int (*print)(char *s, ...))
+{
+ register loff_t pos = 0;
+ register struct kallsym_iter *iter = &mdb_iter;
+
+ if (!print)
+ return 0;
+
+ // set to beginning of the kallsyms list
+ reset_iter(iter, 0);
+ while (1)
+ {
+ // search the kallsyms list
+ if (!update_iter(iter, pos++))
+ break;
+
+ if (!iter->name[0])
+ continue;
+
+ // if an exclusion search was specified, skip non-matching entries
+ if (str && *str && !strstr(iter->name, str))
+ continue;
+
+ if (iter->module_name[0])
+ {
+ if (print("%0*lx %c %s [%s]\n", (int)(2*sizeof(void*)),
+ iter->value, iter->type, iter->name,
+ iter->module_name))
+ return 1;
+ }
+ else
+ {
+ if (print("%0*lx %c %s\n", (int)(2*sizeof(void*)),
+ iter->value, iter->type, iter->name))
+ return 1;
+ }
+ }
+ return 0;
+}
+EXPORT_SYMBOL_GPL(mdb_kallsyms);
+#endif
+
EXPORT_SYMBOL(__print_symbol);
EXPORT_SYMBOL_GPL(sprint_symbol);
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/
Powered by blists - more mailing lists