Commit c0020efa authored by Jiri Olsa's avatar Jiri Olsa Committed by Arnaldo Carvalho de Melo

perf hists: Add 'hpp__equal' callback function

Adding 'hpp__equal' callback function to compare hpp output format
entries.
Signed-off-by: default avatarJiri Olsa <jolsa@kernel.org>
Cc: David Ahern <dsahern@gmail.com>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Link: http://lkml.kernel.org/r/1453109064-1026-7-git-send-email-jolsa@kernel.orgSigned-off-by: default avatarArnaldo Carvalho de Melo <acme@redhat.com>
parent 97358084
...@@ -371,6 +371,19 @@ static int64_t hpp__nop_cmp(struct perf_hpp_fmt *fmt __maybe_unused, ...@@ -371,6 +371,19 @@ static int64_t hpp__nop_cmp(struct perf_hpp_fmt *fmt __maybe_unused,
return 0; return 0;
} }
static bool perf_hpp__is_hpp_entry(struct perf_hpp_fmt *a)
{
return a->header == hpp__header_fn;
}
static bool hpp__equal(struct perf_hpp_fmt *a, struct perf_hpp_fmt *b)
{
if (!perf_hpp__is_hpp_entry(a) || !perf_hpp__is_hpp_entry(b))
return false;
return a->idx == b->idx;
}
#define HPP__COLOR_PRINT_FNS(_name, _fn, _idx) \ #define HPP__COLOR_PRINT_FNS(_name, _fn, _idx) \
{ \ { \
.name = _name, \ .name = _name, \
...@@ -382,6 +395,7 @@ static int64_t hpp__nop_cmp(struct perf_hpp_fmt *fmt __maybe_unused, ...@@ -382,6 +395,7 @@ static int64_t hpp__nop_cmp(struct perf_hpp_fmt *fmt __maybe_unused,
.collapse = hpp__nop_cmp, \ .collapse = hpp__nop_cmp, \
.sort = hpp__sort_ ## _fn, \ .sort = hpp__sort_ ## _fn, \
.idx = PERF_HPP__ ## _idx, \ .idx = PERF_HPP__ ## _idx, \
.equal = hpp__equal, \
} }
#define HPP__COLOR_ACC_PRINT_FNS(_name, _fn, _idx) \ #define HPP__COLOR_ACC_PRINT_FNS(_name, _fn, _idx) \
...@@ -395,6 +409,7 @@ static int64_t hpp__nop_cmp(struct perf_hpp_fmt *fmt __maybe_unused, ...@@ -395,6 +409,7 @@ static int64_t hpp__nop_cmp(struct perf_hpp_fmt *fmt __maybe_unused,
.collapse = hpp__nop_cmp, \ .collapse = hpp__nop_cmp, \
.sort = hpp__sort_ ## _fn, \ .sort = hpp__sort_ ## _fn, \
.idx = PERF_HPP__ ## _idx, \ .idx = PERF_HPP__ ## _idx, \
.equal = hpp__equal, \
} }
#define HPP__PRINT_FNS(_name, _fn, _idx) \ #define HPP__PRINT_FNS(_name, _fn, _idx) \
...@@ -407,6 +422,7 @@ static int64_t hpp__nop_cmp(struct perf_hpp_fmt *fmt __maybe_unused, ...@@ -407,6 +422,7 @@ static int64_t hpp__nop_cmp(struct perf_hpp_fmt *fmt __maybe_unused,
.collapse = hpp__nop_cmp, \ .collapse = hpp__nop_cmp, \
.sort = hpp__sort_ ## _fn, \ .sort = hpp__sort_ ## _fn, \
.idx = PERF_HPP__ ## _idx, \ .idx = PERF_HPP__ ## _idx, \
.equal = hpp__equal, \
} }
struct perf_hpp_fmt perf_hpp__format[] = { struct perf_hpp_fmt perf_hpp__format[] = {
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment