Received: by 2002:a25:f815:0:0:0:0:0 with SMTP id u21csp2282227ybd; Thu, 27 Jun 2019 09:43:16 -0700 (PDT) X-Google-Smtp-Source: APXvYqxdNviDxszsWH5enEtYd5EqsVoBjecBLmxFg9sU0DT00W6s3MOGnw348rIdZisxbJ7HbmGe X-Received: by 2002:a17:90a:2163:: with SMTP id a90mr6829038pje.3.1561653796285; Thu, 27 Jun 2019 09:43:16 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1561653796; cv=none; d=google.com; s=arc-20160816; b=gsgK2iM0jClOnrFwkqpnnCWqTbvmyc4apB7QSSJ/+LmDyGeaD/PVG83YTK2L/cIiOx VMPE3cgiT5WbrUuYYCPk1mLB5E84uy7sDLyrAQSGURUGzs+s3P100z2xs/mxVUi6aMpg 3RufsEnfRK5z5IovK7kltIBgg4Fd+NTt3vGEkTs2gSYsSY5JDCuZ4yeVBiWOdpvsh3N5 JmbP6UdoWooACuylT/LEyN6h/m/2s7Q46F5ivxCwJ1lTp2LXWPtfyIrJwSmNZOz5TmcM ortDXlenK4WOoYHPf75lMkrunnCC0vLs5Qu57o/u0xdj+gZWZsvPQuZ9U2yeW3UOcSBk aJEg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject; bh=Qj7+Wn1SlUgFXSlGj69vU+g8jTJk3fSfdzdpkOGD/7k=; b=Sljv0WE1SEop3P725GKGXBVtff55nXFpa3wZ7mor40KWDWe+ciMULkzAKvX0M4f1uw oHPjfqviZdULKqYpCxnkn1nW4QiJ0v0Ix+pxO4zIqhqhCahdTlwCuTVNzoQ4ea/Qk5sG ywo3lcIMCPxTou+Oik4Mt4eBiZFvH0K6L8kM7BDE2k5IpEbNK4COrK3br0A12AbVdrIz gc99tdf0OvztGJh5AIHd2TFs5FExZPRLVQfZX6quBt9EsiQRf9CLgCAgIu4f59xhNEsp iuzgYQ0sihj2FUU+CNDd1KPeOOfkf+HzbkQeDLGvvzO3MaNBEV3gEx2W9D9hxp7fVwJq ktpA== 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=collabora.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id x22si2973281pln.150.2019.06.27.09.43.00; Thu, 27 Jun 2019 09:43:16 -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; 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=collabora.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726520AbfF0Qmu (ORCPT + 99 others); Thu, 27 Jun 2019 12:42:50 -0400 Received: from bhuna.collabora.co.uk ([46.235.227.227]:47562 "EHLO bhuna.collabora.co.uk" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726426AbfF0Qmu (ORCPT ); Thu, 27 Jun 2019 12:42:50 -0400 Received: from [127.0.0.1] (localhost [127.0.0.1]) (Authenticated sender: eballetbo) with ESMTPSA id 12000286389 Subject: Re: [PATCH v2] platform/chrome: Expose resume result via debugfs To: Evan Green Cc: Lee Jones , Ravi Chandra Sadineni , Rajat Jain , Guenter Roeck , LKML , Benson Leung , Tim Wawrzynczak References: <20190617215234.260982-1-evgreen@chromium.org> <20190625130515.GJ21119@dell> From: Enric Balletbo i Serra Message-ID: <1be4bbbe-783c-ea91-8283-624ee66be00c@collabora.com> Date: Thu, 27 Jun 2019 18:42:45 +0200 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:60.0) Gecko/20100101 Thunderbird/60.7.1 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8 Content-Language: en-GB Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Evan, On 27/6/19 18:07, Evan Green wrote: > On Wed, Jun 26, 2019 at 1:55 PM Enric Balletbo i Serra > wrote: >> >> Hi Evan, >> >> Two few comments and I think I'm fine with it. >> >> On 25/6/19 15:05, Lee Jones wrote: >>> On Mon, 17 Jun 2019, Evan Green wrote: >>> >>>> For ECs that support it, the EC returns the number of slp_s0 >>>> transitions and whether or not there was a timeout in the resume >>>> response. Expose the last resume result to usermode via debugfs so >>>> that usermode can detect and report S0ix timeouts. >>>> >>>> Signed-off-by: Evan Green >>> >>> This still needs a platform/chrome Ack. >>> >>>> --- >>>> >>>> Changes in v2: >>>> - Moved from sysfs to debugfs (Enric) >>>> - Added documentation (Enric) >>>> >>>> >>>> --- >>>> Documentation/ABI/testing/debugfs-cros-ec | 22 ++++++++++++++++++++++ >>>> drivers/mfd/cros_ec.c | 6 +++++- >>>> drivers/platform/chrome/cros_ec_debugfs.c | 7 +++++++ >>>> include/linux/mfd/cros_ec.h | 1 + >>>> 4 files changed, 35 insertions(+), 1 deletion(-) >>>> >>>> diff --git a/Documentation/ABI/testing/debugfs-cros-ec b/Documentation/ABI/testing/debugfs-cros-ec >>>> index 573a82d23c89..008b31422079 100644 >>>> --- a/Documentation/ABI/testing/debugfs-cros-ec >>>> +++ b/Documentation/ABI/testing/debugfs-cros-ec >>>> @@ -32,3 +32,25 @@ Description: >>>> is used for synchronizing the AP host time with the EC >>>> log. An error is returned if the command is not supported >>>> by the EC or there is a communication problem. >>>> + >>>> +What: /sys/kernel/debug/cros_ec/last_resume_result >> >> Thinking about it, as other the other interfaces, I'd do >> >> s/cros_ec// >> >> I know that for now only cros_ec supports that, but we don't know what will >> happen in the future, specially now that the number of cros devices is incrementing. > > See my comment below, I suppose the fate of these two comments are > tied together. > >> >>>> +Date: June 2019 >>>> +KernelVersion: 5.3 >>>> +Description: >>>> + Some ECs have a feature where they will track transitions to >>>> + the (Intel) processor's SLP_S0 line, in order to detect cases >>>> + where a system failed to go into S0ix. When the system resumes, >>>> + an EC with this feature will return a summary of SLP_S0 >>>> + transitions that occurred. The last_resume_result file returns >>>> + the most recent response from the AP's resume message to the EC. >>>> + >>>> + The bottom 31 bits contain a count of the number of SLP_S0 >>>> + transitions that occurred since the suspend message was >>>> + received. Bit 31 is set if the EC attempted to wake the >>>> + system due to a timeout when watching for SLP_S0 transitions. >>>> + Callers can use this to detect a wake from the EC due to >>>> + S0ix timeouts. The result will be zero if no suspend >>>> + transitions have been attempted, or the EC does not support >>>> + this feature. >>>> + >>>> + Output will be in the format: "0x%08x\n". >>>> diff --git a/drivers/mfd/cros_ec.c b/drivers/mfd/cros_ec.c >>>> index 5d5c41ac3845..2a9ac5213893 100644 >>>> --- a/drivers/mfd/cros_ec.c >>>> +++ b/drivers/mfd/cros_ec.c >>>> @@ -102,12 +102,16 @@ static int cros_ec_sleep_event(struct cros_ec_device *ec_dev, u8 sleep_event) >>>> >>>> /* For now, report failure to transition to S0ix with a warning. */ >>>> if (ret >= 0 && ec_dev->host_sleep_v1 && >>>> - (sleep_event == HOST_SLEEP_EVENT_S0IX_RESUME)) >>>> + (sleep_event == HOST_SLEEP_EVENT_S0IX_RESUME)) { >>>> + ec_dev->last_resume_result = >>>> + buf.u.resp1.resume_response.sleep_transitions; >>>> + >>>> WARN_ONCE(buf.u.resp1.resume_response.sleep_transitions & >>>> EC_HOST_RESUME_SLEEP_TIMEOUT, >>>> "EC detected sleep transition timeout. Total slp_s0 transitions: %d", >>>> buf.u.resp1.resume_response.sleep_transitions & >>>> EC_HOST_RESUME_SLEEP_TRANSITIONS_MASK); >>>> + } >>>> >>>> return ret; >>>> } >>>> diff --git a/drivers/platform/chrome/cros_ec_debugfs.c b/drivers/platform/chrome/cros_ec_debugfs.c >>>> index cd3fb9c22a44..663bebf699bf 100644 >>>> --- a/drivers/platform/chrome/cros_ec_debugfs.c >>>> +++ b/drivers/platform/chrome/cros_ec_debugfs.c >>>> @@ -447,6 +447,13 @@ static int cros_ec_debugfs_probe(struct platform_device *pd) >>>> debugfs_create_file("uptime", 0444, debug_info->dir, debug_info, >>>> &cros_ec_uptime_fops); >>>> >>>> + if (!strcmp(ec->class_dev.kobj.name, CROS_EC_DEV_NAME)) { >> >> For debugfs I don't care having the file exposed even is not supported, anyway >> there are some CROS_EC_DEV_NAME that won't support it, so just make this simple >> and create the file always. > > Aw, really? This file is very specific to system suspend/resume. My > original patch had it everywhere, but I was finding it very ugly that > this was showing up on things like the fingerprint device. I can > change it if you think it's better to have it everywhere, but it also > seems like an easy change to make in the future if this file is for > some reason needed on other EC types. > I'd think different if it was a sysfs property but it's a debugfs. Right now we have: #define CROS_EC_DEV_NAME "cros_ec" #define CROS_EC_DEV_FP_NAME "cros_fp" #define CROS_EC_DEV_ISH_NAME "cros_ish" #define CROS_EC_DEV_PD_NAME "cros_pd" #define CROS_EC_DEV_SCP_NAME "cros_scp" #define CROS_EC_DEV_TP_NAME "cros_tp" Is really the named cros_ec the only that has this feature? What about cros_scp (is not supposed to run the same base code as cros_ec)? And cros_ish ? And all the named cros_ec devices have this feature? Maybe is supported by Nocturne but not Veyron? Wouldn't be exposed also on those cros_ec that doesn't support it? And don't have the answer to all these questions, hence my concerns. As per your documentation + ... The result will be zero if no suspend + transitions have been attempted, or the EC does not support + this feature. I can accept if _all_ the CROS_EC_DEV_NAMEs and _only_ the CROS_EC_DEV_NAME supports it, is that the case? But if you are anyway exposing this on CROS_EC_DEV_NAMEs that doesn't support it why not just expose to all and skip a future bunch of code to filter, it is clear what a 0 means and at the end it's just a debugfs file. ~ Enric > -Evan >