summaryrefslogtreecommitdiffstats
path: root/tapset/conversions.stp
diff options
context:
space:
mode:
authorDavid Smith <dsmith@redhat.com>2010-04-07 16:02:24 -0500
committerDavid Smith <dsmith@redhat.com>2010-04-07 16:02:24 -0500
commit65dd4b7405baeee812f6d41f0ee74824b601a47a (patch)
tree3deb1c995125d6a1e72d939c270173192044a3b3 /tapset/conversions.stp
parent7dfee5e63d57d39677188b9edaa2cad366a1a6e1 (diff)
downloadsystemtap-steved-65dd4b7405baeee812f6d41f0ee74824b601a47a.tar.gz
systemtap-steved-65dd4b7405baeee812f6d41f0ee74824b601a47a.tar.xz
systemtap-steved-65dd4b7405baeee812f6d41f0ee74824b601a47a.zip
Added kernel_pointer()/set_kernel_pointer() tapset functions.
* tapset/conversions.stp (kernel_pointer): New function. * tapset/conversions-guru.stp (set_kernel_pointer): Ditto. * testsuite/buildok/conversions-embedded.stp: Added kernel_pointer() test. * testsuite/buildok/conversions.stp: Ditto. * testsuite/buildok/set_kernel.stp: Added set_kernel_pointer() test. * tapset/nfs.stp: Removed __d_loff_t() function. Uses new kernel_pointer() function instead. * testsuite/buildok/nfs-embedded.stp: Removed __d_loff_t() test.
Diffstat (limited to 'tapset/conversions.stp')
-rw-r--r--tapset/conversions.stp20
1 files changed, 19 insertions, 1 deletions
diff --git a/tapset/conversions.stp b/tapset/conversions.stp
index 3bbbb725..fbaba6e4 100644
--- a/tapset/conversions.stp
+++ b/tapset/conversions.stp
@@ -1,5 +1,5 @@
// conversions tapset
-// Copyright (C) 2005-2009 Red Hat Inc.
+// Copyright (C) 2005-2010 Red Hat Inc.
// Copyright (C) 2007 Intel Corporation.
//
// This file is part of systemtap, and is free software. You can
@@ -113,6 +113,24 @@ deref_fault: /* branched to from kread() */
}
%}
+/**
+ * sfunction kernel_pointer - Retrieves a pointer value stored in
+ * kernel memory.
+ * @addr: The kernel address to retrieve the pointer from.
+ *
+ * Description: Returns the pointer value from a given kernel memory
+ * address. Reports an error when reading from the given address
+ * fails.
+ */
+function kernel_pointer:long (addr:long) %{ /* pure */
+ THIS->__retvalue = (int64_t) kread((void **) (intptr_t) THIS->addr);
+ if (0) {
+deref_fault: /* branched to from kread() */
+ snprintf (CONTEXT->error_buffer, sizeof(CONTEXT->error_buffer),
+ "kernel pointer copy fault at 0x%p", (void *) (uintptr_t) THIS->addr);
+ CONTEXT->last_error = CONTEXT->error_buffer;
+ }
+%}
/**
* sfunction user_string - Retrieves string from user space.