summaryrefslogtreecommitdiffstats
path: root/tracemarks
diff options
context:
space:
mode:
authorSteve Dickson <steved@redhat.com>2008-11-21 12:29:33 -0500
committerSteve Dickson <steved@redhat.com>2008-11-21 12:29:33 -0500
commitc6425b809d873bb602e4192e7ccea56653f6a6db (patch)
tree83825592e84648c58c00251890d7bdd4f2555f27 /tracemarks
parentb4e375cf7ab4f309661d548d0169bbdc10504aab (diff)
downloadsystemtap-c6425b809d873bb602e4192e7ccea56653f6a6db.tar.gz
systemtap-c6425b809d873bb602e4192e7ccea56653f6a6db.tar.xz
systemtap-c6425b809d873bb602e4192e7ccea56653f6a6db.zip
Added sys_bind/inet_bind.stp
Added tracemarks/nfs_mount.trace Signed-off-by: Steve Dickson <steved@redhat.com>
Diffstat (limited to 'tracemarks')
-rw-r--r--tracemarks/nfs_mount.trace160
1 files changed, 160 insertions, 0 deletions
diff --git a/tracemarks/nfs_mount.trace b/tracemarks/nfs_mount.trace
new file mode 100644
index 0000000..78e4981
--- /dev/null
+++ b/tracemarks/nfs_mount.trace
@@ -0,0 +1,160 @@
+%{
+#include <linux/mount.h>
+#include <linux/nfs_mount.h>
+%}
+
+function _fstype_name:string (_fstype:long) %{
+ struct file_system_type *fstype;
+ char *name;
+
+ fstype = (struct file_system_type *)(long)kread(&(THIS->_fstype));
+ name = (char *)(long)kread(&fstype->name);
+
+ snprintf(THIS->__retvalue, MAXSTRINGLEN, "name %s flags 0x%x",
+ name, fstype->fs_flags);
+
+ CATCH_DEREF_FAULT();
+%}
+function _vfsmnt_dump:string (_vfsmnt:long) %{
+ struct vfsmount *vfsmnt;
+ char *dev;
+
+ vfsmnt = (struct vfsmount *)(long)kread(&(THIS->_vfsmnt));
+ dev = (char *)(long)kread(&vfsmnt->mnt_devname);
+
+ snprintf(THIS->__retvalue, MAXSTRINGLEN, "dev %s flags=0x%x",
+ vfsmnt->mnt_devname, vfsmnt->mnt_flags);
+
+ CATCH_DEREF_FAULT();
+%}
+function _nfsmnt_dump:string (_nfsmnt:long) %{
+ struct nfs_mount_data *data;
+ unsigned char *bytes;
+
+ data = (struct nfs_mount_data *)(long)kread(&(THIS->_nfsmnt));
+ bytes = (unsigned char *)&data->addr.sin_addr.s_addr;
+
+ snprintf(THIS->__retvalue, MAXSTRINGLEN,
+ "vers %d flags 0x%x flavor %d hostname %s(%d.%d.%d.%d)",
+ data->version, data->flags, data->pseudoflavor,
+ data->hostname, bytes[0], bytes[1], bytes[2], bytes[3]);
+
+ CATCH_DEREF_FAULT();
+%}
+
+probe kernel.mark("nfs_mount") {
+ printf("nfs_mount:entry: fstype (%s) flags %x dev %s\n",
+ _fstype_name($arg1), $arg2, kernel_string($arg3));
+ printf("\tdata: %s\n\tmnt: %s\n",
+ _nfsmnt_dump($arg4), _vfsmnt_dump($arg5));
+
+}
+probe kernel.mark("nfs_mount_data_null") {
+ printf("nfs_mount: missing mount data: errno %d\n", $arg1);
+}
+probe kernel.mark("nfs_mount_data_badvers") {
+
+ if ($arg1 <= 0) {
+ printf("nfs_mount: invalid mount version: vers %d <= 0\n", $arg1);
+ } else {
+ printf("nfs_mount: invalid mount version: vers %d > %d\n",
+ $arg1, $arg2);
+ }
+}
+probe kernel.mark("nfs_mount_data_invalvers") {
+ if ($arg1 == 3) {
+ printf("nfs_mount: mount structure version %d does not support NFSv3\n", $arg1);
+ } else {
+ printf("nfs_mount: mount structure version %d does not support strong security\n", arg1)
+ }
+}
+probe kernel.mark("nfs_mount_data_noaddr") {
+ printf("nfs_mount: invalid server IP address:\n");
+}
+probe kernel.mark("nfs_mount_data_badsize") {
+ printf("nfs_mount: invalid root filehandle: fhsize %s > maxsize %d\n",
+ arg1, arg2);
+}
+probe kernel.mark("nfs_mount_get_root") {
+ printf("nfs_get_root: sb %p server %p mntfh %p\n", $arg1, $arg2, $arg3);
+}
+probe kernel.mark("nfs_mount_getroot_fhget1") {
+ printf("nfs_get_root: !s_root: nfs_fhget failed: errno %d (%s)\n",
+ $arg1, errno_str($arg1));
+}
+probe kernel.mark("nfs_mount_getroot_alloc1") {
+ printf("nfs_get_root: !s_root: d_alloc_root failed: errno %d (%s)\n",
+ $arg1, errno_str($arg1));
+}
+probe kernel.mark("nfs_mount_getroot_fhget2") {
+ printf("nfs_get_root: nfs_fhget failed: errno %d (%s)\n",
+ $arg1, errno_str($arg1));
+}
+probe kernel.mark("nfs_mount_getroot_alloc2") {
+ printf("nfs_get_root: d_alloc_root failed: errno %d (%s)\n",
+ $arg1, errno_str($arg1));
+}
+probe kernel.mark("nfs_mount_init_clnt") {
+ printf("nfs_init_client: nfs_create_rpc_client failed: errno %d (%s)\n",
+ $arg1, errno_str($arg1));
+}
+probe kernel.mark("nfs_create_rpc_client") {
+ printf("nfs_create_rpc_client: clp %p proto %d timeo %d retrans %d flavor %d",
+ $arg1, $arg2, $arg3, $arg4, $arg5);
+}
+probe kernel.mark("nfs_create_rpc_client_proto") {
+ printf("nfs_create_rpc_client: xprt_create_proto failed: errno %d (%s)\n",
+ $arg1, errno_str($arg1));
+}
+probe kernel.mark("nfs_create_rpc_client_client") {
+ printf("nfs_create_rpc_client: rpc_create_client failed: errno %d (%s)\n",
+ $arg1, errno_str($arg1));
+}
+probe kernel.mark("nfs_mount_init_srv") {
+ printf("nfs_init_server: nfs_get_client failed: errno %d (%s)\n",
+ $arg1, errno_str($arg1));
+}
+probe kernel.mark("nfs_mount_sget") {
+ printf("nfs_init_server: nfs_get_client failed: errno %d (%s)\n",
+ $arg1, errno_str($arg1));
+}
+
+probe kernel.mark("nfs_init_server_rpcclient") {
+ printf("nfs_init_server_rpcclient: server %p flavor %d\n",
+ $arg1, $arg2);
+}
+probe kernel.mark("nfs_init_server_rpcclient_clone") {
+ printf("nfs_init_server_rpcclient: rpc_clone_client failed errno %d (%s)\n",
+ $arg1, errno_str($arg1));
+}
+probe kernel.mark("nfs_init_server_rpcclient_auth") {
+ printf("nfs_init_server_rpcclient: rpcauth_create failed errno %d (%s)\n",
+ $arg1, errno_str($arg1));
+}
+probe kernel.mark("nfs_start_lockd") {
+ // struct nfs_server *server = $arg1;
+
+ printf("nfs_start_lockd: lockd_up_proto failed errno %d (%s)\n",
+ $arg2, errno_str($arg2));
+}
+probe kernel.mark("nfs_probe_fsinfo") {
+ printf("nfs_probe_fsinfo: server %p mntfh %p fattr %p\n",
+ $arg1, $arg2, $arg3);
+}
+probe kernel.mark("nfs_probe_fsinfo_setcaps") {
+ printf("nfs_probe_fsinfo: set_capabilities failed errno %d (%s)\n",
+ $arg1, errno_str($arg1));
+}
+probe kernel.mark("nfs_probe_fsinfo_fsinfo") {
+ printf("nfs_probe_fsinfo: fsinfo failed errno %d (%s)\n",
+ $arg1, errno_str($arg1));
+}
+probe kernel.mark("nfs_create_server") {
+ // struct nfs_server *server = $arg1;
+ // struct nfs_fh *mntfh = $arg2;
+
+ printf("nfs_create_server: getattr failed errno %d (%s)\n",
+ $arg3, errno_str($arg3));
+}
+probe begin { log("starting nfs_mount trace") }
+probe end { log("ending nfs_mount trace") }