Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753280AbbBXXSe (ORCPT ); Tue, 24 Feb 2015 18:18:34 -0500 Received: from mga01.intel.com ([192.55.52.88]:5514 "EHLO mga01.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753240AbbBXXSc (ORCPT ); Tue, 24 Feb 2015 18:18:32 -0500 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.09,641,1418112000"; d="scan'208";a="532360009" From: Vikas Shivappa To: linux-kernel@vger.kernel.org Cc: vikas.shivappa@intel.com, vikas.shivappa@linux.intel.com, matt.fleming@intel.com, hpa@zytor.com, tglx@linutronix.de, mingo@kernel.org, tj@kernel.org, peterz@infradead.org, will.auld@intel.com, dave.hansen@intel.com, andi.kleen@intel.com, tony.luck@intel.com, kanaka.d.juvva@intel.com Subject: [PATCH 6/7] x86/intel_rdt: Intel haswell CAT enumeration Date: Tue, 24 Feb 2015 15:16:43 -0800 Message-Id: <1424819804-4082-7-git-send-email-vikas.shivappa@linux.intel.com> X-Mailer: git-send-email 1.9.1 In-Reply-To: <1424819804-4082-1-git-send-email-vikas.shivappa@linux.intel.com> References: <1424819804-4082-1-git-send-email-vikas.shivappa@linux.intel.com> Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2202 Lines: 77 CAT(Cache Allocation Technology) on hsw needs to be enumerated separately. CAT is only supported on certain HSW SKUs. This patch does a probe test for hsw CPUs by writing a CLOSid into high 32 bits of IA32_PQR_MSR and see if the bits stick. The probe test is only done after confirming that the CPU is HSW. Signed-off-by: Vikas Shivappa --- arch/x86/kernel/cpu/intel_rdt.c | 42 +++++++++++++++++++++++++++++++++++++++++ 1 file changed, 42 insertions(+) diff --git a/arch/x86/kernel/cpu/intel_rdt.c b/arch/x86/kernel/cpu/intel_rdt.c index 602c580..d61be19 100644 --- a/arch/x86/kernel/cpu/intel_rdt.c +++ b/arch/x86/kernel/cpu/intel_rdt.c @@ -38,11 +38,53 @@ DEFINE_PER_CPU(unsigned int, x86_cpu_clos); #define rdt_for_each_child(pos_css, parent_ir) \ css_for_each_child((pos_css), &(parent_ir)->css) +/* + * hsw_probetest() - Have to do probe + * test for Intel haswell CPUs as it does not have + * CPUID enumeration support for CAT. + * + * Probes by writing to the high 32 bits(CLOSid) + * of the IA32_PQR_MSR and testing if the bits stick. + * Then hardcode the max CLOS and max bitmask length on hsw. + */ + +static inline bool hsw_probetest(void) +{ + u32 l, h_old, h_new, h_tmp; + + if (rdmsr_safe(MSR_IA32_PQR_ASSOC, &l, &h_old)) + return false; + + /* + * Default value is always 0 if feature is present. + */ + h_tmp = h_old ^ 0x1U; + if (wrmsr_safe(MSR_IA32_PQR_ASSOC, l, h_tmp) || + rdmsr_safe(MSR_IA32_PQR_ASSOC, &l, &h_new)) + return false; + + if (h_tmp != h_new) + return false; + + wrmsr_safe(MSR_IA32_PQR_ASSOC, l, h_old); + + boot_cpu_data.x86_cat_closs = 4; + boot_cpu_data.x86_cat_cbmlength = 20; + + return true; +} + static inline bool cat_supported(struct cpuinfo_x86 *c) { if (cpu_has(c, X86_FEATURE_CAT_L3)) return true; + /* + * Probe test for Haswell CPUs. + */ + if (c->x86 == 6 && c->x86_model == 0x3f) + return hsw_probetest(); + return false; } -- 1.9.1 -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/