Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S933628AbcKORHW convert rfc822-to-8bit (ORCPT ); Tue, 15 Nov 2016 12:07:22 -0500 Received: from mga11.intel.com ([192.55.52.93]:21977 "EHLO mga11.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751971AbcKORHU (ORCPT ); Tue, 15 Nov 2016 12:07:20 -0500 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.31,495,1473145200"; d="scan'208";a="1068826146" From: "Liang, Kan" To: Oskar Senft , "linux-kernel@vger.kernel.org" CC: "mark@voidzero.net" Subject: RE: [PATCH 2/2] perf/x86/intel/uncore: Fix SBOX support for Broadwell CPUs. Thread-Topic: [PATCH 2/2] perf/x86/intel/uncore: Fix SBOX support for Broadwell CPUs. Thread-Index: AQHSP2E+4a1vRFjbeEScP0ZuSsM1wKDaRmiw Date: Tue, 15 Nov 2016 17:07:16 +0000 Message-ID: <37D7C6CF3E00A74B8858931C1DB2F07750C9FFA6@SHSMSX103.ccr.corp.intel.com> References: <1479228970-15245-1-git-send-email-osk@google.com> <1479228970-15245-2-git-send-email-osk@google.com> In-Reply-To: <1479228970-15245-2-git-send-email-osk@google.com> Accept-Language: zh-CN, en-US Content-Language: en-US X-MS-Has-Attach: X-MS-TNEF-Correlator: x-titus-metadata-40: eyJDYXRlZ29yeUxhYmVscyI6IiIsIk1ldGFkYXRhIjp7Im5zIjoiaHR0cDpcL1wvd3d3LnRpdHVzLmNvbVwvbnNcL0ludGVsMyIsImlkIjoiYjYwMWE3ZmUtNWYyOC00ZDZkLWEyYzgtN2M4ZjU5NTg5YTJmIiwicHJvcHMiOlt7Im4iOiJDVFBDbGFzc2lmaWNhdGlvbiIsInZhbHMiOlt7InZhbHVlIjoiQ1RQX0lDIn1dfV19LCJTdWJqZWN0TGFiZWxzIjpbXSwiVE1DVmVyc2lvbiI6IjE1LjkuNi42IiwiVHJ1c3RlZExhYmVsSGFzaCI6InBxdWk3dnBtTzlvU3BlQlZrSDF1eXVoQ1VxbFVvT2ZCNFFKWlBJdWxBeEE9In0= x-ctpclassification: CTP_IC x-originating-ip: [10.239.127.40] Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 8BIT MIME-Version: 1.0 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2245 Lines: 72 > This fixes SBOX support for Broadwell CPUs by checking the Power Control > Unit CAPID4 register to determine the number of available SBOXes on the > particular CPU before trying to enable them. > > This patch has been tested on E5-2620 v4 (no SBOXes) and E5-2697 v4 (4 > SBOXes). > > Signed-off-by: Oskar Senft > Tested-by: Mark van Dijk Reviewed-by: Kan Liang > Fixes: 3b94a891667c30fb4624221497d77fc65d950345 > --- > arch/x86/events/intel/uncore_snbep.c | 22 ++++++++++++++++++++-- > 1 file changed, 20 insertions(+), 2 deletions(-) > > diff --git a/arch/x86/events/intel/uncore_snbep.c > b/arch/x86/events/intel/uncore_snbep.c > index bcb54d7..6f4f67e 100644 > --- a/arch/x86/events/intel/uncore_snbep.c > +++ b/arch/x86/events/intel/uncore_snbep.c > @@ -3054,13 +3054,26 @@ static struct intel_uncore_type > *bdx_msr_uncores[] = { > > void bdx_uncore_cpu_init(void) > { > + int pkg = topology_phys_to_logical_pkg(0); > + > if (bdx_uncore_cbox.num_boxes > boot_cpu_data.x86_max_cores) > bdx_uncore_cbox.num_boxes = > boot_cpu_data.x86_max_cores; > - uncore_msr_uncores = bdx_msr_uncores; > > /* BDX-DE doesn't have SBOX */ > if (boot_cpu_data.x86_model == 86) > - uncore_msr_uncores[BDX_MSR_UNCORE_SBOX] = NULL; > + bdx_msr_uncores[BDX_MSR_UNCORE_SBOX] = NULL; > + /* Detect systems with no SBOXes */ > + else if (uncore_extra_pci_dev[pkg].dev[HSWEP_PCI_PCU_3]) { > + u32 capid4; > + > + pci_read_config_dword( > + uncore_extra_pci_dev[pkg].dev[HSWEP_PCI_PCU_3], > + 0x94, &capid4); > + if (((capid4 >> 6) & 0x3) == 0) > + bdx_msr_uncores[BDX_MSR_UNCORE_SBOX] = NULL; > + } > + > + uncore_msr_uncores = bdx_msr_uncores; > } > > static struct intel_uncore_type bdx_uncore_ha = { @@ -3277,6 +3290,11 > @@ static const struct pci_device_id bdx_uncore_pci_ids[] = { > PCI_DEVICE(PCI_VENDOR_ID_INTEL, 0x6f46), > .driver_data = > UNCORE_PCI_DEV_DATA(UNCORE_EXTRA_PCI_DEV, 2), > }, > + { /* PCU.3 (for Capability registers) */ > + PCI_DEVICE(PCI_VENDOR_ID_INTEL, 0x6fc0), > + .driver_data = > UNCORE_PCI_DEV_DATA(UNCORE_EXTRA_PCI_DEV, > + HSWEP_PCI_PCU_3), > + }, > { /* end: all zeroes */ } > }; > > -- > 2.8.0.rc3.226.g39d4020