perf powerpc: Add data source encodings for power10 platform
authorKajol Jain <kjain@linux.ibm.com>
Mon, 6 Dec 2021 09:17:49 +0000 (14:47 +0530)
committerArnaldo Carvalho de Melo <acme@redhat.com>
Wed, 22 Dec 2021 12:38:56 +0000 (09:38 -0300)
commitaf2b24f228a0373ac65eb7a502e0bc31e2c0269d
treec5d89a744256b81c13297ca1f8c51c606488feda
parent0ebce3d65f1f53c936fdd51e975bd876ba7ed64f
perf powerpc: Add data source encodings for power10 platform

The code represent memory/cache level data based on PERF_MEM_LVL_*
namespace, which is in the process of deprication in the favour of newer
composite PERF_MEM_{LVLNUM_,REMOTE_,SNOOPX_,HOPS_} fields.  Add data
source encodings to represent cache/memory data based on newer composite
PERF_MEM_{LVLNUM_,REMOTE_,SNOOPX_,HOPS_} fields.

Add data source encodings to represent data coming from local
memory/Remote memory/distant memory and remote/distant cache hits.

Inorder to represent data coming from OpenCAPI cache/memory, we use
LVLNUM "PMEM" field which is used to present persistent memory accesses.

Result in power10 system with patch changes:

  localhost:# ./perf mem report --sort="mem,sym,dso" --stdio
  # Overhead  Samples  Memory access                           Symbol                       Shared Object
  # ........  .......  ......................................  ...........................  .................
  #
     29.46%     2331  L1 or L1 hit                             [.] __random                 libc-2.28.so
     23.11%     2121  L1 or L1 hit                             [.] producer_populate_cache  producer_consumer
     18.56%     1758  L1 or L1 hit                             [.] __random_r               libc-2.28.so
     15.64%     1559  L2 or L2 hit                             [.] __random                 libc-2.28.so
     .....
     0.09%         5  Remote socket, same board Any cache hit  [.] __random                 libc-2.28.so
     0.07%         4  Remote socket, same board Any cache hit  [.] __random                 libc-2.28.so
     .....

Reviewed-by: Madhavan Srinivasan <maddy@linux.ibm.com>
Signed-off-by: Kajol Jain <kjain@linux.ibm.com>
Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com>
Cc: Alexei Starovoitov <ast@kernel.org>
Cc: Andi Kleen <ak@linux.intel.com>
Cc: Athira Jajeev <atrajeev@linux.vnet.ibm.com>
Cc: Daniel Borkmann <daniel@iogearbox.net>
Cc: Jin Yao <yao.jin@linux.intel.com>
Cc: Jiri Olsa <jolsa@kernel.org>
Cc: Kan Liang <kan.liang@linux.intel.com>
Cc: Mark Rutland <mark.rutland@arm.com>
Cc: Michael Ellerman <mpe@ellerman.id.au>
Cc: Nageswara R Sastry <rnsastry@linux.ibm.com>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Song Liu <songliubraving@fb.com>
Cc: linuxppc-dev@lists.ozlabs.org
Link: http://lore.kernel.org/lkml/20211206091749.87585-5-kjain@linux.ibm.com
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
arch/powerpc/perf/isa207-common.c