|
Michal Suchanek |
d096c5 |
From 26da4abfb38201c3cbe127daeded76d4c2bc9077 Mon Sep 17 00:00:00 2001
|
|
Michal Suchanek |
d096c5 |
From: Kajol Jain <kjain@linux.ibm.com>
|
|
Michal Suchanek |
d096c5 |
Date: Wed, 6 Oct 2021 19:36:54 +0530
|
|
Michal Suchanek |
d096c5 |
Subject: [PATCH] powerpc/perf: Fix data source encodings for L2.1 and L3.1
|
|
Michal Suchanek |
d096c5 |
accesses
|
|
Michal Suchanek |
d096c5 |
|
|
Michal Suchanek |
d096c5 |
References: bsc#1065729
|
|
Michal Suchanek |
d096c5 |
Patch-mainline: v5.16-rc1
|
|
Michal Suchanek |
d096c5 |
Git-commit: 26da4abfb38201c3cbe127daeded76d4c2bc9077
|
|
Michal Suchanek |
d096c5 |
|
|
Michal Suchanek |
d096c5 |
Fix the data source encodings to represent L2.1/L3.1(another core's
|
|
Michal Suchanek |
d096c5 |
L2/L3 on the same node) accesses properly for power10 and older
|
|
Michal Suchanek |
d096c5 |
plaforms.
|
|
Michal Suchanek |
d096c5 |
|
|
Michal Suchanek |
d096c5 |
Add new macros(LEVEL/REM) which can be used to add mem_lvl_num and remote
|
|
Michal Suchanek |
d096c5 |
field data inside perf_mem_data_src structure.
|
|
Michal Suchanek |
d096c5 |
|
|
Michal Suchanek |
d096c5 |
Result in power9 system with patch changes:
|
|
Michal Suchanek |
d096c5 |
|
|
Michal Suchanek |
d096c5 |
localhost:~/linux/tools/perf # ./perf mem report | grep Remote
|
|
Michal Suchanek |
d096c5 |
0.01% 1 252 Remote core, same node L3 or L3 hit [.] 0x0000000000002dd0 producer_consumer [.] 0x00007fff7f25eb90
|
|
Michal Suchanek |
d096c5 |
anon HitM N/A No N/A 0 0
|
|
Michal Suchanek |
d096c5 |
0.01% 1 220 Remote core, same node L3 or L3 hit [.] 0x0000000000002dd0 producer_consumer [.] 0x00007fff77776d90
|
|
Michal Suchanek |
d096c5 |
anon HitM N/A No N/A 0 0
|
|
Michal Suchanek |
d096c5 |
0.01% 1 220 Remote core, same node L3 or L3 hit [.] 0x0000000000002dd0 producer_consumer [.] 0x00007fff817d9410
|
|
Michal Suchanek |
d096c5 |
anon HitM N/A No N/A 0 0
|
|
Michal Suchanek |
d096c5 |
|
|
Michal Suchanek |
d096c5 |
Fixes: 79e96f8f930d ("powerpc/perf: Export memory hierarchy info to user space")
|
|
Michal Suchanek |
d096c5 |
Signed-off-by: Kajol Jain <kjain@linux.ibm.com>
|
|
Michal Suchanek |
d096c5 |
Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org>
|
|
Michal Suchanek |
d096c5 |
Link: https://lore.kernel.org/r/20211006140654.298352-5-kjain@linux.ibm.com
|
|
Michal Suchanek |
d096c5 |
[ms: P(HOPS, 0) encoding not supported on 5.3]
|
|
Michal Suchanek |
d096c5 |
Acked-by: Michal Suchanek <msuchanek@suse.de>
|
|
Michal Suchanek |
d096c5 |
---
|
|
Michal Suchanek |
d096c5 |
arch/powerpc/perf/isa207-common.c | 26 +++++++++++++++++++++-----
|
|
Michal Suchanek |
d096c5 |
arch/powerpc/perf/isa207-common.h | 2 ++
|
|
Michal Suchanek |
d096c5 |
2 files changed, 23 insertions(+), 5 deletions(-)
|
|
Michal Suchanek |
d096c5 |
|
|
Michal Suchanek |
d096c5 |
diff --git a/arch/powerpc/perf/isa207-common.c b/arch/powerpc/perf/isa207-common.c
|
|
Michal Suchanek |
d096c5 |
--- a/arch/powerpc/perf/isa207-common.c
|
|
Michal Suchanek |
d096c5 |
+++ b/arch/powerpc/perf/isa207-common.c
|
|
Michal Suchanek |
d096c5 |
@@ -238,11 +238,27 @@ static inline u64 isa207_find_source(u64 idx, u32 sub_idx)
|
|
Michal Suchanek |
d096c5 |
ret |= P(SNOOP, HIT);
|
|
Michal Suchanek |
d096c5 |
break;
|
|
Michal Suchanek |
d096c5 |
case 5:
|
|
Michal Suchanek |
d096c5 |
- ret = PH(LVL, REM_CCE1);
|
|
Michal Suchanek |
d096c5 |
- if ((sub_idx == 0) || (sub_idx == 2) || (sub_idx == 4))
|
|
Michal Suchanek |
d096c5 |
- ret |= P(SNOOP, HIT);
|
|
Michal Suchanek |
d096c5 |
- else if ((sub_idx == 1) || (sub_idx == 3) || (sub_idx == 5))
|
|
Michal Suchanek |
d096c5 |
- ret |= P(SNOOP, HITM);
|
|
Michal Suchanek |
d096c5 |
+ if (cpu_has_feature(CPU_FTR_ARCH_31)) {
|
|
Michal Suchanek |
d096c5 |
+ ret = REM;
|
|
Michal Suchanek |
d096c5 |
+
|
|
Michal Suchanek |
d096c5 |
+ if (sub_idx == 0 || sub_idx == 4)
|
|
Michal Suchanek |
d096c5 |
+ ret |= PH(LVL, L2) | LEVEL(L2) | P(SNOOP, HIT);
|
|
Michal Suchanek |
d096c5 |
+ else if (sub_idx == 1 || sub_idx == 5)
|
|
Michal Suchanek |
d096c5 |
+ ret |= PH(LVL, L2) | LEVEL(L2) | P(SNOOP, HITM);
|
|
Michal Suchanek |
d096c5 |
+ else if (sub_idx == 2 || sub_idx == 6)
|
|
Michal Suchanek |
d096c5 |
+ ret |= PH(LVL, L3) | LEVEL(L3) | P(SNOOP, HIT);
|
|
Michal Suchanek |
d096c5 |
+ else if (sub_idx == 3 || sub_idx == 7)
|
|
Michal Suchanek |
d096c5 |
+ ret |= PH(LVL, L3) | LEVEL(L3) | P(SNOOP, HITM);
|
|
Michal Suchanek |
d096c5 |
+ } else {
|
|
Michal Suchanek |
d096c5 |
+ if (sub_idx == 0)
|
|
Michal Suchanek |
d096c5 |
+ ret = PH(LVL, L2) | LEVEL(L2) | REM | P(SNOOP, HIT);
|
|
Michal Suchanek |
d096c5 |
+ else if (sub_idx == 1)
|
|
Michal Suchanek |
d096c5 |
+ ret = PH(LVL, L2) | LEVEL(L2) | REM | P(SNOOP, HITM);
|
|
Michal Suchanek |
d096c5 |
+ else if (sub_idx == 2 || sub_idx == 4)
|
|
Michal Suchanek |
d096c5 |
+ ret = PH(LVL, L3) | LEVEL(L3) | REM | P(SNOOP, HIT);
|
|
Michal Suchanek |
d096c5 |
+ else if (sub_idx == 3 || sub_idx == 5)
|
|
Michal Suchanek |
d096c5 |
+ ret = PH(LVL, L3) | LEVEL(L3) | REM | P(SNOOP, HITM);
|
|
Michal Suchanek |
d096c5 |
+ }
|
|
Michal Suchanek |
d096c5 |
break;
|
|
Michal Suchanek |
d096c5 |
case 6:
|
|
Michal Suchanek |
d096c5 |
ret = PH(LVL, REM_CCE2);
|
|
Michal Suchanek |
d096c5 |
diff --git a/arch/powerpc/perf/isa207-common.h b/arch/powerpc/perf/isa207-common.h
|
|
Michal Suchanek |
d096c5 |
--- a/arch/powerpc/perf/isa207-common.h
|
|
Michal Suchanek |
d096c5 |
+++ b/arch/powerpc/perf/isa207-common.h
|
|
Michal Suchanek |
d096c5 |
@@ -273,6 +273,8 @@
|
|
Michal Suchanek |
d096c5 |
#define P(a, b) PERF_MEM_S(a, b)
|
|
Michal Suchanek |
d096c5 |
#define PH(a, b) (P(LVL, HIT) | P(a, b))
|
|
Michal Suchanek |
d096c5 |
#define PM(a, b) (P(LVL, MISS) | P(a, b))
|
|
Michal Suchanek |
d096c5 |
+#define LEVEL(x) P(LVLNUM, x)
|
|
Michal Suchanek |
d096c5 |
+#define REM P(REMOTE, REMOTE)
|
|
Michal Suchanek |
d096c5 |
|
|
Michal Suchanek |
d096c5 |
int isa207_get_constraint(u64 event, unsigned long *maskp, unsigned long *valp);
|
|
Michal Suchanek |
d096c5 |
int isa207_compute_mmcr(u64 event[], int n_ev,
|
|
Michal Suchanek |
d096c5 |
--
|
|
Michal Suchanek |
d096c5 |
2.31.1
|
|
Michal Suchanek |
d096c5 |
|