Received: by 2002:ac0:946b:0:0:0:0:0 with SMTP id j40csp3624182imj; Tue, 12 Feb 2019 01:47:57 -0800 (PST) X-Google-Smtp-Source: AHgI3IYE2odvY2ZWX19ridu7/9wyF1xsr8OI93MCEKiK7xNw/C272WRzhZR08bkgwyuty/IvdBbw X-Received: by 2002:aa7:8281:: with SMTP id s1mr3084248pfm.120.1549964877639; Tue, 12 Feb 2019 01:47:57 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1549964877; cv=none; d=google.com; s=arc-20160816; b=EzBtVtY9teHiIh28Tyr1LaStq8Yyb91oDX+bkfRVTtwXk3P1ocJDf7EwjmGTwSCfAZ 8IqNOn+P58LwNZndJJ5VokNLrQNH5O+jkLtbNfN6vUAuyso65OXPIilqDProKipA7jcF 2CQn9kRB2m72Aohgq8Mxj/mnLUvheoMAeKxWhD4aRkWGDzBdx/9/5K1eSzXm7vaDcEAz //chuJ/RaInkvyxkk5YKXqcPSa7k5yt+6D++8ICP+KjMgU2f2vlrWb8eBTv+z6WjybF/ Fi86/kr9ODxns7Mez+NUIeCd8AEwriRtGcE48fjAlnohRvqLy1Ladvj9IuU9jOxmejcc P1fw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date; bh=fvlQHz/wyRhmZ0T6Rjcdtlgl84YpPkvdlkGtyTQ7ejg=; b=FfGlYqR7P00T449NtGO6VV8CO6c1yd/b9wW7e73R27XuS9t0K1WlMDEIr6+l9AwvNX a4kolqaEhhFeLxs4wBKNC26PoULajPazqPdZjQ3yfqkrfOEMgqdXneULYAlkwqzADAVN MefaXzAeUuR57lgOTYnIb2UnhRL1qBHvQ81uPBqRq/2uEOk1MqwUdZWi9E5ckHOuQXwZ pEZh1T35TfVOg1ah2wvF2vQNyJthCG2cyR51wZavODCupMuDr7L3kur08ZAUl49oeMt6 PtEqwCbuygMjbfhztDj4JKu2t73K3kX9nikwUPliUNZzYbS/OfsUmqsvx4qzFBg5U48U UmxA== 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 d2si12589608pfe.159.2019.02.12.01.47.42; Tue, 12 Feb 2019 01:47:57 -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 S1728243AbfBLJqY (ORCPT + 99 others); Tue, 12 Feb 2019 04:46:24 -0500 Received: from mga18.intel.com ([134.134.136.126]:50240 "EHLO mga18.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728059AbfBLJqY (ORCPT ); Tue, 12 Feb 2019 04:46:24 -0500 X-Amp-Result: UNSCANNABLE X-Amp-File-Uploaded: False Received: from fmsmga002.fm.intel.com ([10.253.24.26]) by orsmga106.jf.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 12 Feb 2019 01:46:23 -0800 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.58,361,1544515200"; d="scan'208";a="142713593" Received: from genxfsim-desktop.iind.intel.com (HELO genxfsim-desktop) ([10.223.26.105]) by fmsmga002.fm.intel.com with ESMTP; 12 Feb 2019 01:46:20 -0800 Date: Tue, 12 Feb 2019 15:13:19 +0530 From: Anshuman Gupta To: Rajneesh Bhardwaj Cc: platform-driver-x86@vger.kernel.org, dvhart@infradead.org, andy@infradead.org, linux-kernel@vger.kernel.org, "David E. Box" , Srinivas Pandruvada Subject: Re: [PATCH 08/10] platform/x86: intel_pmc_core: Add ICL platform support Message-ID: <20190212094318.GA8062@genxfsim-desktop> References: <20190201073234.13280-1-rajneesh.bhardwaj@linux.intel.com> <20190201073234.13280-9-rajneesh.bhardwaj@linux.intel.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20190201073234.13280-9-rajneesh.bhardwaj@linux.intel.com> User-Agent: Mutt/1.5.24 (2015-08-30) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 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: > --- > 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 > --