xref: /openbmc/linux/tools/perf/util/thread.c (revision 3f067dcab711c2df7eefcfc5b3aa9a0e2b5f7d42)
16baa0a5aSFrederic Weisbecker #include "../perf.h"
26baa0a5aSFrederic Weisbecker #include <stdlib.h>
36baa0a5aSFrederic Weisbecker #include <stdio.h>
46baa0a5aSFrederic Weisbecker #include <string.h>
5b3165f41SArnaldo Carvalho de Melo #include "session.h"
66baa0a5aSFrederic Weisbecker #include "thread.h"
76baa0a5aSFrederic Weisbecker #include "util.h"
86e086437SFrederic Weisbecker #include "debug.h"
96baa0a5aSFrederic Weisbecker 
109d2f8e22SArnaldo Carvalho de Melo struct thread *thread__new(pid_t pid)
116baa0a5aSFrederic Weisbecker {
1236479484SArnaldo Carvalho de Melo 	struct thread *self = zalloc(sizeof(*self));
136baa0a5aSFrederic Weisbecker 
146baa0a5aSFrederic Weisbecker 	if (self != NULL) {
159958e1f0SArnaldo Carvalho de Melo 		map_groups__init(&self->mg);
169958e1f0SArnaldo Carvalho de Melo 		self->pid = pid;
176baa0a5aSFrederic Weisbecker 		self->comm = malloc(32);
186baa0a5aSFrederic Weisbecker 		if (self->comm)
196baa0a5aSFrederic Weisbecker 			snprintf(self->comm, 32, ":%d", self->pid);
206baa0a5aSFrederic Weisbecker 	}
216baa0a5aSFrederic Weisbecker 
226baa0a5aSFrederic Weisbecker 	return self;
236baa0a5aSFrederic Weisbecker }
246baa0a5aSFrederic Weisbecker 
25591765fdSArnaldo Carvalho de Melo void thread__delete(struct thread *self)
26591765fdSArnaldo Carvalho de Melo {
27591765fdSArnaldo Carvalho de Melo 	map_groups__exit(&self->mg);
28591765fdSArnaldo Carvalho de Melo 	free(self->comm);
29591765fdSArnaldo Carvalho de Melo 	free(self);
30591765fdSArnaldo Carvalho de Melo }
31591765fdSArnaldo Carvalho de Melo 
326baa0a5aSFrederic Weisbecker int thread__set_comm(struct thread *self, const char *comm)
336baa0a5aSFrederic Weisbecker {
344385d580SDavid S. Miller 	int err;
354385d580SDavid S. Miller 
366baa0a5aSFrederic Weisbecker 	if (self->comm)
376baa0a5aSFrederic Weisbecker 		free(self->comm);
386baa0a5aSFrederic Weisbecker 	self->comm = strdup(comm);
394385d580SDavid S. Miller 	err = self->comm == NULL ? -ENOMEM : 0;
404385d580SDavid S. Miller 	if (!err) {
41faa5c5c3SArnaldo Carvalho de Melo 		self->comm_set = true;
424385d580SDavid S. Miller 	}
434385d580SDavid S. Miller 	return err;
446baa0a5aSFrederic Weisbecker }
456baa0a5aSFrederic Weisbecker 
46a4fb581bSFrederic Weisbecker int thread__comm_len(struct thread *self)
47a4fb581bSFrederic Weisbecker {
48a4fb581bSFrederic Weisbecker 	if (!self->comm_len) {
49a4fb581bSFrederic Weisbecker 		if (!self->comm)
50a4fb581bSFrederic Weisbecker 			return 0;
51a4fb581bSFrederic Weisbecker 		self->comm_len = strlen(self->comm);
52a4fb581bSFrederic Weisbecker 	}
53a4fb581bSFrederic Weisbecker 
54a4fb581bSFrederic Weisbecker 	return self->comm_len;
55a4fb581bSFrederic Weisbecker }
56a4fb581bSFrederic Weisbecker 
57*3f067dcaSArnaldo Carvalho de Melo size_t thread__fprintf(struct thread *thread, FILE *fp)
5895011c60SArnaldo Carvalho de Melo {
59*3f067dcaSArnaldo Carvalho de Melo 	return fprintf(fp, "Thread %d %s\n", thread->pid, thread->comm) +
60*3f067dcaSArnaldo Carvalho de Melo 	       map_groups__fprintf(&thread->mg, verbose, fp);
616baa0a5aSFrederic Weisbecker }
626baa0a5aSFrederic Weisbecker 
631b46cddfSArnaldo Carvalho de Melo void thread__insert_map(struct thread *self, struct map *map)
641b46cddfSArnaldo Carvalho de Melo {
65c6e718ffSArnaldo Carvalho de Melo 	map_groups__fixup_overlappings(&self->mg, map, verbose, stderr);
669958e1f0SArnaldo Carvalho de Melo 	map_groups__insert(&self->mg, map);
6795011c60SArnaldo Carvalho de Melo }
6895011c60SArnaldo Carvalho de Melo 
696baa0a5aSFrederic Weisbecker int thread__fork(struct thread *self, struct thread *parent)
706baa0a5aSFrederic Weisbecker {
7195011c60SArnaldo Carvalho de Melo 	int i;
726baa0a5aSFrederic Weisbecker 
73faa5c5c3SArnaldo Carvalho de Melo 	if (parent->comm_set) {
746baa0a5aSFrederic Weisbecker 		if (self->comm)
756baa0a5aSFrederic Weisbecker 			free(self->comm);
766baa0a5aSFrederic Weisbecker 		self->comm = strdup(parent->comm);
776baa0a5aSFrederic Weisbecker 		if (!self->comm)
786baa0a5aSFrederic Weisbecker 			return -ENOMEM;
79faa5c5c3SArnaldo Carvalho de Melo 		self->comm_set = true;
80faa5c5c3SArnaldo Carvalho de Melo 	}
816baa0a5aSFrederic Weisbecker 
8295011c60SArnaldo Carvalho de Melo 	for (i = 0; i < MAP__NR_TYPES; ++i)
839958e1f0SArnaldo Carvalho de Melo 		if (map_groups__clone(&self->mg, &parent->mg, i) < 0)
846baa0a5aSFrederic Weisbecker 			return -ENOMEM;
856baa0a5aSFrederic Weisbecker 	return 0;
866baa0a5aSFrederic Weisbecker }
87