Received: by 10.192.165.148 with SMTP id m20csp132914imm; Thu, 19 Apr 2018 17:52:01 -0700 (PDT) X-Google-Smtp-Source: AIpwx48SofYIwlg+R6oUkGDtn08AXA8UWb4OTU9FLtA/rogqqApSGVgzgN24rJM/IPO2PVg+lKS8 X-Received: by 10.101.90.13 with SMTP id y13mr6820580pgs.324.1524185521495; Thu, 19 Apr 2018 17:52:01 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1524185521; cv=none; d=google.com; s=arc-20160816; b=vK00R7I6O43Hico4711hmn0O49cwhwGrjv7sdwW18XKpSsNGc+bMmTAf/0upCB1KWp ILXcma+20TPUyKYcn2PWR0wvQ5X8iGMB4vI29qJm48XWnRwwUofp2vc1rZL21hhr78y4 vpddCNqcLVMziy6Wkp6x4igezUgf+pSCQ3km/j2j8qRepswU7yBUcXEaE1YxT3jpYn7m J6YBFQmGy5MFDi3mb9+Z3yNVxHBM9wC+/CfHy3+Lj8JYoBbZ8/CWWwKPFa25zbFOElWQ Tve2lSoejuoCJ5637Ef7OH1FIMVbsB8HFwFmh+70VqwnBfXAbTrRTgt2umH8e+hCmfPA WRFw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:subject:message-id:date:from :references:in-reply-to:mime-version:dkim-signature :arc-authentication-results; bh=6InqoyN+3Yj9jYChqkfxZyb+A3gMtNpmwVP9sMq+z4g=; b=paiZlWsubjxu+VxTiEuEF3zn3watrXHZUbN4M5EMyjs+Y5SCBajS7qLrDrLuibKOca dqElAiV59e5LdPu8PZevzs2iSts1uBKEy+0OVBVy3XO5mvZVg4Zd8aIA5413EfxHPv5v go7JbpvkQZzeiEt65DdkThsZGOKJ8fZ3MB4xMN4eUIGk9AAJyiVpAKT40n//d44OkjT3 9bB5IF5ff8qSUWnPrrXHoTdtnU9o/RggKEXARD7WBO0c8ee/9pTCVKr09VeYMVNKl37L 3ZwQHIR6SLMjf8LXZv4AOkTTI9ah+Vra1N0Avui96x7B9A0wXPqyO9eTkWFnUvL+Bv1f qAQw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=eiDThguO; 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=REJECT sp=REJECT dis=NONE) header.from=google.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id w124si4293525pfb.12.2018.04.19.17.51.47; Thu, 19 Apr 2018 17:52:01 -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=@google.com header.s=20161025 header.b=eiDThguO; 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=REJECT sp=REJECT dis=NONE) header.from=google.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754039AbeDTAuY (ORCPT + 99 others); Thu, 19 Apr 2018 20:50:24 -0400 Received: from mail-vk0-f50.google.com ([209.85.213.50]:41869 "EHLO mail-vk0-f50.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1753964AbeDTAuX (ORCPT ); Thu, 19 Apr 2018 20:50:23 -0400 Received: by mail-vk0-f50.google.com with SMTP id i75so4306695vke.8 for ; Thu, 19 Apr 2018 17:50:23 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20161025; h=mime-version:in-reply-to:references:from:date:message-id:subject:to :cc; bh=6InqoyN+3Yj9jYChqkfxZyb+A3gMtNpmwVP9sMq+z4g=; b=eiDThguONTgbnB8VxSi1mt6KPQYQHnvLrLoY15TR+8ZA0xPepb31RmERFi+jsSHE9x 7E2v8tTF4qRrBzAaPXgmaecopVFlvUgjvWKbuJnHfsUkrl/fCaf0NcYanmBsQfougYXx W54M+IoonhLAgCSpXgKx2ixYXKMGS0iroGLw+Ng7NlrxEu13eSa95g4Ld1SnQTW9+gpu YaVdYFZZboa8ZDE6OafwmHPQ0yybtTCYuVDAaOiUS0PNr4/SaBtich9aRekAMNrnEeUl gaCYu9JbFSczVOp6KSTMbu9NJbeRrV4rb4HJH4lFhF8friCtqHlv6e87NvaFTKxB45yd 6+kg== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:in-reply-to:references:from:date :message-id:subject:to:cc; bh=6InqoyN+3Yj9jYChqkfxZyb+A3gMtNpmwVP9sMq+z4g=; b=C11FXuZjwlf/9/up50oosayBq1LnFe5ajQ0wu2qwF+6Scih0l4jM/F+Isq2ynsi4xQ P9pfGqICy0lRUDhM6OzV7dKCkQxdT6McHA8v45AsaAYcynfJu666lMrTh8FDsBPzHM4X YHXITRy5kQziBF/9j5+TOjaIHedKYMoF8Yj1WwHqWnijJBjxEd+sDKBgi8jGWcICg2E0 U75c9zyON3n5KdIpc+fMdRkTq1KPePq5e3yW+pBlyqZPmaO7OS0vlsHdpeO+DCQI0Jwd 4/kbscHfYQTnLhUkW23Bn3xB7nrGh+ingxGryjRcObcFDcA7UW3X+WJV4gd3XZbNFXkh a82A== X-Gm-Message-State: ALQs6tBpSk0VRLM7xMiUjlplcqXOZ0gHmHaByBloyBzg7jLSykjS61Ap uUn7QwCL0PBdYV+ghfvMag0yW+kXigOsQSmwIJWVIg== X-Received: by 10.31.63.75 with SMTP id m72mr5731363vka.42.1524185422013; Thu, 19 Apr 2018 17:50:22 -0700 (PDT) MIME-Version: 1.0 Received: by 10.103.116.199 with HTTP; Thu, 19 Apr 2018 17:50:01 -0700 (PDT) In-Reply-To: References: <20180419001850.133110-1-ravisadineni@chromium.org> From: Ravi Chandra Sadineni Date: Thu, 19 Apr 2018 17:50:01 -0700 Message-ID: Subject: Re: [PATCH] USB: Increment wakeup count on remote wakeup. To: Alan Stern Cc: Ravi Chandra Sadineni , gregkh@linuxfoundation.org, martin.blumenstingl@googlemail.com, chunfeng.yun@mediatek.com, johan@kernel.org, arvind.yadav.cs@gmail.com, Dmitry Torokhov , 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, Todd Broch , linux-usb@vger.kernel.org, linux-kernel@vger.kernel.org, Rajat Jain , Benson Leung Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Alan, Thanks for reviewing the change. Appreciate your time. I tried to address your comments in the V2 of the patch. On Thu, Apr 19, 2018 at 8:01 AM, Alan Stern wrote: > On Wed, 18 Apr 2018, Ravi Chandra Sadineni wrote: > >> 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); > > Instead of dev, you probably want to use hcd->self.sysdev. Or maybe > hcd->self.controller, although the difference probably doesn't matter > for your purposes. Trying to increment the wakeup count for the roothub. So pointed dev to &hcd->self.root_hub->dev. Hope this is fine. > > On the other hand, this wakeup event may already have been counted by > the host controller's bus subsystem. Does it matter if the same wakeup > event gets counted twice? > > (This is inevitable with USB devices, in any case. If a device sends a > wakeup request, it will be counted for that device, for all the > intermediate hubs, and for the host controller.) We are o.k. with the wake-up count getting incremented for the intermediate hubs. We just want to identify the leaf hid devices, if they are cause of the remote wake. This way, we can differentiate user triggered wake from a automatic wakes (Ex: wakes triggered by WOLAN packets from USB ethernet adapter). We are also o.k. with the wake-up count getting incremented twice. All we look for is a change in the wake-up count for the interested devices. > >> @@ -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 */ > > What is the reason for moving the comment line down after the > hub_port_status() call? Sorry. This was a mistake. Changed this back in V2. > > Alan Stern > >> + 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)) >> > Thanks, Ravi