Received: by 2002:a05:6a10:8c0a:0:0:0:0 with SMTP id go10csp1566660pxb; Mon, 8 Mar 2021 00:16:27 -0800 (PST) X-Google-Smtp-Source: ABdhPJyETc9jflp69Dvj8MvNKvHPgLOScws7F6w5Fa4nErOEuGVzIu/0uewUHI8/BGD/vY6KRES7 X-Received: by 2002:aa7:cd54:: with SMTP id v20mr21228401edw.80.1615191386924; Mon, 08 Mar 2021 00:16:26 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1615191386; cv=none; d=google.com; s=arc-20160816; b=tfgJj3piqrFq5Y1AcBV9lqUKSWEmX9t2jWCBqdVzE6DYEGwdfCIysGWiv+MCRL5dA5 Mp8h17Bh03Awzv6Mu4KF2MSQY9Qz0dyEhzMhiy/X1GVlnZTV/CxdxJj3D6L6VIrqxdNr 3sM6wGSQL3nn9GyWOj4jWtzImRK5tvbe0V6+YcLf8IfRVeIS1JlHlwVT1EzNShFUORSt VuLGZxeGM4b4VPeopRZ4Q5T88j0DbtMmgj2VPbYydmXmLHh1Pm6IliWG0TVbDVLMbTPh GNKwN3x9QBog96tik+90TAcK/MOYbRWLs5FT+KGa0r9gPcQpWe7E0s1PPO0aJapRhCB9 81Kw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:organization:references:in-reply-to:date:cc:to:reply-to :from:subject:message-id:ironport-sdr:ironport-sdr; bh=GbwjnK+ZWa+PJ+oPTVh3rz/YwI4SL5cdV5ihN+GT/2g=; b=GCQfdudHPVD5MuKqFh0idE8ELIxXkech1ZlhsVOePS4V1jHo5C+2Ph/1QDa6r383K4 m0lNWWaoPx5dgr3I31cV/47Cm85ds/G5kzxkvKJbgOV9yTfNB6v2e36TwkfbK3IGM4rO jXJAHDl1rdWT/WBiwFZs0iKDm8KhAknFZbt/tSYSXo/O7TFV7m2L5nTYZG4OZ6yTkDNN V2CK1Dkh3Wpxd+X9gKyYAFYb6favd+bbOVt5grUGO5oy0ujUslVgczIz0pwYbBYbODXL Rl4+uY3OhpTVZ3BtwNgia8/qGKwhFNNXeXBfqVxNoZC1hor/4jBz/J3S1x4QTV21lCld Ppdw== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 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. [23.128.96.18]) by mx.google.com with ESMTP id l3si6464648edk.141.2021.03.08.00.16.04; Mon, 08 Mar 2021 00:16:26 -0800 (PST) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 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 S232171AbhCGTJj (ORCPT + 99 others); Sun, 7 Mar 2021 14:09:39 -0500 Received: from mga03.intel.com ([134.134.136.65]:25558 "EHLO mga03.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S232176AbhCGTJP (ORCPT ); Sun, 7 Mar 2021 14:09:15 -0500 IronPort-SDR: 3dOA4lGIbUSz4iwnOFl+tenkHl5k3EU6MqfOVrsYyC+D1402Yf2fJDmIieEw2Ce+7wYAwTkjbp udwCwxtVv/DQ== X-IronPort-AV: E=McAfee;i="6000,8403,9916"; a="187977355" X-IronPort-AV: E=Sophos;i="5.81,230,1610438400"; d="scan'208";a="187977355" Received: from fmsmga005.fm.intel.com ([10.253.24.32]) by orsmga103.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 07 Mar 2021 11:09:14 -0800 IronPort-SDR: k4u/SFLJtT4v2Y95kgtSD8GHq87WnACa/lCo/6HdKs5XWe1Fru1ms6Do1R5S+gb2pdJ6KBmsji vMc2Y5nlDSRw== X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.81,230,1610438400"; d="scan'208";a="601882081" Received: from linux.intel.com ([10.54.29.200]) by fmsmga005.fm.intel.com with ESMTP; 07 Mar 2021 11:09:14 -0800 Received: from debox1-desk1.jf.intel.com (debox1-desk1.jf.intel.com [10.54.75.57]) by linux.intel.com (Postfix) with ESMTP id 8498758080F; Sun, 7 Mar 2021 11:09:14 -0800 (PST) Message-ID: <35bca0efb7d485f66e3cacdac113ab9e42058846.camel@linux.intel.com> Subject: Re: [PATCH] platform/x86: intel_pmc: Ignore GBE LTR on Tiger Lake platforms From: "David E. Box" Reply-To: david.e.box@linux.intel.com To: "Neftin, Sasha" , irenic.rajneesh@gmail.com, hdegoede@redhat.com, mgross@linux.intel.com Cc: platform-driver-x86@vger.kernel.org, linux-kernel@vger.kernel.org, intel-wired-lan@lists.osuosl.org Date: Sun, 07 Mar 2021 11:09:14 -0800 In-Reply-To: <113b08b2-ead1-7f4c-1b09-4f3572d6134f@intel.com> References: <20210305190608.1834164-1-david.e.box@linux.intel.com> <113b08b2-ead1-7f4c-1b09-4f3572d6134f@intel.com> Organization: David E. Box Content-Type: text/plain; charset="UTF-8" User-Agent: Evolution 3.38.4 (3.38.4-1.fc33) MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Sasha, On Sun, 2021-03-07 at 10:39 +0200, Neftin, Sasha wrote: > On 3/5/2021 21:06, David E. Box wrote: > > Due to a HW limitation, the Latency Tolerance Reporting (LTR) value > > programmed in the Tiger Lake GBE controller is not large enough to > > allow > > the platform to enter Package C10, which in turn prevents the > > platform from > > achieving its low power target during suspend-to-idle.  Ignore the > > GBE LTR > > value on Tiger Lake. LTR ignore functionality is currently > > performed solely > > by a debugfs write call. Split out the LTR code into its own > > function that > > can be called by both the debugfs writer and by this work around. > > > > Signed-off-by: David E. Box > > Reviewed-by: Sasha Neftin > > Cc: intel-wired-lan@lists.osuosl.org > > --- > >   drivers/platform/x86/intel_pmc_core.c | 55 ++++++++++++++++++++-- > > ----- > >   1 file changed, 42 insertions(+), 13 deletions(-) > > > > diff --git a/drivers/platform/x86/intel_pmc_core.c > > b/drivers/platform/x86/intel_pmc_core.c > > index ee2f757515b0..ab31eb646a1a 100644 > > --- a/drivers/platform/x86/intel_pmc_core.c > > +++ b/drivers/platform/x86/intel_pmc_core.c > > @@ -863,34 +863,45 @@ static int pmc_core_pll_show(struct seq_file > > *s, void *unused) > >   } > >   DEFINE_SHOW_ATTRIBUTE(pmc_core_pll); > >   > > -static ssize_t pmc_core_ltr_ignore_write(struct file *file, > > -                                        const char __user > > *userbuf, > > -                                        size_t count, loff_t > > *ppos) > > +static int pmc_core_write_ltr_ignore(u32 value) > >   { > >         struct pmc_dev *pmcdev = &pmc; > >         const struct pmc_reg_map *map = pmcdev->map; > > -       u32 val, buf_size, fd; > > -       int err; > > - > > -       buf_size = count < 64 ? count : 64; > > - > > -       err = kstrtou32_from_user(userbuf, buf_size, 10, &val); > > -       if (err) > > -               return err; > > +       u32 fd; > > +       int err = 0; > >   > >         mutex_lock(&pmcdev->lock); > >   > > -       if (val > map->ltr_ignore_max) { > > +       if (fls(value) > map->ltr_ignore_max) { > >                 err = -EINVAL; > >                 goto out_unlock; > >         } > >   > >         fd = pmc_core_reg_read(pmcdev, map->ltr_ignore_offset); > > -       fd |= (1U << val); > > +       fd |= value; > >         pmc_core_reg_write(pmcdev, map->ltr_ignore_offset, fd); > >   > >   out_unlock: > >         mutex_unlock(&pmcdev->lock); > > + > > +       return err; > > +} > > + > > +static ssize_t pmc_core_ltr_ignore_write(struct file *file, > > +                                        const char __user > > *userbuf, > > +                                        size_t count, loff_t > > *ppos) > > +{ > > +       u32 buf_size, val; > > +       int err; > > + > > +       buf_size = count < 64 ? count : 64; > > + > > +       err = kstrtou32_from_user(userbuf, buf_size, 10, &val); > > +       if (err) > > +               return err; > > + > > +       err = pmc_core_write_ltr_ignore(1U << val); > > + > >         return err == 0 ? count : err; > >   } > >   > > @@ -1189,6 +1200,15 @@ static int quirk_xtal_ignore(const struct > > dmi_system_id *id) > >         return 0; > >   } > >   > > +static int quirk_ltr_ignore(u32 val) > > +{ > > +       int err; > > + > > +       err = pmc_core_write_ltr_ignore(val); > > + > > +       return err; > > +} > > + > >   static const struct dmi_system_id pmc_core_dmi_table[]  = { > >         { > >         .callback = quirk_xtal_ignore, > > @@ -1244,6 +1264,15 @@ static int pmc_core_probe(struct > > platform_device *pdev) > >         pmcdev->pmc_xram_read_bit = pmc_core_check_read_lock_bit(); > >         dmi_check_system(pmc_core_dmi_table); > >   > > +       /* > > +        * On TGL, due to a hardware limitation, the GBE LTR blocks > > PC10 when > > +        * a cable is attached. Tell the PMC to ignore it. > > +        */ > > +       if (pmcdev->map == &tgl_reg_map) { > I would suggest: if (pmcdev->map >= &tgl_reg_map) This will already cover Rocket Lake since it uses Tiger Lake PCH. Those are the newest platforms this driver covers. Otherwise, I don't want to rely on this as the permanent solution. We can evaluate this on a per platform basis while persuing other measures to more properly resolve it. David > > +               dev_dbg(&pdev->dev, "ignoring GBE LTR\n"); > > +               quirk_ltr_ignore(1U << 3); > > +       } > > + > >         pmc_core_dbgfs_register(pmcdev); > >   > >         device_initialized = true; > > >