diff options
author | Namhyung Kim <namhyung.kim@lge.com> | 2012-12-10 03:29:54 -0500 |
---|---|---|
committer | Arnaldo Carvalho de Melo <acme@redhat.com> | 2013-01-24 14:40:05 -0500 |
commit | 9afcf930b1fa1158b0878afeba3eff299300dc65 (patch) | |
tree | f3006330f854fd8379fdb08f3abfb028fad5b983 | |
parent | 203e04c16330c880538588e932743f404ee4fd66 (diff) |
perf hists: Exchange order of comparing items when collapsing hists
When comparing entries for collapsing put the given entry first, and
then the iterated entry. This is not the case of hist_entry__cmp() when
called if given sort keys don't require collapsing. So change the order
for the sake of consistency. It will be required for matching and/or
linking multiple hist entries.
Signed-off-by: Namhyung Kim <namhyung@kernel.org>
Acked-by: Jiri Olsa <jolsa@redhat.com>
Cc: Ingo Molnar <mingo@kernel.org>
Cc: Jiri Olsa <jolsa@redhat.com>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Stephane Eranian <eranian@google.com>
Link: http://lkml.kernel.org/r/1355128197-18193-2-git-send-email-namhyung@kernel.org
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
-rw-r--r-- | tools/perf/builtin-diff.c | 2 | ||||
-rw-r--r-- | tools/perf/util/hist.c | 12 |
2 files changed, 10 insertions, 4 deletions
diff --git a/tools/perf/builtin-diff.c b/tools/perf/builtin-diff.c index b2e7d39f099b..4dda6f4dc618 100644 --- a/tools/perf/builtin-diff.c +++ b/tools/perf/builtin-diff.c | |||
@@ -285,7 +285,7 @@ static void insert_hist_entry_by_name(struct rb_root *root, | |||
285 | while (*p != NULL) { | 285 | while (*p != NULL) { |
286 | parent = *p; | 286 | parent = *p; |
287 | iter = rb_entry(parent, struct hist_entry, rb_node); | 287 | iter = rb_entry(parent, struct hist_entry, rb_node); |
288 | if (hist_entry__cmp(he, iter) < 0) | 288 | if (hist_entry__cmp(iter, he) < 0) |
289 | p = &(*p)->rb_left; | 289 | p = &(*p)->rb_left; |
290 | else | 290 | else |
291 | p = &(*p)->rb_right; | 291 | p = &(*p)->rb_right; |
diff --git a/tools/perf/util/hist.c b/tools/perf/util/hist.c index 82df1b26f0d4..3a9ccd09835d 100644 --- a/tools/perf/util/hist.c +++ b/tools/perf/util/hist.c | |||
@@ -285,7 +285,13 @@ static struct hist_entry *add_hist_entry(struct hists *hists, | |||
285 | parent = *p; | 285 | parent = *p; |
286 | he = rb_entry(parent, struct hist_entry, rb_node_in); | 286 | he = rb_entry(parent, struct hist_entry, rb_node_in); |
287 | 287 | ||
288 | cmp = hist_entry__cmp(entry, he); | 288 | /* |
289 | * Make sure that it receives arguments in a same order as | ||
290 | * hist_entry__collapse() so that we can use an appropriate | ||
291 | * function when searching an entry regardless which sort | ||
292 | * keys were used. | ||
293 | */ | ||
294 | cmp = hist_entry__cmp(he, entry); | ||
289 | 295 | ||
290 | if (!cmp) { | 296 | if (!cmp) { |
291 | he_stat__add_period(&he->stat, period); | 297 | he_stat__add_period(&he->stat, period); |
@@ -729,7 +735,7 @@ static struct hist_entry *hists__add_dummy_entry(struct hists *hists, | |||
729 | parent = *p; | 735 | parent = *p; |
730 | he = rb_entry(parent, struct hist_entry, rb_node); | 736 | he = rb_entry(parent, struct hist_entry, rb_node); |
731 | 737 | ||
732 | cmp = hist_entry__cmp(pair, he); | 738 | cmp = hist_entry__cmp(he, pair); |
733 | 739 | ||
734 | if (!cmp) | 740 | if (!cmp) |
735 | goto out; | 741 | goto out; |
@@ -759,7 +765,7 @@ static struct hist_entry *hists__find_entry(struct hists *hists, | |||
759 | 765 | ||
760 | while (n) { | 766 | while (n) { |
761 | struct hist_entry *iter = rb_entry(n, struct hist_entry, rb_node); | 767 | struct hist_entry *iter = rb_entry(n, struct hist_entry, rb_node); |
762 | int64_t cmp = hist_entry__cmp(he, iter); | 768 | int64_t cmp = hist_entry__cmp(iter, he); |
763 | 769 | ||
764 | if (cmp < 0) | 770 | if (cmp < 0) |
765 | n = n->rb_left; | 771 | n = n->rb_left; |