All of lore.kernel.org
 help / color / mirror / Atom feed
From: Arnaldo Carvalho de Melo <acme@kernel.org>
To: Masami Hiramatsu <mhiramat@kernel.org>
Cc: linux-kernel@vger.kernel.org, Namhyung Kim <namhyung@kernel.org>,
	Peter Zijlstra <peterz@infradead.org>,
	Ingo Molnar <mingo@redhat.com>,
	Hemant Kumar <hemant@linux.vnet.ibm.com>,
	Ananth N Mavinakayanahalli <ananth@linux.vnet.ibm.com>,
	Brendan Gregg <brendan.d.gregg@gmail.com>
Subject: Re: [PATCH perf/core v13 01/15] perf probe: Use cache entry if possible
Date: Fri, 1 Jul 2016 10:20:24 -0300	[thread overview]
Message-ID: <20160701132024.GK5324@kernel.org> (raw)
In-Reply-To: <146736019226.27797.16366402884098398857.stgit@devbox>

Em Fri, Jul 01, 2016 at 05:03:12PM +0900, Masami Hiramatsu escreveu:
> From: Masami Hiramatsu <masami.hiramatsu.pt@hitachi.com>
> 
> Before analyzing debuginfo, try to find a corresponding entry
> from probe cache always. This does not depend on --cache,
> the --cache enables to store/update cache, but looking up
> the cache is always enabled.
> 
> Signed-off-by: Masami Hiramatsu <masami.hiramatsu.pt@hitachi.com>
> Signed-off-by: Masami Hiramatsu <mhiramat@kernel.org>
> ---
>  Changes in v12:
>   - Rename strlist__for_each to  strlist__for_each_entry.
> 
>  Changes in v6:
>   - Remove fallback lookup routine by using function name
>     as cached event name, because it should be done by following
>     patch which supports %cached-event.

cool, keeping the entries for changes for this specific patch helps in
swapping back into my brain the history of this patch, helping in
re-re-re-re-reviewing 8-)

> ---
>  tools/perf/util/probe-event.c |   65 ++++++++++++++++++++++++++++++++++++++++-
>  tools/perf/util/probe-file.c  |   20 ++++++++++++-
>  tools/perf/util/probe-file.h  |    5 +++
>  3 files changed, 86 insertions(+), 4 deletions(-)
> 
> diff --git a/tools/perf/util/probe-event.c b/tools/perf/util/probe-event.c
> index 55f41d5..47b6b8b 100644
> --- a/tools/perf/util/probe-event.c
> +++ b/tools/perf/util/probe-event.c
> @@ -2474,17 +2474,24 @@ static int probe_trace_event__set_name(struct probe_trace_event *tev,
>  	char buf[64];
>  	int ret;
>  
> +	/* If probe_event or trace_event already have the name, reuse it */
>  	if (pev->event)
>  		event = pev->event;
> -	else
> +	else if (tev->event)
> +		event = tev->event;
> +	else {
> +		/* Or generate new one from probe point */
>  		if (pev->point.function &&
>  			(strncmp(pev->point.function, "0x", 2) != 0) &&
>  			!strisglob(pev->point.function))
>  			event = pev->point.function;
>  		else
>  			event = tev->point.realname;
> +	}
>  	if (pev->group)
>  		group = pev->group;
> +	else if (tev->group)
> +		group = tev->group;
>  	else
>  		group = PERFPROBE_GROUP;
>  
> @@ -2531,7 +2538,7 @@ static int __add_probe_trace_events(struct perf_probe_event *pev,
>  	for (i = 0; i < ntevs; i++) {
>  		tev = &tevs[i];
>  		/* Skip if the symbol is out of .text or blacklisted */
> -		if (!tev->point.symbol)
> +		if (!tev->point.symbol && !pev->uprobes)
>  			continue;
>  
>  		/* Set new name for tev (and update namelist) */
> @@ -2844,6 +2851,55 @@ errout:
>  
>  bool __weak arch__prefers_symtab(void) { return false; }
>  
> +static int find_probe_trace_events_from_cache(struct perf_probe_event *pev,
> +					      struct probe_trace_event **tevs)
> +{
> +	struct probe_cache *cache;
> +	struct probe_cache_entry *entry;
> +	struct probe_trace_event *tev;
> +	struct str_node *node;
> +	int ret, i;
> +
> +	cache = probe_cache__new(pev->target);
> +	if (!cache)
> +		return 0;
> +
> +	entry = probe_cache__find(cache, pev);
> +	if (!entry) {
> +		ret = 0;
> +		goto out;
> +	}
> +
> +	ret = strlist__nr_entries(entry->tevlist);
> +	if (ret > probe_conf.max_probes) {
> +		pr_debug("Too many entries matched in the cache of %s\n",
> +			 pev->target ? : "kernel");
> +		ret = -E2BIG;
> +		goto out;
> +	}
> +
> +	*tevs = zalloc(ret * sizeof(*tev));
> +	if (!*tevs) {
> +		ret = -ENOMEM;
> +		goto out;
> +	}
> +
> +	i = 0;
> +	strlist__for_each_entry(node, entry->tevlist) {
> +		tev = &(*tevs)[i++];
> +		ret = parse_probe_trace_command(node->s, tev);
> +		if (ret < 0)
> +			goto out;
> +		/* Set the uprobes attribute as same as original */
> +		tev->uprobes = pev->uprobes;
> +	}
> +	ret = i;
> +
> +out:
> +	probe_cache__delete(cache);
> +	return ret;
> +}
> +
>  static int convert_to_probe_trace_events(struct perf_probe_event *pev,
>  					 struct probe_trace_event **tevs)
>  {
> @@ -2866,6 +2922,11 @@ static int convert_to_probe_trace_events(struct perf_probe_event *pev,
>  	if (ret > 0)
>  		return ret;
>  
> +	/* At first, we need to lookup cache entry */
> +	ret = find_probe_trace_events_from_cache(pev, tevs);
> +	if (ret > 0)
> +		return ret;	/* Found in probe cache */
> +
>  	if (arch__prefers_symtab() && !perf_probe_event_need_dwarf(pev)) {
>  		ret = find_probe_trace_events_from_map(pev, tevs);
>  		if (ret > 0)
> diff --git a/tools/perf/util/probe-file.c b/tools/perf/util/probe-file.c
> index 1c12c1a..a94ee47 100644
> --- a/tools/perf/util/probe-file.c
> +++ b/tools/perf/util/probe-file.c
> @@ -524,7 +524,7 @@ static bool streql(const char *a, const char *b)
>  	return !strcmp(a, b);
>  }
>  
> -static struct probe_cache_entry *
> +struct probe_cache_entry *
>  probe_cache__find(struct probe_cache *pcache, struct perf_probe_event *pev)
>  {
>  	struct probe_cache_entry *entry = NULL;
> @@ -548,6 +548,24 @@ found:
>  	return entry;
>  }
>  
> +struct probe_cache_entry *
> +probe_cache__find_by_name(struct probe_cache *pcache,
> +			  const char *group, const char *event)
> +{
> +	struct probe_cache_entry *entry = NULL;
> +
> +	list_for_each_entry(entry, &pcache->entries, node) {
> +		/* Hit if same event name or same command-string */
> +		if (streql(entry->pev.group, group) &&
> +		    streql(entry->pev.event, event))
> +			goto found;
> +	}
> +	entry = NULL;
> +
> +found:
> +	return entry;
> +}
> +
>  int probe_cache__add_entry(struct probe_cache *pcache,
>  			   struct perf_probe_event *pev,
>  			   struct probe_trace_event *tevs, int ntevs)
> diff --git a/tools/perf/util/probe-file.h b/tools/perf/util/probe-file.h
> index d872e3d..910aa74 100644
> --- a/tools/perf/util/probe-file.h
> +++ b/tools/perf/util/probe-file.h
> @@ -38,5 +38,8 @@ int probe_cache__add_entry(struct probe_cache *pcache,
>  int probe_cache__commit(struct probe_cache *pcache);
>  void probe_cache__purge(struct probe_cache *pcache);
>  void probe_cache__delete(struct probe_cache *pcache);
> -
> +struct probe_cache_entry *probe_cache__find(struct probe_cache *pcache,
> +					    struct perf_probe_event *pev);
> +struct probe_cache_entry *probe_cache__find_by_name(struct probe_cache *pcache,
> +					const char *group, const char *event);
>  #endif

  reply	other threads:[~2016-07-01 13:20 UTC|newest]

Thread overview: 32+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2016-07-01  8:03 [PATCH perf/core v13 00/15] perf-probe --cache and SDT support Masami Hiramatsu
2016-07-01  8:03 ` [PATCH perf/core v13 01/15] perf probe: Use cache entry if possible Masami Hiramatsu
2016-07-01 13:20   ` Arnaldo Carvalho de Melo [this message]
2016-07-05 10:16   ` [tip:perf/core] " tip-bot for Masami Hiramatsu
2016-07-01  8:03 ` [PATCH perf/core v13 02/15] perf probe: Show all cached probes Masami Hiramatsu
2016-07-01 13:51   ` Arnaldo Carvalho de Melo
2016-07-04  2:03     ` Masami Hiramatsu
2016-07-04  2:06       ` [PATCH perf/core] [BUGFIX] perf-probe: Fix to show correct error message for $vars and $params Masami Hiramatsu
2016-07-05 10:17   ` [tip:perf/core] perf probe: Show all cached probes tip-bot for Masami Hiramatsu
2016-07-01  8:03 ` [PATCH perf/core v13 03/15] perf probe: Remove caches when --cache is given Masami Hiramatsu
2016-07-05 10:17   ` [tip:perf/core] " tip-bot for Masami Hiramatsu
2016-07-01  8:03 ` [PATCH perf/core v13 04/15] perf/sdt: ELF support for SDT Masami Hiramatsu
2016-07-01 18:56   ` Arnaldo Carvalho de Melo
2016-07-04  5:25     ` Masami Hiramatsu
2016-07-05 10:18   ` [tip:perf/core] perf sdt: " tip-bot for Hemant Kumar
2016-07-01  8:04 ` [PATCH perf/core v13 05/15] perf probe: Add group name support Masami Hiramatsu
2016-07-05 10:19   ` [tip:perf/core] " tip-bot for Masami Hiramatsu
2016-07-01  8:04 ` [PATCH perf/core v13 06/15] perf buildid-cache: Scan and import user SDT events to probe cache Masami Hiramatsu
2016-07-01 18:22   ` Arnaldo Carvalho de Melo
2016-07-04  2:15     ` Masami Hiramatsu
2016-07-05  2:08     ` Masami Hiramatsu
2016-07-05 10:19   ` [tip:perf/core] " tip-bot for Masami Hiramatsu
2016-07-01  8:04 ` [PATCH perf/core v13 07/15] perf probe: Accept %sdt and %cached event name Masami Hiramatsu
2016-07-01  8:04 ` [PATCH perf/core v13 08/15] perf-probe: Make --list shows only available cached events Masami Hiramatsu
2016-07-01  8:04 ` [PATCH perf/core v13 09/15] perf: probe-cache: Add for_each_probe_cache_entry() wrapper Masami Hiramatsu
2016-07-01  8:04 ` [PATCH perf/core v13 10/15] perf probe: Allow wildcard for cached events Masami Hiramatsu
2016-07-01  8:04 ` [PATCH perf/core v13 11/15] perf probe: Search SDT/cached event from all probe caches Masami Hiramatsu
2016-07-01  8:05 ` [PATCH perf/core v13 12/15] perf probe: Support @BUILDID or @FILE suffix for SDT events Masami Hiramatsu
2016-07-01  8:05 ` [PATCH perf/core v13 13/15] perf probe: Support a special SDT probe format Masami Hiramatsu
2016-07-01  8:05 ` [PATCH perf/core v13 14/15] perf build: Add sdt feature detection Masami Hiramatsu
2016-07-01  8:05 ` [PATCH perf/core v13 15/15] perf-test: Add a test case for SDT event Masami Hiramatsu
2016-07-01 13:19 ` [PATCH perf/core v13 00/15] perf-probe --cache and SDT support Arnaldo Carvalho de Melo

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20160701132024.GK5324@kernel.org \
    --to=acme@kernel.org \
    --cc=ananth@linux.vnet.ibm.com \
    --cc=brendan.d.gregg@gmail.com \
    --cc=hemant@linux.vnet.ibm.com \
    --cc=linux-kernel@vger.kernel.org \
    --cc=mhiramat@kernel.org \
    --cc=mingo@redhat.com \
    --cc=namhyung@kernel.org \
    --cc=peterz@infradead.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.