diff options
Diffstat (limited to 'tools/perf/util/thread.c')
| -rw-r--r-- | tools/perf/util/thread.c | 32 |
1 files changed, 25 insertions, 7 deletions
diff --git a/tools/perf/util/thread.c b/tools/perf/util/thread.c index 3b56aebb1f4..8bd5ca2d2f2 100644 --- a/tools/perf/util/thread.c +++ b/tools/perf/util/thread.c | |||
| @@ -6,15 +6,17 @@ | |||
| 6 | #include "util.h" | 6 | #include "util.h" |
| 7 | #include "debug.h" | 7 | #include "debug.h" |
| 8 | 8 | ||
| 9 | static struct thread *thread__new(pid_t pid) | 9 | static struct thread *thread__new(pid_t pid, int set_comm) |
| 10 | { | 10 | { |
| 11 | struct thread *self = calloc(1, sizeof(*self)); | 11 | struct thread *self = calloc(1, sizeof(*self)); |
| 12 | 12 | ||
| 13 | if (self != NULL) { | 13 | if (self != NULL) { |
| 14 | self->pid = pid; | 14 | self->pid = pid; |
| 15 | self->comm = malloc(32); | 15 | if (set_comm) { |
| 16 | if (self->comm) | 16 | self->comm = malloc(32); |
| 17 | snprintf(self->comm, 32, ":%d", self->pid); | 17 | if (self->comm) |
| 18 | snprintf(self->comm, 32, ":%d", self->pid); | ||
| 19 | } | ||
| 18 | self->maps = RB_ROOT; | 20 | self->maps = RB_ROOT; |
| 19 | INIT_LIST_HEAD(&self->removed_maps); | 21 | INIT_LIST_HEAD(&self->removed_maps); |
| 20 | } | 22 | } |
| @@ -50,8 +52,10 @@ static size_t thread__fprintf(struct thread *self, FILE *fp) | |||
| 50 | return ret; | 52 | return ret; |
| 51 | } | 53 | } |
| 52 | 54 | ||
| 53 | struct thread * | 55 | static struct thread * |
| 54 | threads__findnew(pid_t pid, struct rb_root *threads, struct thread **last_match) | 56 | __threads__findnew(pid_t pid, struct rb_root *threads, |
| 57 | struct thread **last_match, | ||
| 58 | int set_comm) | ||
| 55 | { | 59 | { |
| 56 | struct rb_node **p = &threads->rb_node; | 60 | struct rb_node **p = &threads->rb_node; |
| 57 | struct rb_node *parent = NULL; | 61 | struct rb_node *parent = NULL; |
| @@ -80,7 +84,8 @@ threads__findnew(pid_t pid, struct rb_root *threads, struct thread **last_match) | |||
| 80 | p = &(*p)->rb_right; | 84 | p = &(*p)->rb_right; |
| 81 | } | 85 | } |
| 82 | 86 | ||
| 83 | th = thread__new(pid); | 87 | th = thread__new(pid, set_comm); |
| 88 | |||
| 84 | if (th != NULL) { | 89 | if (th != NULL) { |
| 85 | rb_link_node(&th->rb_node, parent, p); | 90 | rb_link_node(&th->rb_node, parent, p); |
| 86 | rb_insert_color(&th->rb_node, threads); | 91 | rb_insert_color(&th->rb_node, threads); |
| @@ -91,6 +96,19 @@ threads__findnew(pid_t pid, struct rb_root *threads, struct thread **last_match) | |||
| 91 | } | 96 | } |
| 92 | 97 | ||
| 93 | struct thread * | 98 | struct thread * |
| 99 | threads__findnew(pid_t pid, struct rb_root *threads, struct thread **last_match) | ||
| 100 | { | ||
| 101 | return __threads__findnew(pid, threads, last_match, 1); | ||
| 102 | } | ||
| 103 | |||
| 104 | struct thread * | ||
| 105 | threads__findnew_nocomm(pid_t pid, struct rb_root *threads, | ||
| 106 | struct thread **last_match) | ||
| 107 | { | ||
| 108 | return __threads__findnew(pid, threads, last_match, 0); | ||
| 109 | } | ||
| 110 | |||
| 111 | struct thread * | ||
| 94 | register_idle_thread(struct rb_root *threads, struct thread **last_match) | 112 | register_idle_thread(struct rb_root *threads, struct thread **last_match) |
| 95 | { | 113 | { |
| 96 | struct thread *thread = threads__findnew(0, threads, last_match); | 114 | struct thread *thread = threads__findnew(0, threads, last_match); |
