aboutsummaryrefslogtreecommitdiffstats
path: root/tools/perf
diff options
context:
space:
mode:
authorJiri Olsa <jolsa@kernel.org>2014-05-07 12:30:45 -0400
committerJiri Olsa <jolsa@kernel.org>2014-06-12 10:53:19 -0400
commitca40e2af1f75eddf7eb2b93fde6391ea185d8fc8 (patch)
tree07bf57da6d70240a489d96fdfdce12b44d1c5db1 /tools/perf
parent0c4e774fad0202b91dea8d99c04e9bdf2c2c6647 (diff)
perf tools: Separate dso data related variables
Add separated structure/namespace for data related variables. We are going to add mode of them, so this way they will be clearly separated. Acked-by: Namhyung Kim <namhyung@kernel.org> Cc: Arnaldo Carvalho de Melo <acme@kernel.org> Cc: Corey Ashford <cjashfor@linux.vnet.ibm.com> Cc: David Ahern <dsahern@gmail.com> Cc: Frederic Weisbecker <fweisbec@gmail.com> Cc: Ingo Molnar <mingo@kernel.org> Cc: Jean Pihet <jean.pihet@linaro.org> Cc: Namhyung Kim <namhyung@kernel.org> Cc: Paul Mackerras <paulus@samba.org> Cc: Peter Zijlstra <a.p.zijlstra@chello.nl> Link: http://lkml.kernel.org/r/1401892622-30848-3-git-send-email-jolsa@kernel.org Signed-off-by: Jiri Olsa <jolsa@kernel.org>
Diffstat (limited to 'tools/perf')
-rw-r--r--tools/perf/util/dso.c8
-rw-r--r--tools/perf/util/dso.h7
2 files changed, 10 insertions, 5 deletions
diff --git a/tools/perf/util/dso.c b/tools/perf/util/dso.c
index 64453d63b971..1c3cdaf228c1 100644
--- a/tools/perf/util/dso.c
+++ b/tools/perf/util/dso.c
@@ -292,7 +292,7 @@ dso_cache__read(struct dso *dso, struct machine *machine,
292 292
293 cache->offset = cache_offset; 293 cache->offset = cache_offset;
294 cache->size = ret; 294 cache->size = ret;
295 dso_cache__insert(&dso->cache, cache); 295 dso_cache__insert(&dso->data.cache, cache);
296 296
297 ret = dso_cache__memcpy(cache, offset, data, size); 297 ret = dso_cache__memcpy(cache, offset, data, size);
298 298
@@ -310,7 +310,7 @@ static ssize_t dso_cache_read(struct dso *dso, struct machine *machine,
310{ 310{
311 struct dso_cache *cache; 311 struct dso_cache *cache;
312 312
313 cache = dso_cache__find(&dso->cache, offset); 313 cache = dso_cache__find(&dso->data.cache, offset);
314 if (cache) 314 if (cache)
315 return dso_cache__memcpy(cache, offset, data, size); 315 return dso_cache__memcpy(cache, offset, data, size);
316 else 316 else
@@ -473,7 +473,7 @@ struct dso *dso__new(const char *name)
473 dso__set_short_name(dso, dso->name, false); 473 dso__set_short_name(dso, dso->name, false);
474 for (i = 0; i < MAP__NR_TYPES; ++i) 474 for (i = 0; i < MAP__NR_TYPES; ++i)
475 dso->symbols[i] = dso->symbol_names[i] = RB_ROOT; 475 dso->symbols[i] = dso->symbol_names[i] = RB_ROOT;
476 dso->cache = RB_ROOT; 476 dso->data.cache = RB_ROOT;
477 dso->symtab_type = DSO_BINARY_TYPE__NOT_FOUND; 477 dso->symtab_type = DSO_BINARY_TYPE__NOT_FOUND;
478 dso->binary_type = DSO_BINARY_TYPE__NOT_FOUND; 478 dso->binary_type = DSO_BINARY_TYPE__NOT_FOUND;
479 dso->loaded = 0; 479 dso->loaded = 0;
@@ -506,7 +506,7 @@ void dso__delete(struct dso *dso)
506 dso->long_name_allocated = false; 506 dso->long_name_allocated = false;
507 } 507 }
508 508
509 dso_cache__free(&dso->cache); 509 dso_cache__free(&dso->data.cache);
510 dso__free_a2l(dso); 510 dso__free_a2l(dso);
511 zfree(&dso->symsrc_filename); 511 zfree(&dso->symsrc_filename);
512 free(dso); 512 free(dso);
diff --git a/tools/perf/util/dso.h b/tools/perf/util/dso.h
index 38efe95a7fdd..7637fdd680b2 100644
--- a/tools/perf/util/dso.h
+++ b/tools/perf/util/dso.h
@@ -76,7 +76,6 @@ struct dso {
76 struct list_head node; 76 struct list_head node;
77 struct rb_root symbols[MAP__NR_TYPES]; 77 struct rb_root symbols[MAP__NR_TYPES];
78 struct rb_root symbol_names[MAP__NR_TYPES]; 78 struct rb_root symbol_names[MAP__NR_TYPES];
79 struct rb_root cache;
80 void *a2l; 79 void *a2l;
81 char *symsrc_filename; 80 char *symsrc_filename;
82 unsigned int a2l_fails; 81 unsigned int a2l_fails;
@@ -99,6 +98,12 @@ struct dso {
99 const char *long_name; 98 const char *long_name;
100 u16 long_name_len; 99 u16 long_name_len;
101 u16 short_name_len; 100 u16 short_name_len;
101
102 /* dso data file */
103 struct {
104 struct rb_root cache;
105 } data;
106
102 char name[0]; 107 char name[0];
103}; 108};
104 109