Received: by 10.192.165.148 with SMTP id m20csp545225imm; Fri, 20 Apr 2018 10:56:51 -0700 (PDT) X-Google-Smtp-Source: AIpwx4/NwU0bUJxx+tHofXeSP21n3QADswGwE8uXDhzt0rd32UaZCaHP4O553kfsCGIlOrxGkOeb X-Received: by 10.98.77.2 with SMTP id a2mr10609612pfb.213.1524247011474; Fri, 20 Apr 2018 10:56:51 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1524247011; cv=none; d=google.com; s=arc-20160816; b=Ridzx49W1MzkhrJTH/jLZOa8GcXlzjju5LmhOjISi3XpytJZr9vGIqX+3KkPvPHpBb LW4d1Q3Z4pytvcsl9LaiEWwN8frN4+cPYbJC6nkHsi01SQYxRHC0xUkAsaLU0Id4oaCY hSHFiQO6eiF1XChzbPq9FMNawtKEQ+VxDQZ0fWh0krehn7SYx08n5SetoLrUThaC+UHy gBrWjTbTZUJ5HffpvFMvLsPLR62kp20loSK+F2kP4wXg0nGVa4txLyNDkAPrpD9iRRie BYEB+vQFcdDojnjhD+I52Ie3VQYWJBLGomtq3TDsscbIGDFrN9fFTIMELl5YiOygYxec vKfA== 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=1EGxjyKPxGwXFDxvFmAmpOvl2K7Up1Gjh6yfEh8PPDM=; b=rK3D9rcwkuNFcsAlv/8fTKUMM5eUgmIv6VwtBfGGdQ3p5F+QeZBVMUJTN5sN/mlsKT dH9c0iVD7uY7uHmcmsmtNAPSTtNdumpevUonm6dHoGm13+uDOch211IDh4JESfsc84zC 8yXTWMptNSBqzFs87DWVMUumu9ZORJJsxSCN8KiSTs0F74/dOOlZScxfR0iLmwl5dQ9t X8dkNG5G2HC1ht5uAWMv4NAPbMTS5R/njgawB6g8qmz1KELXH9lZW/puAoNsizVZFrAN WeMwnAq5Rhye5O0eHq8hLwRxK2WQH6ZxEUnQ0Im/2vM+geFtCcRdTyJ+tbYRW64DgLYS asyA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@chromium.org header.s=google header.b=lzINQGCd; 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 y7-v6si6154636plh.583.2018.04.20.10.56.37; Fri, 20 Apr 2018 10:56:51 -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=lzINQGCd; 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 S1753669AbeDTRym (ORCPT + 99 others); Fri, 20 Apr 2018 13:54:42 -0400 Received: from mail-pl0-f66.google.com ([209.85.160.66]:45562 "EHLO mail-pl0-f66.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753566AbeDTRyk (ORCPT ); Fri, 20 Apr 2018 13:54:40 -0400 Received: by mail-pl0-f66.google.com with SMTP id w22-v6so1084734pll.12 for ; Fri, 20 Apr 2018 10:54:39 -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=1EGxjyKPxGwXFDxvFmAmpOvl2K7Up1Gjh6yfEh8PPDM=; b=lzINQGCdChMx1c1rlJqlIoelxLcmXI0yClXSWZjjidkIibBeuEj/QPisxnXGIRPy9c 5uRaG0tXnpD0wYJICfJReKDs2aGyEyZe7o4nkZ0OuD932jpSbDp8BoRsWyfTJJs4jiL/ tLI/KEsVAQLU0dZI/Rmwa4FpAkNVktXQgQ8s8= 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=1EGxjyKPxGwXFDxvFmAmpOvl2K7Up1Gjh6yfEh8PPDM=; b=saWwOfE7WfJalZYhAbdzOV4iqoBWedxxxTu7qt8znruDiQU1T2NT6ammQSuBTPylsA GuxjjqxUSWC/lE3YJ7FcjgUzz3evfZv0V3b6bvwZocFyGob6ZKcx+M4YAZJIVtTGxUx0 rfqh6PC+6sd3l/oBkt7rfW+QBxgpOYxb3p7x0vq0wk7P1aoupgvjO85wc9p3vCJBrseb RyZJakG9vVIMOxImMDfLFhzgq0kEYsC69DRfTohnCujksW7glYxcWQ9akrKah7NS+qcT 1dj6vHJLIv7n8TmM7logk8JThKDYrgjK35Z8wbVsmgraiYo38K8DtuNxjjWO3NLVHUGF 846g== X-Gm-Message-State: ALQs6tBGbyY7Jtg5g7/IEupRLrZ4Iclf4EEqbIfsgdahb7Ty/Pn7Iak/ lyqblB2QHhMBzmkNOPeoAPQRKA== X-Received: by 2002:a17:902:1c8:: with SMTP id b66-v6mr7385554plb.156.1524246879659; Fri, 20 Apr 2018 10:54:39 -0700 (PDT) Received: from ravisadineni0.mtv.corp.google.com ([2620:0:1000:1501:22d6:f20d:f2b7:3315]) by smtp.gmail.com with ESMTPSA id t137sm13542227pgc.16.2018.04.20.10.54.36 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Fri, 20 Apr 2018 10:54:37 -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 V4] USB: Increment wakeup count on remote wakeup. Date: Fri, 20 Apr 2018 10:54:10 -0700 Message-Id: <20180420175410.191710-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 --- 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