Received: by 2002:ac0:a582:0:0:0:0:0 with SMTP id m2-v6csp3101700imm; Fri, 19 Oct 2018 05:15:10 -0700 (PDT) X-Google-Smtp-Source: ACcGV62dZIOfyybf0sl2YP0pAzd/IgtI4NNeZM49dUMcniI/R0xPq8qtzZDu5EsAf8nHNt9nJTxQ X-Received: by 2002:a63:7f0e:: with SMTP id a14-v6mr32364796pgd.296.1539951310479; Fri, 19 Oct 2018 05:15:10 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1539951310; cv=none; d=google.com; s=arc-20160816; b=H8QHpSI0ytLUdOThQKh3jprGshRJ0JKPcBnuv1R79EI1ikVmdXyEqwQcrW8K5wo9Au W0Io1ey3M0QNiEeD4pGAG9uALYguP+jJWyuU1dbubtndYlhO0r4OLIhPTEtc01/9/XJ9 qEo1qT1uzgyfiJIkUh3byYa+JHKdjbIzbSu6tGoIOh7r2Vpk+42efMyw/4cGPlMYoAlj HfaRV3+r35QdJbvZ54TAObBDsJcWLQtBtF6QZFvIndlNc7RoJ439kx9f/fSNMkGJGhbT 7KWgIK+mRKgT/QSgUZdkZJBbsXC6y7CgMtWc7CWrFYkJnhJLbW40FvnTzZDClR2EQFae hO7Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:dkim-signature; bh=SodfdrROM8o31w3jksw/of120WMoWeMnoyI8XZvFvpM=; b=azYi01tQcbNW803tFTnC3UW//swCesFJVot6dS1nP1viVEBQF8hNj6VCUuSIxPxaDx XGUzxJLA/MXXdKt3ZvWjqHw1ibFLbjnEvrZq9hYGRt6V89NgPrqZOZYVADF8pTpiNagv BEkVtIy6UnYykmmYBRuBq5jzWa/va1ngGnKiwhvebCPxc7i03UkDQBjwNkP5eiHAa08Q g1EiqbU1i4tS43Ck81wcXjX1ht1z7rSsqm14YL5Z0l4KSNffIZI4QDTl2l2w2b07G8Dr E2XrYBDTAczumSv4QiohqT4oD2MBy5Et4q+3LDOdrwCKUI2CaeAtB3rfkZ3PuEXeLnrf nkDw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=t3tY+Hhu; 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=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id 101-v6si26286586ple.326.2018.10.19.05.14.54; Fri, 19 Oct 2018 05:15:10 -0700 (PDT) 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; dkim=pass header.i=@gmail.com header.s=20161025 header.b=t3tY+Hhu; 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=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727567AbeJSUSx (ORCPT + 99 others); Fri, 19 Oct 2018 16:18:53 -0400 Received: from mail-qt1-f195.google.com ([209.85.160.195]:34150 "EHLO mail-qt1-f195.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727282AbeJSUSw (ORCPT ); Fri, 19 Oct 2018 16:18:52 -0400 Received: by mail-qt1-f195.google.com with SMTP id o17-v6so38015001qtr.1; Fri, 19 Oct 2018 05:13:01 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=SodfdrROM8o31w3jksw/of120WMoWeMnoyI8XZvFvpM=; b=t3tY+Hhu5JxN3Hkso9wchc/gMgEMhp3rqyqA0oCr794Jr+w0XzWv5s970mMrqircbQ wsv2m/SJeOkJyqjKlXuT5c2+xqAg1UML+hPd+GmiBP/8552NwpAEzltOXHbgQjTrPA1G fCaaqqVZ8uKUid3fLxJCDlDFV+rIk1YbqFeWHI+TX5jSnF8yMBgo/gxYLM3coH6FKXn1 fMGNDJBNdO/FkZKByytPQ1y2NFAWTqVbPFxgB2gN7uR2Y+GqhOlPUP8B/C/1cROzBTT5 T4WDaGf0Jc9HhwS2Ly3tOn2eLaa3lzH+5orFSjKKRDLMttENa03pNNpCkOhI3IWQg301 ibHQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=SodfdrROM8o31w3jksw/of120WMoWeMnoyI8XZvFvpM=; b=sFWFo45kCXlJoyqKoHt0SlML3JlYtJ+lAGixImiBYgihCIYC2YX8zw1BC5ZHF6Tqbp Iqx/+/zXRKux9MszgJPl8brPXAZjJtonEP8ajiCAUysgclWQ9yo7o2qNKMC2FZnFp7rv pOtH22Y5Uz60ETNrdoP9ea1Sia2NtowhEIfFssUyUubN24gf1aOT4TW7lXrX10C4gVfF wjoWEkZ1gAbLoffn84rtXbt+Xl4mTH2S69UTY00HkeK9eqX1+yL0TcwEkc68l/biWtaq 0EAOSOBIfrY0yq1bE9RAsG18A354gm8P7uADiHTIJcZkpyUg+FLaQk9c/kHNTtjE/MEd 11Kw== X-Gm-Message-State: ABuFfohCAL+N9O21yq5082xjXQoFs3yTM7LKNcpPCj6BFGqooIbYHfMi JNnBn3OsLSXmu8nFY8cRJZLivOT7ngfp+tg0ftDTxLyJ X-Received: by 2002:a0c:9e6e:: with SMTP id z46mr27436032qve.180.1539951181117; Fri, 19 Oct 2018 05:13:01 -0700 (PDT) MIME-Version: 1.0 References: <20181006065113.669-1-rajneesh.bhardwaj@linux.intel.com> In-Reply-To: <20181006065113.669-1-rajneesh.bhardwaj@linux.intel.com> From: Andy Shevchenko Date: Fri, 19 Oct 2018 15:12:49 +0300 Message-ID: Subject: Re: [PATCH v2 1/4] platform/x86: intel_pmc_core: Show Latency Tolerance info To: rajneesh.bhardwaj@linux.intel.com Cc: Platform Driver , Darren Hart , Andy Shevchenko , Linux Kernel Mailing List , Rajneesh Bhardwaj Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Sat, Oct 6, 2018 at 9:54 AM Rajneesh Bhardwaj wrote: > > This adds support to show the Latency Tolerance Reporting for the IPs on > the PCH as reported by the PMC. The format shown here is raw LTR data > payload that can further be decoded as per the PCI specification. > > This also fixes some minor alignment issues in the header file by > removing spaces and converting to tabs at some places. > I have pushed slightly modified variant of this patch to my review and testing queue. Though this series needs a bit more work. I see inconsistency now with the output with the rest of nodes there. I don't care much, though some can be addressed for no regression. For example, index printing. Please, remove it. I completely forgot about userspace powerful tools. At least two very old and nice can enumerate lines for you. Obviously the index printing is redundant. > Signed-off-by: Rajneesh Bhardwaj > --- > Changes in v2: > * Removed IP # from map and displaying IP # while printing. > * Other style fixes as per Andy's suggestion. > > drivers/platform/x86/intel_pmc_core.c | 73 +++++++++++++++++++++++++++ > drivers/platform/x86/intel_pmc_core.h | 56 +++++++++++++++++--- > 2 files changed, 122 insertions(+), 7 deletions(-) > > diff --git a/drivers/platform/x86/intel_pmc_core.c b/drivers/platform/x86/intel_pmc_core.c > index 2d272a3e0176..217a822a8da1 100644 > --- a/drivers/platform/x86/intel_pmc_core.c > +++ b/drivers/platform/x86/intel_pmc_core.c > @@ -110,10 +110,37 @@ static const struct pmc_bit_map spt_pfear_map[] = { > {}, > }; > > +static const struct pmc_bit_map spt_ltr_show_map[] = { > + {"LTR_SOUTHPORT_A", SPT_PMC_LTR_SPA}, > + {"LTR_SOUTHPORT_B", SPT_PMC_LTR_SPB}, > + {"LTR_SATA", SPT_PMC_LTR_SATA}, > + {"LTR_GIGABIT_ETHERNET", SPT_PMC_LTR_GBE}, > + {"LTR_XHCI", SPT_PMC_LTR_XHCI}, > + /* IP 5 is reserved */ > + {"LTR_ME", SPT_PMC_LTR_ME}, > + /* EVA is Enterprise Value Add, doesn't really exist on PCH */ > + {"LTR_EVA", SPT_PMC_LTR_EVA}, > + {"LTR_SOUTHPORT_C", SPT_PMC_LTR_SPC}, > + {"LTR_HD_AUDIO", SPT_PMC_LTR_AZ}, > + /* IP 10 is reserved */ > + {"LTR_LPSS", SPT_PMC_LTR_LPSS}, > + {"LTR_SOUTHPORT_D", SPT_PMC_LTR_SPD}, > + {"LTR_SOUTHPORT_E", SPT_PMC_LTR_SPE}, > + {"LTR_CAMERA", SPT_PMC_LTR_CAM}, > + {"LTR_ESPI", SPT_PMC_LTR_ESPI}, > + {"LTR_SCC", SPT_PMC_LTR_SCC}, > + {"LTR_ISH", SPT_PMC_LTR_ISH}, > + /* Below two cannot be used for LTR_IGNORE */ > + {"LTR_CURRENT_PLATFORM", SPT_PMC_LTR_CUR_PLT}, > + {"LTR_AGGREGATED_SYSTEM", SPT_PMC_LTR_CUR_ASLT}, > + {} > +}; > + > static const struct pmc_reg_map spt_reg_map = { > .pfear_sts = spt_pfear_map, > .mphy_sts = spt_mphy_map, > .pll_sts = spt_pll_map, > + .ltr_show_sts = spt_ltr_show_map, > .slp_s0_offset = SPT_PMC_SLP_S0_RES_COUNTER_OFFSET, > .ltr_ignore_offset = SPT_PMC_LTR_IGNORE_OFFSET, > .regmap_length = SPT_PMC_MMIO_REG_LEN, > @@ -252,10 +279,39 @@ static const struct pmc_bit_map *cnp_slps0_dbg_maps[] = { > NULL, > }; > > +static const struct pmc_bit_map cnp_ltr_show_map[] = { > + {"LTR_SOUTHPORT_A", CNP_PMC_LTR_SPA}, > + {"LTR_SOUTHPORT_B", CNP_PMC_LTR_SPB}, > + {"LTR_SATA", CNP_PMC_LTR_SATA}, > + {"LTR_GIGABIT_ETHERNET", CNP_PMC_LTR_GBE}, > + {"LTR_XHCI", CNP_PMC_LTR_XHCI}, > + /* IP 5 is reserved */ > + {"LTR_ME", CNP_PMC_LTR_ME}, > + /* EVA is Enterprise Value Add, doesn't really exist on PCH */ > + {"LTR_EVA", CNP_PMC_LTR_EVA}, > + {"LTR_SOUTHPORT_C", CNP_PMC_LTR_SPC}, > + {"LTR_HD_AUDIO", CNP_PMC_LTR_AZ}, > + {"LTR_CNV", CNP_PMC_LTR_CNV}, > + {"LTR_LPSS", CNP_PMC_LTR_LPSS}, > + {"LTR_SOUTHPORT_D", CNP_PMC_LTR_SPD}, > + {"LTR_SOUTHPORT_E", CNP_PMC_LTR_SPE}, > + {"LTR_CAMERA", CNP_PMC_LTR_CAM}, > + {"LTR_ESPI", CNP_PMC_LTR_ESPI}, > + {"LTR_SCC", CNP_PMC_LTR_SCC}, > + {"LTR_ISH", CNP_PMC_LTR_ISH}, > + {"LTR_UFSX2", CNP_PMC_LTR_UFSX2}, > + {"LTR_EMMC", CNP_PMC_LTR_EMMC}, > + /* Below two cannot be used for LTR_IGNORE */ > + {"LTR_CURRENT_PLATFORM", CNP_PMC_LTR_CUR_PLT}, > + {"LTR_AGGREGATED_SYSTEM", CNP_PMC_LTR_CUR_ASLT}, > + {} > +}; > + > static const struct pmc_reg_map cnp_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, > @@ -592,6 +648,21 @@ static int pmc_core_slps0_dbg_show(struct seq_file *s, void *unused) > } > DEFINE_SHOW_ATTRIBUTE(pmc_core_slps0_dbg); > > +static int pmc_core_ltr_show(struct seq_file *s, void *unused) > +{ > + struct pmc_dev *pmcdev = s->private; > + const struct pmc_bit_map *map = pmcdev->map->ltr_show_sts; > + int index; > + > + for (index = 0; map[index].name ; index++) { > + seq_printf(s, "IP %-2d :%-32s\tRAW LTR: 0x%x\n", index, > + map[index].name, > + pmc_core_reg_read(pmcdev, map[index].bit_mask)); > + } > + return 0; > +} > +DEFINE_SHOW_ATTRIBUTE(pmc_core_ltr); > + > static void pmc_core_dbgfs_unregister(struct pmc_dev *pmcdev) > { > debugfs_remove_recursive(pmcdev->dbgfs_dir); > @@ -616,6 +687,8 @@ static int pmc_core_dbgfs_register(struct pmc_dev *pmcdev) > debugfs_create_file("ltr_ignore", 0644, dir, pmcdev, > &pmc_core_ltr_ignore_ops); > > + debugfs_create_file("ltr_show", 0644, dir, pmcdev, &pmc_core_ltr_fops); > + > if (pmcdev->map->pll_sts) > debugfs_create_file("pll_status", 0444, dir, pmcdev, > &pmc_core_pll_ops); > diff --git a/drivers/platform/x86/intel_pmc_core.h b/drivers/platform/x86/intel_pmc_core.h > index 93a7e99e1f8b..7a00436e337d 100644 > --- a/drivers/platform/x86/intel_pmc_core.h > +++ b/drivers/platform/x86/intel_pmc_core.h > @@ -46,6 +46,25 @@ > #define NUM_RETRIES 100 > #define NUM_IP_IGN_ALLOWED 17 > > +#define SPT_PMC_LTR_CUR_PLT 0x350 > +#define SPT_PMC_LTR_CUR_ASLT 0x354 > +#define SPT_PMC_LTR_SPA 0x360 > +#define SPT_PMC_LTR_SPB 0x364 > +#define SPT_PMC_LTR_SATA 0x368 > +#define SPT_PMC_LTR_GBE 0x36C > +#define SPT_PMC_LTR_XHCI 0x370 > +#define SPT_PMC_LTR_ME 0x378 > +#define SPT_PMC_LTR_EVA 0x37C > +#define SPT_PMC_LTR_SPC 0x380 > +#define SPT_PMC_LTR_AZ 0x384 > +#define SPT_PMC_LTR_LPSS 0x38C > +#define SPT_PMC_LTR_CAM 0x390 > +#define SPT_PMC_LTR_SPD 0x394 > +#define SPT_PMC_LTR_SPE 0x398 > +#define SPT_PMC_LTR_ESPI 0x39C > +#define SPT_PMC_LTR_SCC 0x3A0 > +#define SPT_PMC_LTR_ISH 0x3A4 > + > /* Sunrise Point: PGD PFET Enable Ack Status Registers */ > enum ppfear_regs { > SPT_PMC_XRAM_PPFEAR0A = 0x590, > @@ -124,17 +143,38 @@ enum ppfear_regs { > #define SPT_PMC_BIT_MPHY_CMN_LANE3 BIT(3) > > /* Cannonlake Power Management Controller register offsets */ > -#define CNP_PMC_SLP_S0_RES_COUNTER_OFFSET 0x193C > -#define CNP_PMC_LTR_IGNORE_OFFSET 0x1B0C > -#define CNP_PMC_PM_CFG_OFFSET 0x1818 > +#define CNP_PMC_SLP_S0_RES_COUNTER_OFFSET 0x193C > +#define CNP_PMC_LTR_IGNORE_OFFSET 0x1B0C > +#define CNP_PMC_PM_CFG_OFFSET 0x1818 > #define CNP_PMC_SLPS0_DBG_OFFSET 0x10B4 > /* Cannonlake: PGD PFET Enable Ack Status Register(s) start */ > -#define CNP_PMC_HOST_PPFEAR0A 0x1D90 > +#define CNP_PMC_HOST_PPFEAR0A 0x1D90 > > -#define CNP_PMC_MMIO_REG_LEN 0x2000 > -#define CNP_PPFEAR_NUM_ENTRIES 8 > -#define CNP_PMC_READ_DISABLE_BIT 22 > +#define CNP_PMC_MMIO_REG_LEN 0x2000 > +#define CNP_PPFEAR_NUM_ENTRIES 8 > +#define CNP_PMC_READ_DISABLE_BIT 22 > #define CNP_PMC_LATCH_SLPS0_EVENTS BIT(31) > +#define CNP_PMC_LTR_CUR_PLT 0x1B50 > +#define CNP_PMC_LTR_CUR_ASLT 0x1B54 > +#define CNP_PMC_LTR_SPA 0x1B60 > +#define CNP_PMC_LTR_SPB 0x1B64 > +#define CNP_PMC_LTR_SATA 0x1B68 > +#define CNP_PMC_LTR_GBE 0x1B6C > +#define CNP_PMC_LTR_XHCI 0x1B70 > +#define CNP_PMC_LTR_ME 0x1B78 > +#define CNP_PMC_LTR_EVA 0x1B7C > +#define CNP_PMC_LTR_SPC 0x1B80 > +#define CNP_PMC_LTR_AZ 0x1B84 > +#define CNP_PMC_LTR_LPSS 0x1B8C > +#define CNP_PMC_LTR_CAM 0x1B90 > +#define CNP_PMC_LTR_SPD 0x1B94 > +#define CNP_PMC_LTR_SPE 0x1B98 > +#define CNP_PMC_LTR_ESPI 0x1B9C > +#define CNP_PMC_LTR_SCC 0x1BA0 > +#define CNP_PMC_LTR_ISH 0x1BA4 > +#define CNP_PMC_LTR_CNV 0x1BF0 > +#define CNP_PMC_LTR_EMMC 0x1BF4 > +#define CNP_PMC_LTR_UFSX2 0x1BF8 > > struct pmc_bit_map { > const char *name; > @@ -148,6 +188,7 @@ struct pmc_bit_map { > * @mphy_sts: Maps name of MPHY lane to MPHY status lane status bit > * @pll_sts: Maps name of PLL to corresponding bit status > * @slps0_dbg_maps: Array of SLP_S0_DBG* registers containing debug info > + * @ltr_show_sts: Maps PCH IP Names to their MMIO register offsets > * @slp_s0_offset: PWRMBASE offset to read SLP_S0 residency > * @ltr_ignore_offset: PWRMBASE offset to read/write LTR ignore bit > * @regmap_length: Length of memory to map from PWRMBASE address to access > @@ -166,6 +207,7 @@ struct pmc_reg_map { > const struct pmc_bit_map *mphy_sts; > const struct pmc_bit_map *pll_sts; > const struct pmc_bit_map **slps0_dbg_maps; > + const struct pmc_bit_map *ltr_show_sts; > const u32 slp_s0_offset; > const u32 ltr_ignore_offset; > const int regmap_length; > -- > 2.17.1 > -- With Best Regards, Andy Shevchenko