mirror of
				https://github.com/torvalds/linux.git
				synced 2025-11-04 02:30:34 +02:00 
			
		
		
		
	perf tools: Add thread_map__(alloc|realloc) helpers
In order to have 'struct thread_map' allocation on single place and can change it easily in following patch. Using alloc|realloc for static helpers, because thread_map__new is already used in public interface. Signed-off-by: Jiri Olsa <jolsa@kernel.org> Cc: Adrian Hunter <adrian.hunter@intel.com> Cc: Andi Kleen <ak@linux.intel.com> Cc: David Ahern <dsahern@gmail.com> Cc: Namhyung Kim <namhyung@kernel.org> Cc: Peter Zijlstra <a.p.zijlstra@chello.nl> Cc: Stephane Eranian <eranian@google.com> Link: http://lkml.kernel.org/r/1434269985-521-3-git-send-email-jolsa@kernel.org Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
This commit is contained in:
		
							parent
							
								
									b45f65e8fd
								
							
						
					
					
						commit
						9d7e8c3a96
					
				
					 1 changed files with 16 additions and 8 deletions
				
			
		| 
						 | 
				
			
			@ -20,6 +20,15 @@ static int filter(const struct dirent *dir)
 | 
			
		|||
		return 1;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
static struct thread_map *thread_map__realloc(struct thread_map *map, int nr)
 | 
			
		||||
{
 | 
			
		||||
	size_t size = sizeof(*map) + sizeof(pid_t) * nr;
 | 
			
		||||
 | 
			
		||||
	return realloc(map, size);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#define thread_map__alloc(__nr) thread_map__realloc(NULL, __nr)
 | 
			
		||||
 | 
			
		||||
struct thread_map *thread_map__new_by_pid(pid_t pid)
 | 
			
		||||
{
 | 
			
		||||
	struct thread_map *threads;
 | 
			
		||||
| 
						 | 
				
			
			@ -33,7 +42,7 @@ struct thread_map *thread_map__new_by_pid(pid_t pid)
 | 
			
		|||
	if (items <= 0)
 | 
			
		||||
		return NULL;
 | 
			
		||||
 | 
			
		||||
	threads = malloc(sizeof(*threads) + sizeof(pid_t) * items);
 | 
			
		||||
	threads = thread_map__alloc(items);
 | 
			
		||||
	if (threads != NULL) {
 | 
			
		||||
		for (i = 0; i < items; i++)
 | 
			
		||||
			threads->map[i] = atoi(namelist[i]->d_name);
 | 
			
		||||
| 
						 | 
				
			
			@ -49,7 +58,7 @@ struct thread_map *thread_map__new_by_pid(pid_t pid)
 | 
			
		|||
 | 
			
		||||
struct thread_map *thread_map__new_by_tid(pid_t tid)
 | 
			
		||||
{
 | 
			
		||||
	struct thread_map *threads = malloc(sizeof(*threads) + sizeof(pid_t));
 | 
			
		||||
	struct thread_map *threads = thread_map__alloc(1);
 | 
			
		||||
 | 
			
		||||
	if (threads != NULL) {
 | 
			
		||||
		threads->map[0] = tid;
 | 
			
		||||
| 
						 | 
				
			
			@ -65,8 +74,8 @@ struct thread_map *thread_map__new_by_uid(uid_t uid)
 | 
			
		|||
	int max_threads = 32, items, i;
 | 
			
		||||
	char path[256];
 | 
			
		||||
	struct dirent dirent, *next, **namelist = NULL;
 | 
			
		||||
	struct thread_map *threads = malloc(sizeof(*threads) +
 | 
			
		||||
					    max_threads * sizeof(pid_t));
 | 
			
		||||
	struct thread_map *threads = thread_map__alloc(max_threads);
 | 
			
		||||
 | 
			
		||||
	if (threads == NULL)
 | 
			
		||||
		goto out;
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -185,8 +194,7 @@ static struct thread_map *thread_map__new_by_pid_str(const char *pid_str)
 | 
			
		|||
			goto out_free_threads;
 | 
			
		||||
 | 
			
		||||
		total_tasks += items;
 | 
			
		||||
		nt = realloc(threads, (sizeof(*threads) +
 | 
			
		||||
				       sizeof(pid_t) * total_tasks));
 | 
			
		||||
		nt = thread_map__realloc(threads, total_tasks);
 | 
			
		||||
		if (nt == NULL)
 | 
			
		||||
			goto out_free_namelist;
 | 
			
		||||
 | 
			
		||||
| 
						 | 
				
			
			@ -216,7 +224,7 @@ static struct thread_map *thread_map__new_by_pid_str(const char *pid_str)
 | 
			
		|||
 | 
			
		||||
struct thread_map *thread_map__new_dummy(void)
 | 
			
		||||
{
 | 
			
		||||
	struct thread_map *threads = malloc(sizeof(*threads) + sizeof(pid_t));
 | 
			
		||||
	struct thread_map *threads = thread_map__alloc(1);
 | 
			
		||||
 | 
			
		||||
	if (threads != NULL) {
 | 
			
		||||
		threads->map[0]	= -1;
 | 
			
		||||
| 
						 | 
				
			
			@ -253,7 +261,7 @@ static struct thread_map *thread_map__new_by_tid_str(const char *tid_str)
 | 
			
		|||
			continue;
 | 
			
		||||
 | 
			
		||||
		ntasks++;
 | 
			
		||||
		nt = realloc(threads, sizeof(*threads) + sizeof(pid_t) * ntasks);
 | 
			
		||||
		nt = thread_map__realloc(threads, ntasks);
 | 
			
		||||
 | 
			
		||||
		if (nt == NULL)
 | 
			
		||||
			goto out_free_threads;
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
		Reference in a new issue