Re: [PATCH 1/4] perf hists: Add hists__filter_by_symbol
From: Arnaldo Carvalho de Melo
Date: Thu Mar 15 2012 - 13:35:05 EST
Em Tue, Mar 13, 2012 at 03:14:51PM +0900, Namhyung Kim escreveu:
> This function will be used for simple (sub-)string matching
> filter based on user input.
Can you check if these apply as well? I fear they wont.
- Arnaldo
> Signed-off-by: Namhyung Kim <namhyung.kim@xxxxxxx>
> ---
> tools/perf/util/hist.c | 35 +++++++++++++++++++++++++++++++++++
> tools/perf/util/hist.h | 2 ++
> 2 files changed, 37 insertions(+), 0 deletions(-)
>
> diff --git a/tools/perf/util/hist.c b/tools/perf/util/hist.c
> index 6f505d1abac7..021b49c498d5 100644
> --- a/tools/perf/util/hist.c
> +++ b/tools/perf/util/hist.c
> @@ -10,11 +10,14 @@ static bool hists__filter_entry_by_dso(struct hists *hists,
> struct hist_entry *he);
> static bool hists__filter_entry_by_thread(struct hists *hists,
> struct hist_entry *he);
> +static bool hists__filter_entry_by_symbol(struct hists *hists,
> + struct hist_entry *he);
>
> enum hist_filter {
> HIST_FILTER__DSO,
> HIST_FILTER__THREAD,
> HIST_FILTER__PARENT,
> + HIST_FILTER__SYMBOL,
> };
>
> struct callchain_param callchain_param = {
> @@ -352,6 +355,7 @@ static void hists__apply_filters(struct hists *hists, struct hist_entry *he)
> {
> hists__filter_entry_by_dso(hists, he);
> hists__filter_entry_by_thread(hists, he);
> + hists__filter_entry_by_symbol(hists, he);
> }
>
> static void __hists__collapse_resort(struct hists *hists, bool threaded)
> @@ -1179,6 +1183,37 @@ void hists__filter_by_thread(struct hists *hists)
> }
> }
>
> +static bool hists__filter_entry_by_symbol(struct hists *hists,
> + struct hist_entry *he)
> +{
> + if (hists->symbol_filter_str != NULL &&
> + (!he->ms.sym || strstr(he->ms.sym->name,
> + hists->symbol_filter_str) == NULL)) {
> + he->filtered |= (1 << HIST_FILTER__SYMBOL);
> + return true;
> + }
> +
> + return false;
> +}
> +
> +void hists__filter_by_symbol(struct hists *hists)
> +{
> + struct rb_node *nd;
> +
> + hists->nr_entries = hists->stats.total_period = 0;
> + hists->stats.nr_events[PERF_RECORD_SAMPLE] = 0;
> + hists__reset_col_len(hists);
> +
> + for (nd = rb_first(&hists->entries); nd; nd = rb_next(nd)) {
> + struct hist_entry *h = rb_entry(nd, struct hist_entry, rb_node);
> +
> + if (hists__filter_entry_by_symbol(hists, h))
> + continue;
> +
> + hists__remove_entry_filter(hists, h, HIST_FILTER__SYMBOL);
> + }
> +}
> +
> int hist_entry__inc_addr_samples(struct hist_entry *he, int evidx, u64 ip)
> {
> return symbol__inc_addr_samples(he->ms.sym, he->ms.map, evidx, ip);
> diff --git a/tools/perf/util/hist.h b/tools/perf/util/hist.h
> index 48e5acd1e862..020d3477cabc 100644
> --- a/tools/perf/util/hist.h
> +++ b/tools/perf/util/hist.h
> @@ -57,6 +57,7 @@ struct hists {
> const struct thread *thread_filter;
> const struct dso *dso_filter;
> const char *uid_filter_str;
> + const char *symbol_filter_str;
> pthread_mutex_t lock;
> struct events_stats stats;
> u64 event_stream;
> @@ -96,6 +97,7 @@ int hist_entry__annotate(struct hist_entry *self, size_t privsize);
>
> void hists__filter_by_dso(struct hists *hists);
> void hists__filter_by_thread(struct hists *hists);
> +void hists__filter_by_symbol(struct hists *hists);
>
> u16 hists__col_len(struct hists *self, enum hist_column col);
> void hists__set_col_len(struct hists *self, enum hist_column col, u16 len);
> --
> 1.7.9
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/