Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp567441yba; Wed, 3 Apr 2019 14:36:47 -0700 (PDT) X-Google-Smtp-Source: APXvYqyZKFtfWGEMwItG/msn6qAsYv0lWghS5rPlPpiVd7+WBpSk0/lZvVnyF7rGk2o38rRv5Kaf X-Received: by 2002:a63:6903:: with SMTP id e3mr1897015pgc.147.1554327407578; Wed, 03 Apr 2019 14:36:47 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1554327407; cv=none; d=google.com; s=arc-20160816; b=OE4JgbWS00bGuPrsqUjPNmsCOjad8CKCWRf3H04g3Bd2FgU7zAB84EzgXevI4wgjxu +B+e1WAg7qx0YAXE9yqEiK14axgzSomQ2rJSPXCg4XH4BdnoovSUTtrGjZpwNVcrdsba Qb0sViE083VMABBoXuHHmHvCyYQbBL2xb8k3Tu8nSmMNWyp2Z16riQXnrNz1BsfQjaMr u4fGTEQ8SpFPUO5aEaJN6YGnHAbxRMRHRj/Y5dFTYnv2eRndX1TawTqrEWIB8Ir55Wy6 3w73WQNtuW6aV0OSkyfut5aO2w87CkynhbfqoSsztUndMeBwj5OatNC/XZGc2Umy+rDz 2bpg== 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:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature; bh=qSSz+zR7M/ELeq393leY6tHgOOqG0ck7KLOSfSbxL80=; b=jYdete3b4SaWGGrPQ2IIU1EgdEwM+ulh80iMTmv88qQKW6MYEIN03D8CvbPAPYv+ua qhs1Brb23ukXobi1Iney8tfCCiANmkHJpHgd5SOTZ0r6GnXobe27CE1g8la98Miy56ru QZ9uuQ+EYv4fYEjX1nqyvjy/JFdNPxxEKtGlvBqMN5WKUWATL09j224k7X1gQxAo+mzy 0e2gYwIfxkJ06170SPGGJLiggPCFTam+Jot4LrfEjEancKiimjomup+Jv5eUjhrl6DcO RPISv5k81CSyWy7fazFZV3Vynk1XGD37Y4ZFqiZwRbUgJQyFX9txrUETBp0ZV24n0AVX 8VGQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=iUgvrSUL; 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=NONE dis=NONE) header.from=chromium.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id a61si15184604pla.178.2019.04.03.14.36.32; Wed, 03 Apr 2019 14:36:47 -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=@chromium.org header.s=google header.b=iUgvrSUL; 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=NONE dis=NONE) header.from=chromium.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726531AbfDCVen (ORCPT + 99 others); Wed, 3 Apr 2019 17:34:43 -0400 Received: from mail-pf1-f195.google.com ([209.85.210.195]:43630 "EHLO mail-pf1-f195.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727053AbfDCVel (ORCPT ); Wed, 3 Apr 2019 17:34:41 -0400 Received: by mail-pf1-f195.google.com with SMTP id c8so213854pfd.10 for ; Wed, 03 Apr 2019 14:34:40 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=chromium.org; s=google; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=qSSz+zR7M/ELeq393leY6tHgOOqG0ck7KLOSfSbxL80=; b=iUgvrSULpteRl+PHacjTqhPJKe+Mk8h4NiAXxOl6sjJNr8u2bVPU96X69VfCDZ3U8y ushroGtR7VmEYXH0Uo7pyu212GOErfVyrUiLK2B0hzF94lKa3uK2IqaN2HWolbWu893Q uR6uLtkVw9BrXY8QKsEX2kne1hpw+beUCsaJI= X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=qSSz+zR7M/ELeq393leY6tHgOOqG0ck7KLOSfSbxL80=; b=LNNS5tKZw2Jxv8WfMSslM3OB5qO2rwssUQyKPVCyJCALPL8/cAcfPDlPovTeA5MG60 ZwJ2y44er0PSZnHjnqDn9eB+QsiluVq1d6owaV0mxSPtVuW3oUB1WwUE+k4dBxtOT4AK 77dpTioJfNYwI86OhawYIwqFalLorJM3MBeBZpP6GNY9xcpMO2MYzSpHyB9wndadvMT/ A9FTrzZOzE5VcdukO6w/+Fvb2tRISGXKVm/SgxzKxSXA0ikutKFmgpYWcLHFlV2gNeho ptqvVIrnIpGfXYVP4PUo1xg8UkDL8NDiBHgUUJW/Ct0aQtAdv0jnw1xFEoBOViCmDOg6 smUw== X-Gm-Message-State: APjAAAVYfoQEFsyp6pn1DEouoaB02jzv2ccxbxlz2aXjwOpBw+CAuNOB wei40n/oJxSny3v1L560m96aJQ== X-Received: by 2002:a63:6941:: with SMTP id e62mr1874494pgc.99.1554327280038; Wed, 03 Apr 2019 14:34:40 -0700 (PDT) Received: from evgreen2.mtv.corp.google.com ([2620:15c:202:201:ffda:7716:9afc:1301]) by smtp.gmail.com with ESMTPSA id k124sm21796741pgc.65.2019.04.03.14.34.38 (version=TLS1_2 cipher=ECDHE-RSA-AES128-SHA bits=128/128); Wed, 03 Apr 2019 14:34:39 -0700 (PDT) From: Evan Green To: Benson Leung , Enric Balletbo i Serra Cc: Furquan Shaikh , Rajat Jain , Evan Green , linux-kernel@vger.kernel.org, Guenter Roeck , Lee Jones Subject: [PATCH v3 2/2] platform/chrome: Add support for v1 of host sleep event Date: Wed, 3 Apr 2019 14:34:28 -0700 Message-Id: <20190403213428.89920-3-evgreen@chromium.org> X-Mailer: git-send-email 2.20.1 In-Reply-To: <20190403213428.89920-1-evgreen@chromium.org> References: <20190403213428.89920-1-evgreen@chromium.org> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Add support in code for the new forms of the host sleep event. Detects the presence of this version of the command at runtime, and use whichever form the EC supports. At this time, always request the default timeout, and only report the failing response via a WARN_ONCE(). Future versions could accept the sleep parameter from outside the driver, and return the response information to usermode or elsewhere. Signed-off-by: Evan Green --- Changes in v3: - Consolidated boolean logic for host_sleep_v1 (Guenter) Changes in v2: - Removed unnecessary version assignment (Guenter) - Changed WARN to WARN_ONCE (Guenter) - Fixed C code to use anonymous unions - insize is only bigger for resume events. drivers/mfd/cros_ec.c | 39 +++++++++++++++++++++---- drivers/platform/chrome/cros_ec_proto.c | 6 ++++ include/linux/mfd/cros_ec.h | 2 ++ 3 files changed, 42 insertions(+), 5 deletions(-) diff --git a/drivers/mfd/cros_ec.c b/drivers/mfd/cros_ec.c index 6acfe036d522..bd2bcdd4718b 100644 --- a/drivers/mfd/cros_ec.c +++ b/drivers/mfd/cros_ec.c @@ -75,20 +75,49 @@ static irqreturn_t ec_irq_thread(int irq, void *data) static int cros_ec_sleep_event(struct cros_ec_device *ec_dev, u8 sleep_event) { + int ret; struct { struct cros_ec_command msg; - struct ec_params_host_sleep_event req; + union { + struct ec_params_host_sleep_event req0; + struct ec_params_host_sleep_event_v1 req1; + struct ec_response_host_sleep_event_v1 resp1; + } u; } __packed buf; memset(&buf, 0, sizeof(buf)); - buf.req.sleep_event = sleep_event; + if (ec_dev->host_sleep_v1) { + buf.u.req1.sleep_event = sleep_event; + buf.u.req1.suspend_params.sleep_timeout_ms = + EC_HOST_SLEEP_TIMEOUT_DEFAULT; + + buf.msg.outsize = sizeof(buf.u.req1); + if ((sleep_event == HOST_SLEEP_EVENT_S3_RESUME) || + (sleep_event == HOST_SLEEP_EVENT_S0IX_RESUME)) + buf.msg.insize = sizeof(buf.u.resp1); + + buf.msg.version = 1; + + } else { + buf.u.req0.sleep_event = sleep_event; + buf.msg.outsize = sizeof(buf.u.req0); + } buf.msg.command = EC_CMD_HOST_SLEEP_EVENT; - buf.msg.version = 0; - buf.msg.outsize = sizeof(buf.req); - return cros_ec_cmd_xfer(ec_dev, &buf.msg); + ret = cros_ec_cmd_xfer(ec_dev, &buf.msg); + + /* 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)) + 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; } int cros_ec_register(struct cros_ec_device *ec_dev) diff --git a/drivers/platform/chrome/cros_ec_proto.c b/drivers/platform/chrome/cros_ec_proto.c index 97a068dff192..52ca564a64e7 100644 --- a/drivers/platform/chrome/cros_ec_proto.c +++ b/drivers/platform/chrome/cros_ec_proto.c @@ -414,6 +414,12 @@ int cros_ec_query_all(struct cros_ec_device *ec_dev) else ec_dev->mkbp_event_supported = 1; + /* Probe if host sleep v1 is supported for S0ix failure detection. */ + ret = cros_ec_get_host_command_version_mask(ec_dev, + EC_CMD_HOST_SLEEP_EVENT, + &ver_mask); + ec_dev->host_sleep_v1 = (ret >= 0 && (ver_mask & EC_VER_MASK(1))); + /* * Get host event wake mask, assume all events are wake events * if unavailable. diff --git a/include/linux/mfd/cros_ec.h b/include/linux/mfd/cros_ec.h index 8f2a8918bfa3..b6442201f77f 100644 --- a/include/linux/mfd/cros_ec.h +++ b/include/linux/mfd/cros_ec.h @@ -120,6 +120,7 @@ struct cros_ec_command { * @pkt_xfer: Send packet to EC and get response. * @lock: One transaction at a time. * @mkbp_event_supported: True if this EC supports the MKBP event protocol. + * @host_sleep_v1: True if this EC supports the sleep v1 command. * @event_notifier: Interrupt event notifier for transport devices. * @event_data: Raw payload transferred with the MKBP event. * @event_size: Size in bytes of the event data. @@ -153,6 +154,7 @@ struct cros_ec_device { struct cros_ec_command *msg); struct mutex lock; bool mkbp_event_supported; + bool host_sleep_v1; struct blocking_notifier_head event_notifier; struct ec_response_get_next_event_v1 event_data; -- 2.20.1