[PATCH 2.6.27-rc1-git5 23/26] mdb: add kallsyms fixes for duplicate names

From: jmerkey
Date: Tue Aug 05 2008 - 03:10:53 EST


Centralized external definitions into include files and corrected
the file to conform to Linux coding practices. fixed word wrap
problems with patches.

add the ability to call through kallsyms and output strstr() matches
for name searches, since modules can have functions that share identical
names with the kernel functions.

Signed-off-by: Jeffrey Vernon Merkey (jmerkey@xxxxxxxxxxxxxxxxxxxxx)

--- a/kernel/kallsyms.c 2008-08-04 15:53:44.000000000 -0600
+++ b/kernel/kallsyms.c 2008-08-04 15:49:51.000000000 -0600
@@ -477,5 +477,48 @@
}
__initcall(kallsyms_init);

+#ifdef CONFIG_MDB
+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;
+}
+#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@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/