perf streams: Introduce branch history "streams"
authorJin Yao <yao.jin@linux.intel.com>
Fri, 9 Oct 2020 02:28:39 +0000 (10:28 +0800)
committerArnaldo Carvalho de Melo <acme@redhat.com>
Wed, 14 Oct 2020 16:27:28 +0000 (13:27 -0300)
commit480accbb17609be01abcd09517605a930791bfdb
tree105199a5641a450122c7ede5f947159ae0001015
parent6556a75becb51afa8f9233186d437e9b6eb6f4b5
perf streams: Introduce branch history "streams"

We define a stream as the branch history which is aggregated by the
branch records from perf samples. For example, the callchains aggregated
from the branch records are considered as streams.  By browsing the hot
stream, we can understand the hot code path.

Now we only support the callchain for stream. For measuring the hot
level for a stream, we use the callchain_node->hit, higher is hotter.

There may be many callchains sampled so we only focus on the top N
hottest callchains. N is a user defined parameter or predefined default
value (nr_streams_max).

This patch creates an evsel_streams array per event, and saves the top N
hottest streams in a stream array.

So now we can get the per-event top N hottest streams.

Signed-off-by: Jin Yao <yao.jin@linux.intel.com>
Acked-by: Jiri Olsa <jolsa@kernel.org>
Link: https://lore.kernel.org/r/20201009022845.13141-2-yao.jin@linux.intel.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
tools/perf/util/Build
tools/perf/util/stream.c [new file with mode: 0644]
tools/perf/util/stream.h [new file with mode: 0644]