Received: by 10.192.165.156 with SMTP id m28csp61287imm; Wed, 18 Apr 2018 17:20:44 -0700 (PDT) X-Google-Smtp-Source: AIpwx49/tFTfWAHSpD4yCarPjOo/xII+KNkMaBO/y/LZa0m8hWzxj+tpMIS9AnLjSJlDQp0k4lOq X-Received: by 2002:a17:902:b609:: with SMTP id b9-v6mr3876918pls.29.1524097244819; Wed, 18 Apr 2018 17:20:44 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1524097244; cv=none; d=google.com; s=arc-20160816; b=RTeytomHnihktZlEAZ3LqAIhQfDi8FD02emaoninXy6nuX99PDEyoBoCppKidW1NSN FtouoqMgM+XH5/vo0AqQ36jMavnY7KbszyAKIUtEy7p6VRTRREb5QyJEQPgnCF3JQgFR A98n0/zVBC8P3Ukts0ki+bPbDqhIFc2yhHD6uqxaG3y2xulI1zefJX3ULAimR7fiepDT 0bNQwM95wGnT1AjaSTdh+K+nC1hu7lE+0EIsbLcFFMdTC1n/HdrmSZB04akqJvpg3cA4 j4TCGC2O9FSq6CZqDl4PhwTpUJ4T8h2CUTo1uU2qLDwfO3zeC0oZ9NW9a2ti/No2w89B DAiQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from :dkim-signature:arc-authentication-results; bh=KBPNMxaXO5BRdA+16kGJLSjfpSPzl0mJ7vCw/WhluSg=; b=e28fn+kF7oiZhg/fwSKU8t0TAMovJI10rx8ZvRdXfNpVj4/xOokc9DRQrAVslefDTp 1GiYFlmXVsjTg21im1i2ti05VO49yEQd4oQwviRL/YDOjdEnTs2fCsIdRWgElHuT0fz6 evX7TXMEzDl2v6BanrZdHLNL6YAme8uF2oGUVhrY3fV3/FryEaQfUgktQrcGleD2Qr9Q CNebudRk0MMq/Gi2MQbOWIgbmwq9LnwbXvNC0mKnkWA9g9CNJwb8A5JGTFrT09DRxx1m x/dPGNBtaKkYfEM1RurPyIcH102W+ME0H6WAJVRLK9GKTMB3F1Xj5/Twxpd1uOfCta+V 9txw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=XWE6aDKc; 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 k13si1957270pgr.124.2018.04.18.17.20.29; Wed, 18 Apr 2018 17:20:44 -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=XWE6aDKc; 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 S1753048AbeDSATL (ORCPT + 99 others); Wed, 18 Apr 2018 20:19:11 -0400 Received: from mail-pl0-f66.google.com ([209.85.160.66]:46393 "EHLO mail-pl0-f66.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752499AbeDSATH (ORCPT ); Wed, 18 Apr 2018 20:19:07 -0400 Received: by mail-pl0-f66.google.com with SMTP id 59-v6so2098487plc.13 for ; Wed, 18 Apr 2018 17:19:07 -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; bh=KBPNMxaXO5BRdA+16kGJLSjfpSPzl0mJ7vCw/WhluSg=; b=XWE6aDKcK8JfrX+pDZoPLLwFMwxHbu94QEcmGMC0FoKYutuHsGCMi/ed/L6iebTdmh rBZRp4ATedUv0rXR522C7oIYyX/JF3eAeNSScVkh6VHhuseVG4C71U6X5Sz0YiVsDobO c/OpKYEHBWCStRq+7F8WYqtc179qGxemYr7us= 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; bh=KBPNMxaXO5BRdA+16kGJLSjfpSPzl0mJ7vCw/WhluSg=; b=XvsQeOvXv81sWCf2i9t9TaeozBHjlHE15IrSrB4CoDVjMVsSEd8KUwLxqUuFIRRcoq Ad/mlCKFL/lMB8KmJcB8AL9L0dxfeBh2E0GWgqROcBe5AEpJNXxMr+3bN9VgP07bcb6j fgaVO9ZSPJEdCmmVK/8/Am6sUMGp1Pg8c8Z3vdyj8xQfjU1EuSkqWqzgPH1n/6QBCtVD thPk4QcpdxxvIuURAs1wq4CfhRpd3r2hv8AL8MDiukYmmqNb+dDPyiQSnTE22IQ8FKre Dzp45ihoeTR5GEPFMHL6jW7gJhaUbzkxoOBuExsVEMVVdCejzlBqSyB0Q+XHIL+8tX+J DuSw== X-Gm-Message-State: ALQs6tDvij3WTkDlbEEUTO4SZW0oFOvtMp/EAUbrSHi0B1b0hmC6IKhy jb57SNUBKJ62QuMqHlLfPIFbXQ== X-Received: by 2002:a17:902:aa46:: with SMTP id c6-v6mr3843695plr.154.1524097146475; Wed, 18 Apr 2018 17:19:06 -0700 (PDT) Received: from ravisadineni0.mtv.corp.google.com ([2620:0:1000:1501:22d6:f20d:f2b7:3315]) by smtp.gmail.com with ESMTPSA id y6sm4487558pfd.18.2018.04.18.17.19.05 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Wed, 18 Apr 2018 17:19:05 -0700 (PDT) From: Ravi Chandra Sadineni To: stern@rowland.harvard.edu, gregkh@linuxfoundation.org, martin.blumenstingl@googlemail.com, ravisadineni@google.com, chunfeng.yun@mediatek.com, johan@kernel.org, arvind.yadav.cs@gmail.com, dtor@google.com, anton.bondarenko.sama@gmail.com, f.fainelli@gmail.com, keescook@chromium.org, mathias.nyman@linux.intel.com, felipe.balbi@linux.intel.com, ekorenevsky@gmail.com, peter.chen@nxp.com, joe@perches.com Cc: tbroch@google.com, linux-usb@vger.kernel.org, linux-kernel@vger.kernel.org, rajatja@google.com, bleung@google.com, Ravi Chandra Sadineni Subject: [PATCH] USB: Increment wakeup count on remote wakeup. Date: Wed, 18 Apr 2018 17:18:50 -0700 Message-Id: <20180419001850.133110-1-ravisadineni@chromium.org> X-Mailer: git-send-email 2.17.0.484.g0c8726318c-goog Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On chromebooks we depend on wakeup count to identify the wakeup source. But currently USB devices do not increment the wakeup count when they trigger the remote wake. This patch addresses the same. Resume condition is reported differently on USB 2.0 and USB 3.0 devices. On USB 2.0 devices, a wake capable device, if wake enabled, drives resume signal to indicate a remote wake (USB 2.0 spec section 7.1.7.7). The upstream facing port then sets C_PORT_SUSPEND bit and reports a port change event (USB 2.0 spec section 11.24.2.7.2.3). Thus if a port has resumed before driving the resume signal from the host and C_PORT_SUSPEND is set, then the device attached to the given port might be the reason for the last system wakeup. Increment the wakeup count for the same. On USB 3.0 devices, a function may signal that it wants to exit from device suspend by sending a Function Wake Device Notification to the host (USB3.0 spec section 8.5.6.4) Thus on receiving the Function Wake, increment the wakeup count. Signed-off-by: ravisadineni@chromium.org --- drivers/usb/core/hcd.c | 1 + drivers/usb/core/hub.c | 12 ++++++++++-- 2 files changed, 11 insertions(+), 2 deletions(-) diff --git a/drivers/usb/core/hcd.c b/drivers/usb/core/hcd.c index 777036ae63674..79f95a878fb6e 100644 --- a/drivers/usb/core/hcd.c +++ b/drivers/usb/core/hcd.c @@ -2375,6 +2375,7 @@ void usb_hcd_resume_root_hub (struct usb_hcd *hcd) { unsigned long flags; + pm_wakeup_event(dev, 0); spin_lock_irqsave (&hcd_root_hub_lock, flags); if (hcd->rh_registered) { set_bit(HCD_FLAG_WAKEUP_PENDING, &hcd->flags); diff --git a/drivers/usb/core/hub.c b/drivers/usb/core/hub.c index f6ea16e9f6bb9..6abc5be1bcbf5 100644 --- a/drivers/usb/core/hub.c +++ b/drivers/usb/core/hub.c @@ -653,12 +653,17 @@ void usb_wakeup_notification(struct usb_device *hdev, unsigned int portnum) { struct usb_hub *hub; + struct usb_port *port_dev; if (!hdev) return; hub = usb_hub_to_struct_hub(hdev); if (hub) { + port_dev = hub->ports[portnum - 1]; + if (port_dev && port_dev->child) + pm_wakeup_event(&port_dev->child->dev, 0); + set_bit(portnum, hub->wakeup_bits); kick_hub_wq(hub); } @@ -3432,10 +3437,13 @@ int usb_port_resume(struct usb_device *udev, pm_message_t msg) usb_lock_port(port_dev); - /* Skip the initial Clear-Suspend step for a remote wakeup */ status = hub_port_status(hub, port1, &portstatus, &portchange); - if (status == 0 && !port_is_suspended(hub, portstatus)) + /* Skip the initial Clear-Suspend step for a remote wakeup */ + if (status == 0 && !port_is_suspended(hub, portstatus)) { + if (portchange & USB_PORT_STAT_C_SUSPEND) + pm_wakeup_event(&udev->dev, 0); goto SuspendCleared; + } /* see 7.1.7.7; affects power usage, but not budgeting */ if (hub_is_superspeed(hub->hdev)) -- 2.13.5