perf/x86/amd/uncore: Update the number of uncore counters
This patch updates the AMD uncore driver to support AMD Family17h processors. In Family17h, there are two extra last level cache counters. The maximum available counters is increased and the number of counters for each uncore type is now based on the family. Signed-off-by: Janakarajan Natarajan <Janakarajan.Natarajan@amd.com> Signed-off-by: Peter Zijlstra (Intel) <peterz@infradead.org> Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com> Cc: Arnaldo Carvalho de Melo <acme@kernel.org> Cc: Arnaldo Carvalho de Melo <acme@redhat.com> Cc: Jiri Olsa <jolsa@redhat.com> Cc: Linus Torvalds <torvalds@linux-foundation.org> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Stephane Eranian <eranian@google.com> Cc: Suravee Suthikulpanit <suravee.suthikulpanit@amd.com> Cc: Thomas Gleixner <tglx@linutronix.de> Cc: Vince Weaver <vincent.weaver@maine.edu> Link: http://lkml.kernel.org/r/799f9c5be8963cc209d9169a08f4a2643b748dc7.1484598705.git.Janakarajan.Natarajan@amd.com Signed-off-by: Ingo Molnar <mingo@kernel.org>
This commit is contained in:
parent
a83f4c00dd
commit
bc1daef6b5
|
@ -22,13 +22,17 @@
|
||||||
|
|
||||||
#define NUM_COUNTERS_NB 4
|
#define NUM_COUNTERS_NB 4
|
||||||
#define NUM_COUNTERS_L2 4
|
#define NUM_COUNTERS_L2 4
|
||||||
#define MAX_COUNTERS NUM_COUNTERS_NB
|
#define NUM_COUNTERS_L3 6
|
||||||
|
#define MAX_COUNTERS 6
|
||||||
|
|
||||||
#define RDPMC_BASE_NB 6
|
#define RDPMC_BASE_NB 6
|
||||||
#define RDPMC_BASE_LLC 10
|
#define RDPMC_BASE_LLC 10
|
||||||
|
|
||||||
#define COUNTER_SHIFT 16
|
#define COUNTER_SHIFT 16
|
||||||
|
|
||||||
|
static int num_counters_llc;
|
||||||
|
static int num_counters_nb;
|
||||||
|
|
||||||
static HLIST_HEAD(uncore_unused_list);
|
static HLIST_HEAD(uncore_unused_list);
|
||||||
|
|
||||||
struct amd_uncore {
|
struct amd_uncore {
|
||||||
|
@ -303,7 +307,7 @@ static int amd_uncore_cpu_up_prepare(unsigned int cpu)
|
||||||
if (!uncore_nb)
|
if (!uncore_nb)
|
||||||
goto fail;
|
goto fail;
|
||||||
uncore_nb->cpu = cpu;
|
uncore_nb->cpu = cpu;
|
||||||
uncore_nb->num_counters = NUM_COUNTERS_NB;
|
uncore_nb->num_counters = num_counters_nb;
|
||||||
uncore_nb->rdpmc_base = RDPMC_BASE_NB;
|
uncore_nb->rdpmc_base = RDPMC_BASE_NB;
|
||||||
uncore_nb->msr_base = MSR_F15H_NB_PERF_CTL;
|
uncore_nb->msr_base = MSR_F15H_NB_PERF_CTL;
|
||||||
uncore_nb->active_mask = &amd_nb_active_mask;
|
uncore_nb->active_mask = &amd_nb_active_mask;
|
||||||
|
@ -317,7 +321,7 @@ static int amd_uncore_cpu_up_prepare(unsigned int cpu)
|
||||||
if (!uncore_llc)
|
if (!uncore_llc)
|
||||||
goto fail;
|
goto fail;
|
||||||
uncore_llc->cpu = cpu;
|
uncore_llc->cpu = cpu;
|
||||||
uncore_llc->num_counters = NUM_COUNTERS_L2;
|
uncore_llc->num_counters = num_counters_llc;
|
||||||
uncore_llc->rdpmc_base = RDPMC_BASE_LLC;
|
uncore_llc->rdpmc_base = RDPMC_BASE_LLC;
|
||||||
uncore_llc->msr_base = MSR_F16H_L2I_PERF_CTL;
|
uncore_llc->msr_base = MSR_F16H_L2I_PERF_CTL;
|
||||||
uncore_llc->active_mask = &amd_llc_active_mask;
|
uncore_llc->active_mask = &amd_llc_active_mask;
|
||||||
|
@ -492,6 +496,27 @@ static int __init amd_uncore_init(void)
|
||||||
if (boot_cpu_data.x86_vendor != X86_VENDOR_AMD)
|
if (boot_cpu_data.x86_vendor != X86_VENDOR_AMD)
|
||||||
goto fail_nodev;
|
goto fail_nodev;
|
||||||
|
|
||||||
|
switch(boot_cpu_data.x86) {
|
||||||
|
case 23:
|
||||||
|
/* Family 17h: */
|
||||||
|
num_counters_nb = NUM_COUNTERS_NB;
|
||||||
|
num_counters_llc = NUM_COUNTERS_L3;
|
||||||
|
break;
|
||||||
|
case 22:
|
||||||
|
/* Family 16h - may change: */
|
||||||
|
num_counters_nb = NUM_COUNTERS_NB;
|
||||||
|
num_counters_llc = NUM_COUNTERS_L2;
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
/*
|
||||||
|
* All prior families have the same number of
|
||||||
|
* NorthBridge and Last Level Cache counters
|
||||||
|
*/
|
||||||
|
num_counters_nb = NUM_COUNTERS_NB;
|
||||||
|
num_counters_llc = NUM_COUNTERS_L2;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
if (!boot_cpu_has(X86_FEATURE_TOPOEXT))
|
if (!boot_cpu_has(X86_FEATURE_TOPOEXT))
|
||||||
goto fail_nodev;
|
goto fail_nodev;
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue