diff options
author | Jiri Olsa <jolsa@redhat.com> | 2014-03-02 10:56:40 -0500 |
---|---|---|
committer | Ingo Molnar <mingo@kernel.org> | 2014-03-11 06:57:59 -0400 |
commit | 6bedfab68666afac1b03f8d62ee037c6ab82fbc5 (patch) | |
tree | 900b063d69014b93d04abf5883cf73c729d2e98f /tools/perf/util/evsel.h | |
parent | 63c45f4ba533e9749da16298db53e491c25d805b (diff) |
perf tools: Disable user-space callchain/stack dumps for function trace events
User space callchains and user space stack dump were disabled
for function trace event. Mailing list discussions:
http://marc.info/?t=139302086500001&r=1&w=2
http://marc.info/?t=139301437300003&r=1&w=2
Catching up with perf and disabling user space callchains and
DWARF unwind (uses user stack dump) for function trace event.
Adding following warnings when callchains are used
for function trace event:
# perf record -g -e ftrace:function ...
Disabling user space callchains for function trace event.
...
# ./perf record --call-graph=dwarf -e ftrace:function ...
Cannot use DWARF unwind for function trace event, falling back to framepointers.
Disabling user space callchains for function trace event.
...
Signed-off-by: Jiri Olsa <jolsa@redhat.com>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Arnaldo Carvalho de Melo <acme@ghostprotocols.net>
Cc: "H. Peter Anvin" <hpa@zytor.com>
Cc: Vince Weaver <vincent.weaver@maine.edu>
Cc: Steven Rostedt <rostedt@goodmis.org>
Signed-off-by: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/1393775800-13524-4-git-send-email-jolsa@redhat.com
Signed-off-by: Ingo Molnar <mingo@kernel.org>
Diffstat (limited to 'tools/perf/util/evsel.h')
-rw-r--r-- | tools/perf/util/evsel.h | 18 |
1 files changed, 18 insertions, 0 deletions
diff --git a/tools/perf/util/evsel.h b/tools/perf/util/evsel.h index f1b325665aae..0c9926cfb292 100644 --- a/tools/perf/util/evsel.h +++ b/tools/perf/util/evsel.h | |||
@@ -315,6 +315,24 @@ static inline bool perf_evsel__is_group_event(struct perf_evsel *evsel) | |||
315 | return perf_evsel__is_group_leader(evsel) && evsel->nr_members > 1; | 315 | return perf_evsel__is_group_leader(evsel) && evsel->nr_members > 1; |
316 | } | 316 | } |
317 | 317 | ||
318 | /** | ||
319 | * perf_evsel__is_function_event - Return whether given evsel is a function | ||
320 | * trace event | ||
321 | * | ||
322 | * @evsel - evsel selector to be tested | ||
323 | * | ||
324 | * Return %true if event is function trace event | ||
325 | */ | ||
326 | static inline bool perf_evsel__is_function_event(struct perf_evsel *evsel) | ||
327 | { | ||
328 | #define FUNCTION_EVENT "ftrace:function" | ||
329 | |||
330 | return evsel->name && | ||
331 | !strncmp(FUNCTION_EVENT, evsel->name, sizeof(FUNCTION_EVENT)); | ||
332 | |||
333 | #undef FUNCTION_EVENT | ||
334 | } | ||
335 | |||
318 | struct perf_attr_details { | 336 | struct perf_attr_details { |
319 | bool freq; | 337 | bool freq; |
320 | bool verbose; | 338 | bool verbose; |