Received: by 10.192.165.148 with SMTP id m20csp558523imm; Fri, 20 Apr 2018 11:10:30 -0700 (PDT) X-Google-Smtp-Source: AIpwx48BZp348SgURwCoBDkpgAIMLHUrqRv9IknKiWRriwnXjpE62DITdVKOQwCDobRjyv1pnpKe X-Received: by 2002:a17:902:9a0b:: with SMTP id v11-v6mr11316606plp.387.1524247830624; Fri, 20 Apr 2018 11:10:30 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1524247830; cv=none; d=google.com; s=arc-20160816; b=xc/mNMSunrZLhV1gIHydqyeLcnmExGzb0YkKqYunBSnAM/86MfSfDiXaS1CCK6ikTL zrDnMVz7NSOIygSewESIBZ9cH+WZXeepk7dadBYNBvoPxqYx62BCr68YZZ7cXlc99/nM d2JlMbRpbKm2Gt3Rrqrr31QzYQIPAo1QKquzSXDDk4EXy07zV5qP+NT+MAl33eBKGXqK OAwgGTfRVUsYExwmL/U+oew608LrcrlpCpw9kqxMSZ0wb8ym+lPazoRwkWx4nwSRp9vR +nEYVQpPO7g/k21scumFvAWC88mTqbWKbNJ1avPGXHGhCOhk2HAki5Tq2c7lhZ5koZ9X DcDQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:dkim-signature:arc-authentication-results; bh=1W1F8aF8gg+YBAFKP0XcgJyi1ZIDOlZ7o959HsBbGCk=; b=S3dUBdugMGIeKVi8sC2jt5Mz7wbmHZayXQVamIC1RYslzCWiCc7d4jJlC92lhH10bx 75l+QIZOohaBmBeXpG+DVHISIXK/6bevm8xjaP4rqMEAbpfEP5FpkofTVky/yyVnJGAi 84sSotG+N9WhFJXm3vPNw4yu3QMNGnBlBU7Zpoq1xz+2rcFg2fS8IspEzYiuU/AxwKfj q2y4c6N4MVmfLc6wLFjGm0KizJAZL5BDg2+WeG2wH+c1AOyo6RZ0M26vBdBF4VF1X8i8 yWJJBSM4GhK8rFkpqEh8l+PeY5d/y13fw/boTH/vLF/vMzaiI9dVqj8zdI5Tk4tXOjJk wR8g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=R1aGlXGS; 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 o10si3101912pgs.410.2018.04.20.11.10.16; Fri, 20 Apr 2018 11:10:30 -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=R1aGlXGS; 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 S1753722AbeDTSJE (ORCPT + 99 others); Fri, 20 Apr 2018 14:09:04 -0400 Received: from mail-pf0-f194.google.com ([209.85.192.194]:41961 "EHLO mail-pf0-f194.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753654AbeDTSI6 (ORCPT ); Fri, 20 Apr 2018 14:08:58 -0400 Received: by mail-pf0-f194.google.com with SMTP id a2so4634669pff.8 for ; Fri, 20 Apr 2018 11:08:57 -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; bh=1W1F8aF8gg+YBAFKP0XcgJyi1ZIDOlZ7o959HsBbGCk=; b=R1aGlXGSInRLC2Fl5Us/gL/nEETIiOTJMySeLqX0t3RcHGoWoub5DTBrlCIdFB7NvV ZSqnb/pUWOhqWcHu08X1xOrLyoszQnEa4n898VPhmz4oNpDNzGgyjofq97fI2tn3w+Eh x1CpOGWUBUml++OOTWontJuHJYikk9KKtY6qw= 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; bh=1W1F8aF8gg+YBAFKP0XcgJyi1ZIDOlZ7o959HsBbGCk=; b=IgM4sTjC7gBx7eqBc92yIQOJthJX8skQWRAxSSVW6bqOjFRO1Lso4Ozwwl093i02Km 1WyoljVPbKcukiuVy4CZpQVsdwYda3IoHcN258c5daJbPB52QQEOlT4AvYVgfaXOeI+8 SJ2eNI2Vgx8k5TpWZLbjYMX9Uz7JHTtqSzbIT4djVEAlE/kUKlqOXdW7SUHjrh9r0STg q71j8hK+AzEnExHuflBryIQpclostAArHNi8B7iuduCGpUf9b4Lq0vKAqWAfzUeYZXeu NDQWUVcSe2vkPzkZH3bOWIviAm6WtqckucHSI7TxnFvAmA6/9CXKp6V5p5pBhf9yWKbl b9dA== X-Gm-Message-State: ALQs6tCjwPl7GSSARgEmcmvoWoIYrGwVlomnmHSMNgEnk8ShU2HQp4pn ZpOSNz4DGIXCqieLZ6tYFF9ueg== X-Received: by 10.99.126.9 with SMTP id z9mr9515993pgc.437.1524247737470; Fri, 20 Apr 2018 11:08:57 -0700 (PDT) Received: from ravisadineni0.mtv.corp.google.com ([2620:0:1000:1501:22d6:f20d:f2b7:3315]) by smtp.gmail.com with ESMTPSA id o88sm24063146pfa.29.2018.04.20.11.08.56 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Fri, 20 Apr 2018 11:08:56 -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 V5] USB: Increment wakeup count on remote wakeup. Date: Fri, 20 Apr 2018 11:08:21 -0700 Message-Id: <20180420180821.194380-1-ravisadineni@chromium.org> X-Mailer: git-send-email 2.17.0.484.g0c8726318c-goog In-Reply-To: References: 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: Ravi Chandra Sadineni --- V5: Added the description of changes between different versions of patches. V4: Moved the wakeup count increment logic to the existing if which is safegaurded by hcd_root_hub_lock spinlock. V3: Added a gaurd to check if rh_registered is set before accessing root_hub pointer. V2: Fixed the build failure error due to uninitialized dev pointer. drivers/usb/core/hcd.c | 1 + drivers/usb/core/hub.c | 10 +++++++++- 2 files changed, 10 insertions(+), 1 deletion(-) diff --git a/drivers/usb/core/hcd.c b/drivers/usb/core/hcd.c index 777036ae63674..00bb8417050ff 100644 --- a/drivers/usb/core/hcd.c +++ b/drivers/usb/core/hcd.c @@ -2377,6 +2377,7 @@ void usb_hcd_resume_root_hub (struct usb_hcd *hcd) spin_lock_irqsave (&hcd_root_hub_lock, flags); if (hcd->rh_registered) { + pm_wakeup_event(&hcd->self.root_hub->dev, 0); set_bit(HCD_FLAG_WAKEUP_PENDING, &hcd->flags); queue_work(pm_wq, &hcd->wakeup_work); } diff --git a/drivers/usb/core/hub.c b/drivers/usb/core/hub.c index f6ea16e9f6bb9..aa9968d90a48c 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); } @@ -3434,8 +3439,11 @@ int usb_port_resume(struct usb_device *udev, pm_message_t msg) /* 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)) + 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.17.0.484.g0c8726318c-goog