diff options
author | ddomingo <ddomingo@redhat.com> | 2009-03-17 15:31:54 +1000 |
---|---|---|
committer | ddomingo <ddomingo@redhat.com> | 2009-03-17 15:31:54 +1000 |
commit | b9315d945fa0700f9a1d8cf9185c66388d29023c (patch) | |
tree | 8965c368ed7ef5ff8bc835a76fa61b241133f933 /tapset/task.stp | |
parent | 4e7c048f5184ffcb06bc64d8be6e859156c8af97 (diff) | |
parent | bdca08879745471fdb86991a8e7276900aaaf066 (diff) | |
download | systemtap-steved-b9315d945fa0700f9a1d8cf9185c66388d29023c.tar.gz systemtap-steved-b9315d945fa0700f9a1d8cf9185c66388d29023c.tar.xz systemtap-steved-b9315d945fa0700f9a1d8cf9185c66388d29023c.zip |
Merge branch 'master' of ssh://sources.redhat.com/git/systemtap
Diffstat (limited to 'tapset/task.stp')
-rw-r--r-- | tapset/task.stp | 24 |
1 files changed, 24 insertions, 0 deletions
diff --git a/tapset/task.stp b/tapset/task.stp index 07337156..f1a10b0a 100644 --- a/tapset/task.stp +++ b/tapset/task.stp @@ -63,6 +63,30 @@ function task_pid:long (task:long) } +// Return the task of the given process id +function pid2task:long (pid:long) %{ /* pure */ + struct task_struct *t = NULL; + pid_t t_pid = (pid_t)(long)THIS->pid; + rcu_read_lock(); +#if LINUX_VERSION_CODE >= KERNEL_VERSION(2,6,24) + t = find_task_by_vpid (t_pid); +#else + t = find_task_by_pid (t_pid); +#endif + rcu_read_unlock(); + THIS->__retvalue = (long)t; + CATCH_DEREF_FAULT(); +%} + +// Return the name of the given process id +function pid2execname:string (pid:long) { + tsk = pid2task(pid) + if (tsk) + return task_execname(tsk) + return "" +} + + // Return the thread id of the given task function task_tid:long (task:long) { |