]> git.karo-electronics.de Git - karo-tx-linux.git/blobdiff - kernel/trace/trace_workqueue.c
Merge branch 'topic/hda' into for-linus
[karo-tx-linux.git] / kernel / trace / trace_workqueue.c
index fb5ccac8bbc0e9af264c53d06e173ff1f7fd2b32..797201e4a1376af5987bbce519398b14de3aeada 100644 (file)
@@ -193,25 +193,33 @@ static int workqueue_stat_show(struct seq_file *s, void *p)
        struct cpu_workqueue_stats *cws = p;
        unsigned long flags;
        int cpu = cws->cpu;
-       struct task_struct *tsk = find_task_by_vpid(cws->pid);
-
-       seq_printf(s, "%3d %6d     %6u       %s\n", cws->cpu,
-                  atomic_read(&cws->inserted),
-                  cws->executed,
-                  tsk ? tsk->comm : "<...>");
+       struct pid *pid;
+       struct task_struct *tsk;
 
        spin_lock_irqsave(&workqueue_cpu_stat(cpu)->lock, flags);
        if (&cws->list == workqueue_cpu_stat(cpu)->list.next)
                seq_printf(s, "\n");
        spin_unlock_irqrestore(&workqueue_cpu_stat(cpu)->lock, flags);
 
+       pid = find_get_pid(cws->pid);
+       if (pid) {
+               tsk = get_pid_task(pid, PIDTYPE_PID);
+               if (tsk) {
+                       seq_printf(s, "%3d %6d     %6u       %s\n", cws->cpu,
+                                  atomic_read(&cws->inserted), cws->executed,
+                                  tsk->comm);
+                       put_task_struct(tsk);
+               }
+               put_pid(pid);
+       }
+
        return 0;
 }
 
 static int workqueue_stat_headers(struct seq_file *s)
 {
        seq_printf(s, "# CPU  INSERTED  EXECUTED   NAME\n");
-       seq_printf(s, "# |      |         |          |\n\n");
+       seq_printf(s, "# |      |         |          |\n");
        return 0;
 }