Skip to content

Commit 87bf399

Browse files
zhang-ruiPeter Zijlstra
authored andcommitted
perf/x86/cstate: Add ICELAKE_X and ICELAKE_D support
Introduce icx_cstates for ICELAKE_X and ICELAKE_D, and also update the comments. On ICELAKE_X and ICELAKE_D, Core C1, Core C6, Package C2 and Package C6 Residency MSRs are supported. This patch has been tested on real hardware. Signed-off-by: Zhang Rui <[email protected]> Signed-off-by: Peter Zijlstra (Intel) <[email protected]> Reviewed-by: Kan Liang <[email protected]> Acked-by: Artem Bityutskiy <[email protected]> Link: https://lkml.kernel.org/r/[email protected]
1 parent 62fb987 commit 87bf399

File tree

1 file changed

+17
-6
lines changed

1 file changed

+17
-6
lines changed

arch/x86/events/intel/cstate.c

Lines changed: 17 additions & 6 deletions
Original file line numberDiff line numberDiff line change
@@ -40,7 +40,7 @@
4040
* Model specific counters:
4141
* MSR_CORE_C1_RES: CORE C1 Residency Counter
4242
* perf code: 0x00
43-
* Available model: SLM,AMT,GLM,CNL,TNT,ADL
43+
* Available model: SLM,AMT,GLM,CNL,ICX,TNT,ADL
4444
* Scope: Core (each processor core has a MSR)
4545
* MSR_CORE_C3_RESIDENCY: CORE C3 Residency Counter
4646
* perf code: 0x01
@@ -50,8 +50,8 @@
5050
* MSR_CORE_C6_RESIDENCY: CORE C6 Residency Counter
5151
* perf code: 0x02
5252
* Available model: SLM,AMT,NHM,WSM,SNB,IVB,HSW,BDW,
53-
* SKL,KNL,GLM,CNL,KBL,CML,ICL,TGL,
54-
* TNT,RKL,ADL
53+
* SKL,KNL,GLM,CNL,KBL,CML,ICL,ICX,
54+
* TGL,TNT,RKL,ADL
5555
* Scope: Core
5656
* MSR_CORE_C7_RESIDENCY: CORE C7 Residency Counter
5757
* perf code: 0x03
@@ -61,7 +61,7 @@
6161
* MSR_PKG_C2_RESIDENCY: Package C2 Residency Counter.
6262
* perf code: 0x00
6363
* Available model: SNB,IVB,HSW,BDW,SKL,KNL,GLM,CNL,
64-
* KBL,CML,ICL,TGL,TNT,RKL,ADL
64+
* KBL,CML,ICL,ICX,TGL,TNT,RKL,ADL
6565
* Scope: Package (physical package)
6666
* MSR_PKG_C3_RESIDENCY: Package C3 Residency Counter.
6767
* perf code: 0x01
@@ -72,8 +72,8 @@
7272
* MSR_PKG_C6_RESIDENCY: Package C6 Residency Counter.
7373
* perf code: 0x02
7474
* Available model: SLM,AMT,NHM,WSM,SNB,IVB,HSW,BDW,
75-
* SKL,KNL,GLM,CNL,KBL,CML,ICL,TGL,
76-
* TNT,RKL,ADL
75+
* SKL,KNL,GLM,CNL,KBL,CML,ICL,ICX,
76+
* TGL,TNT,RKL,ADL
7777
* Scope: Package (physical package)
7878
* MSR_PKG_C7_RESIDENCY: Package C7 Residency Counter.
7979
* perf code: 0x03
@@ -566,6 +566,14 @@ static const struct cstate_model icl_cstates __initconst = {
566566
BIT(PERF_CSTATE_PKG_C10_RES),
567567
};
568568

569+
static const struct cstate_model icx_cstates __initconst = {
570+
.core_events = BIT(PERF_CSTATE_CORE_C1_RES) |
571+
BIT(PERF_CSTATE_CORE_C6_RES),
572+
573+
.pkg_events = BIT(PERF_CSTATE_PKG_C2_RES) |
574+
BIT(PERF_CSTATE_PKG_C6_RES),
575+
};
576+
569577
static const struct cstate_model adl_cstates __initconst = {
570578
.core_events = BIT(PERF_CSTATE_CORE_C1_RES) |
571579
BIT(PERF_CSTATE_CORE_C6_RES) |
@@ -664,6 +672,9 @@ static const struct x86_cpu_id intel_cstates_match[] __initconst = {
664672

665673
X86_MATCH_INTEL_FAM6_MODEL(ICELAKE_L, &icl_cstates),
666674
X86_MATCH_INTEL_FAM6_MODEL(ICELAKE, &icl_cstates),
675+
X86_MATCH_INTEL_FAM6_MODEL(ICELAKE_X, &icx_cstates),
676+
X86_MATCH_INTEL_FAM6_MODEL(ICELAKE_D, &icx_cstates),
677+
667678
X86_MATCH_INTEL_FAM6_MODEL(TIGERLAKE_L, &icl_cstates),
668679
X86_MATCH_INTEL_FAM6_MODEL(TIGERLAKE, &icl_cstates),
669680
X86_MATCH_INTEL_FAM6_MODEL(ROCKETLAKE, &icl_cstates),

0 commit comments

Comments
 (0)