Received: by 2002:ac0:946b:0:0:0:0:0 with SMTP id j40csp258797imj; Wed, 13 Feb 2019 07:54:59 -0800 (PST) X-Google-Smtp-Source: AHgI3Ib4DcHDIz2FZM928fF7t13IyNEO43AhuyCRLcy8dUeMjNqC2AlXCb6Vcm3A6Mes7Quaqmc9 X-Received: by 2002:a17:902:24a2:: with SMTP id w31mr1171422pla.216.1550073299206; Wed, 13 Feb 2019 07:54:59 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1550073299; cv=none; d=google.com; s=arc-20160816; b=qfrZouwf0cfzKwYlmfEGsyWF9+bROG2+bLmFjJItxrf/njVP4cm8oO6Ryy9d/95RtY Cj6FheCPnQu/3YfLcHUFfyrdj+FUzYf5yPM9aOxpDOKpkpKDSU8fxUTGQ0t4BZ0h/VdN 6KiXmXhAzNujyCW/gJ1xrP4iuuwkMggpDsIeEtxeci599FHswd7jKG25v0+DJeMB1T6u wVIRoj9iARF1ftcG5/HrblZuTIjIIZ7HPVyE+tzNCkXP8GmEK9vzsSgk1oIfav2mpKyU uRM/RE2lXeOL0wfKTozzUzLa9le6y1WjuVIK6MScwljkw0yT0LXYY6laAcOWBj4P4hCM z3lA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-language :content-transfer-encoding:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject; bh=7zFXArxc+79iK+gfoCCL/2eMfUUON8EgaMy6xrbfXHY=; b=t+PFtrxJ2zY3tuBNotmiriqYQ7QqP2SJMsg6NDIekC39fzcCEFVqLpOVlTNmbUH/Uh Mya+JRGT4tqtLIHBE6ZWJVa+KrQIKvQUwZEfrVEaGNT0amvRyDKhH810JUoUl64xMM7/ SSFYeW1niEc7hfl6DKA2Y+T+JBrHDRh5X+uJMPJeOrUm12Nq3fw+oU0rtmKbBEoYGdct 2UgjkSaRRRmKa5Qp1JPRA6gjJ/vv4gvAVnMr6vJcvTGTefrnqKQmy9YvEKEt5CPJYcCX k5dXPEGzfKS7VIQVwoxbnRwQQoP05IHK0KpwKkPbTxm7gGQ/CABRZRZBdG74wQMAMlDO RJgw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id r12si16115676pgl.350.2019.02.13.07.54.43; Wed, 13 Feb 2019 07:54:59 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2391571AbfBMPRY (ORCPT + 99 others); Wed, 13 Feb 2019 10:17:24 -0500 Received: from mga01.intel.com ([192.55.52.88]:52295 "EHLO mga01.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2389192AbfBMPRY (ORCPT ); Wed, 13 Feb 2019 10:17:24 -0500 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga003.jf.intel.com ([10.7.209.27]) by fmsmga101.fm.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 13 Feb 2019 07:17:23 -0800 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.58,365,1544515200"; d="scan'208";a="126161526" Received: from rbhardw1-mobl.gar.corp.intel.com (HELO [10.252.68.82]) ([10.252.68.82]) by orsmga003.jf.intel.com with ESMTP; 13 Feb 2019 07:17:19 -0800 Subject: Re: [PATCH 08/10] platform/x86: intel_pmc_core: Add ICL platform support To: Andy Shevchenko , Anshuman Gupta Cc: Platform Driver , Darren Hart , Andy Shevchenko , Linux Kernel Mailing List , "David E. Box" , Srinivas Pandruvada References: <20190201073234.13280-1-rajneesh.bhardwaj@linux.intel.com> <20190201073234.13280-9-rajneesh.bhardwaj@linux.intel.com> <20190212094318.GA8062@genxfsim-desktop> From: "Bhardwaj, Rajneesh" Message-ID: <49d30940-8520-b4a1-869b-00af8154e9fa@linux.intel.com> Date: Wed, 13 Feb 2019 20:47:18 +0530 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:60.0) Gecko/20100101 Thunderbird/60.5.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 7bit Content-Language: en-US Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 12-Feb-19 3:48 PM, Andy Shevchenko wrote: > On Tue, Feb 12, 2019 at 11:46 AM Anshuman Gupta > wrote: >> On Fri, Feb 01, 2019 at 01:02:32PM +0530, Rajneesh Bhardwaj wrote: >>> Icelake can resue most of the CNL PCH IPs as they are mostly similar. >>> This patch enables the PMC Core driver for ICL family. >>> >>> It also addresses few other minor issues like upper case conversions and >>> some tab alignments. >>> >>> Cc: "David E. Box" >>> Cc: Srinivas Pandruvada >>> Signed-off-by: Rajneesh Bhardwaj >> Acked-and-tested-by: > Thanks. > > Can you clarify what patches had been tested? > As far as I can understand you can't test this one before applying > previous seven patches. > > Rajneesh, when you will be about to send the rest, don't forget to > append the received tags. Sure Andy. I have sent the v2, incorporating tags and other suggestions that came over last two weeks. > >>> --- >>> drivers/platform/x86/intel_pmc_core.c | 59 +++++++++++++++++++++------ >>> drivers/platform/x86/intel_pmc_core.h | 4 ++ >>> 2 files changed, 50 insertions(+), 13 deletions(-) >>> >>> diff --git a/drivers/platform/x86/intel_pmc_core.c b/drivers/platform/x86/intel_pmc_core.c >>> index d3752d75075b..400946b7a3b5 100644 >>> --- a/drivers/platform/x86/intel_pmc_core.c >>> +++ b/drivers/platform/x86/intel_pmc_core.c >>> @@ -166,25 +166,26 @@ static const struct pmc_bit_map cnp_pfear_map[] = { >>> {"SDX", BIT(4)}, >>> {"SPE", BIT(5)}, >>> {"Fuse", BIT(6)}, >>> - {"Res_23", BIT(7)}, >>> + /* Reserved for Cannonlake but valid for Icelake */ >>> + {"SBR8", BIT(7)}, >>> >>> {"CSME_FSC", BIT(0)}, >>> {"USB3_OTG", BIT(1)}, >>> {"EXI", BIT(2)}, >>> {"CSE", BIT(3)}, >>> - {"csme_kvm", BIT(4)}, >>> - {"csme_pmt", BIT(5)}, >>> - {"csme_clink", BIT(6)}, >>> - {"csme_ptio", BIT(7)}, >>> - >>> - {"csme_usbr", BIT(0)}, >>> - {"csme_susram", BIT(1)}, >>> - {"csme_smt1", BIT(2)}, >>> + {"CSME_KVM", BIT(4)}, >>> + {"CSME_PMT", BIT(5)}, >>> + {"CSME_CLINK", BIT(6)}, >>> + {"CSME_PTIO", BIT(7)}, >>> + >>> + {"CSME_USBR", BIT(0)}, >>> + {"CSME_SUSRAM", BIT(1)}, >>> + {"CSME_SMT1", BIT(2)}, >>> {"CSME_SMT4", BIT(3)}, >>> - {"csme_sms2", BIT(4)}, >>> - {"csme_sms1", BIT(5)}, >>> - {"csme_rtc", BIT(6)}, >>> - {"csme_psf", BIT(7)}, >>> + {"CSME_SMS2", BIT(4)}, >>> + {"CSME_SMS1", BIT(5)}, >>> + {"CSME_RTC", BIT(6)}, >>> + {"CSME_PSF", BIT(7)}, >>> >>> {"SBR0", BIT(0)}, >>> {"SBR1", BIT(1)}, >>> @@ -209,6 +210,20 @@ static const struct pmc_bit_map cnp_pfear_map[] = { >>> {"HDA_PGD4", BIT(2)}, >>> {"HDA_PGD5", BIT(3)}, >>> {"HDA_PGD6", BIT(4)}, >>> + /* Reserved for Cannonlake but valid for Icelake */ >>> + {"PSF6", BIT(5)}, >>> + {"PSF7", BIT(6)}, >>> + {"PSF8", BIT(7)}, >>> + >>> + /* Icelake generation onwards only */ >>> + {"RES_65", BIT(0)}, >>> + {"RES_66", BIT(1)}, >>> + {"RES_67", BIT(2)}, >>> + {"TAM", BIT(3)}, >>> + {"GBETSN", BIT(4)}, >>> + {"TBTLSX", BIT(5)}, >>> + {"RES_71", BIT(6)}, >>> + {"RES_72", BIT(7)}, >>> {} >>> }; >>> >>> @@ -290,6 +305,8 @@ static const struct pmc_bit_map cnp_ltr_show_map[] = { >>> {"ISH", CNP_PMC_LTR_ISH}, >>> {"UFSX2", CNP_PMC_LTR_UFSX2}, >>> {"EMMC", CNP_PMC_LTR_EMMC}, >>> + /* Reserved for Cannonlake but valid for Icelake */ >>> + {"WIGIG", ICL_PMC_LTR_WIGIG}, >>> /* Below two cannot be used for LTR_IGNORE */ >>> {"CURRENT_PLATFORM", CNP_PMC_LTR_CUR_PLT}, >>> {"AGGREGATED_SYSTEM", CNP_PMC_LTR_CUR_ASLT}, >>> @@ -311,6 +328,21 @@ static const struct pmc_reg_map cnp_reg_map = { >>> .ltr_ignore_max = CNP_NUM_IP_IGN_ALLOWED, >>> }; >>> >>> +static const struct pmc_reg_map icl_reg_map = { >>> + .pfear_sts = cnp_pfear_map, >>> + .slp_s0_offset = CNP_PMC_SLP_S0_RES_COUNTER_OFFSET, >>> + .slps0_dbg_maps = cnp_slps0_dbg_maps, >>> + .ltr_show_sts = cnp_ltr_show_map, >>> + .slps0_dbg_offset = CNP_PMC_SLPS0_DBG_OFFSET, >>> + .ltr_ignore_offset = CNP_PMC_LTR_IGNORE_OFFSET, >>> + .regmap_length = CNP_PMC_MMIO_REG_LEN, >>> + .ppfear0_offset = CNP_PMC_HOST_PPFEAR0A, >>> + .ppfear_buckets = ICL_PPFEAR_NUM_ENTRIES, >>> + .pm_cfg_offset = CNP_PMC_PM_CFG_OFFSET, >>> + .pm_read_disable_bit = CNP_PMC_READ_DISABLE_BIT, >>> + .ltr_ignore_max = ICL_NUM_IP_IGN_ALLOWED, >>> +}; >>> + >>> static inline u8 pmc_core_reg_read_byte(struct pmc_dev *pmcdev, int offset) >>> { >>> return readb(pmcdev->regbase + offset); >>> @@ -740,6 +772,7 @@ static const struct x86_cpu_id intel_pmc_core_ids[] = { >>> INTEL_CPU_FAM6(KABYLAKE_MOBILE, spt_reg_map), >>> INTEL_CPU_FAM6(KABYLAKE_DESKTOP, spt_reg_map), >>> INTEL_CPU_FAM6(CANNONLAKE_MOBILE, cnp_reg_map), >>> + INTEL_CPU_FAM6(ICELAKE_MOBILE, icl_reg_map), >>> {} >>> }; >>> >>> diff --git a/drivers/platform/x86/intel_pmc_core.h b/drivers/platform/x86/intel_pmc_core.h >>> index 0680ca397b57..78dd4229489d 100644 >>> --- a/drivers/platform/x86/intel_pmc_core.h >>> +++ b/drivers/platform/x86/intel_pmc_core.h >>> @@ -178,6 +178,10 @@ enum ppfear_regs { >>> #define LTR_REQ_SNOOP BIT(15) >>> #define LTR_REQ_NONSNOOP BIT(31) >>> >>> +#define ICL_PPFEAR_NUM_ENTRIES 9 >>> +#define ICL_NUM_IP_IGN_ALLOWED 20 >>> +#define ICL_PMC_LTR_WIGIG 0x1BFC >>> + >>> struct pmc_bit_map { >>> const char *name; >>> u32 bit_mask; >>> -- >>> 2.17.1 >>> >> -- > >