mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/stable/linux.git
synced 2025-01-01 10:45:49 +00:00
perf c2c: Refactor display filter
When sorting on the respective metrics (lcl_hitm, rmt_hitm, tot_hitm), the FILTER_HITM macro is used to filter out the cache line entries if its overhead is less than 1%. This patch introduces a static function filter_display() to replace that macro and refines its parameters with a more flexible way, rather than passing field name, it changes to pass the cache line's statistic and sum value. Signed-off-by: Leo Yan <leo.yan@linaro.org> Acked-by: Namhyung Kim <namhyung@kernel.org> Acked-by: Jiri Olsa <jolsa@redhat.com> Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com> Cc: Arnaldo Carvalho de Melo <acme@kernel.org> Cc: David Ahern <dsahern@gmail.com> Cc: Don Zickus <dzickus@redhat.com> Cc: Ingo Molnar <mingo@redhat.com> Cc: Joe Mario <jmario@redhat.com> Cc: Joe Perches <joe@perches.com> Cc: Mark Rutland <mark.rutland@arm.com> Cc: Peter Zijlstra <peterz@infradead.org> Link: https://lore.kernel.org/r/20210114154646.209024-4-leo.yan@linaro.org Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
This commit is contained in:
parent
2290e1d619
commit
69a95bfdf9
@ -1851,40 +1851,40 @@ static int c2c_hists__reinit(struct c2c_hists *c2c_hists,
|
||||
|
||||
#define DISPLAY_LINE_LIMIT 0.001
|
||||
|
||||
static u8 filter_display(u32 val, u32 sum)
|
||||
{
|
||||
if (sum == 0 || ((double)val / sum) < DISPLAY_LINE_LIMIT)
|
||||
return HIST_FILTER__C2C;
|
||||
|
||||
return 0;
|
||||
}
|
||||
|
||||
static bool he__display(struct hist_entry *he, struct c2c_stats *stats)
|
||||
{
|
||||
struct c2c_hist_entry *c2c_he;
|
||||
double ld_dist;
|
||||
|
||||
if (c2c.show_all)
|
||||
return true;
|
||||
|
||||
c2c_he = container_of(he, struct c2c_hist_entry, he);
|
||||
|
||||
#define FILTER_HITM(__h) \
|
||||
if (stats->__h) { \
|
||||
ld_dist = ((double)c2c_he->stats.__h / stats->__h); \
|
||||
if (ld_dist < DISPLAY_LINE_LIMIT) \
|
||||
he->filtered = HIST_FILTER__C2C; \
|
||||
} else { \
|
||||
he->filtered = HIST_FILTER__C2C; \
|
||||
}
|
||||
|
||||
switch (c2c.display) {
|
||||
case DISPLAY_LCL:
|
||||
FILTER_HITM(lcl_hitm);
|
||||
he->filtered = filter_display(c2c_he->stats.lcl_hitm,
|
||||
stats->lcl_hitm);
|
||||
break;
|
||||
case DISPLAY_RMT:
|
||||
FILTER_HITM(rmt_hitm);
|
||||
he->filtered = filter_display(c2c_he->stats.rmt_hitm,
|
||||
stats->rmt_hitm);
|
||||
break;
|
||||
case DISPLAY_TOT:
|
||||
FILTER_HITM(tot_hitm);
|
||||
he->filtered = filter_display(c2c_he->stats.tot_hitm,
|
||||
stats->tot_hitm);
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
|
||||
#undef FILTER_HITM
|
||||
|
||||
return he->filtered == 0;
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user