summaryrefslogtreecommitdiffstats
path: root/runtime/sym.c
diff options
context:
space:
mode:
authorMark Wielaard <mjw@redhat.com>2009-04-21 20:01:00 +0200
committerMark Wielaard <mjw@redhat.com>2009-04-21 20:01:00 +0200
commit192d5136bbfcd1e61c2f17cc52df875a954d24ec (patch)
tree27dd76c7386e5b8d177756ad8175e5b700f8541a /runtime/sym.c
parent41d9243cc9d107d1980e18537090ed358dc7920a (diff)
parent7d7f074398802c84f544e263995ce15874b9f408 (diff)
downloadsystemtap-steved-192d5136bbfcd1e61c2f17cc52df875a954d24ec.tar.gz
systemtap-steved-192d5136bbfcd1e61c2f17cc52df875a954d24ec.tar.xz
systemtap-steved-192d5136bbfcd1e61c2f17cc52df875a954d24ec.zip
Merge branch 'user_unwind'
Diffstat (limited to 'runtime/sym.c')
-rw-r--r--runtime/sym.c31
1 files changed, 29 insertions, 2 deletions
diff --git a/runtime/sym.c b/runtime/sym.c
index f6f97ac2..013edd0c 100644
--- a/runtime/sym.c
+++ b/runtime/sym.c
@@ -329,8 +329,35 @@ static void _stp_symbol_print(unsigned long address)
}
}
+/** Print an user space address from a specific task symbolically.
+ * @param address The address to lookup.
+ * @param task The address to lookup.
+ * @note Symbolic lookups should not normally be done within
+ * a probe because it is too time-consuming. Use at module exit time.
+ */
+
+static void _stp_usymbol_print(unsigned long address, struct task_struct *task)
+{
+ const char *modname;
+ const char *name;
+ unsigned long offset, size;
+
+ name = _stp_kallsyms_lookup(address, &size, &offset, &modname, NULL,
+ task);
+
+ _stp_printf("%p", (int64_t) address);
+
+ if (name) {
+ if (modname && *modname)
+ _stp_printf(" : %s+%#lx/%#lx [%s]", name, offset, size, modname);
+ else
+ _stp_printf(" : %s+%#lx/%#lx", name, offset, size);
+ }
+}
+
/* Like _stp_symbol_print, except only print if the address is a valid function address */
-static int _stp_func_print(unsigned long address, int verbose, int exact)
+static int _stp_func_print(unsigned long address, int verbose, int exact,
+ struct task_struct *task)
{
const char *modname;
const char *name;
@@ -342,7 +369,7 @@ static int _stp_func_print(unsigned long address, int verbose, int exact)
else
exstr = " (inexact)";
- name = _stp_kallsyms_lookup(address, &size, &offset, &modname, NULL, NULL);
+ name = _stp_kallsyms_lookup(address, &size, &offset, &modname, NULL, task);
if (name) {
if (verbose) {