Received: by 10.192.165.156 with SMTP id m28csp817430imm; Thu, 19 Apr 2018 08:03:09 -0700 (PDT) X-Google-Smtp-Source: AIpwx4+htFqe+f2m48OAy/U6ZspyaGEx3Ka6y+Xzxx/6sNsDhOD1qHJoN7g7G6m4Z9PQCZkyJQXR X-Received: by 10.101.90.13 with SMTP id y13mr5480391pgs.324.1524150189097; Thu, 19 Apr 2018 08:03:09 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1524150189; cv=none; d=google.com; s=arc-20160816; b=rheNSzEQN83F9dsT6sRQO9nz8Rc/Et+zcOhw751+Ww09s01d/4qXNn946NqGiNlO+Q fUWiZfB5PQCqgYVf/eb/yKToDrrYxNqZOI10ukaCW0dqgpTmD5G84SY/7/yel/f1lH+9 pUuSayNtGqzzJjF4NqoOrLsRVfg6Hl/aQuL169kpvdR82qozp/hS+xYbsAMr0AP67jIL Em6MY2fUjSdDoOjMf2yPUJmdbhDSZhITNXhO1JbFazHGpDiy/3MFh2Z4l+doyHxtqnVa z+uMIyYrEpD8EUwGOYGG75V5dFZufE89nvOGPn1FPIIEeZF+JZA+xKLGoj3b7LC2pkeK aS9g== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:message-id:in-reply-to :subject:cc:to:from:date:arc-authentication-results; bh=vsLZjVLVbpq782MMEupf3AvN3IMFT8q1j4Y1vmJXUdk=; b=uvm3EcqR1As7K3L2svlLqvX9Xx2Lhe0e1HqIczh+VPAFcMZZcu5jeAZG8YffIMqPXu nSgW7LkRECOgqWMZiD5t3ihhakweGNmDpNpZhnsdrasKuULu35ERUkZUaERgNNt6+EXM HNHd2FNqpbCPRBT+e/DtiOd9soTyKeXQR3tTj2/RT0liHjUuisyGQOBJeImR6jTuxNZ9 IEEBQpfvbYUdSd/oBgqT8A2I+tX+N4QW/9yn6ekFkGTrYc4kRCjWTNAT0QoKkAwlAWH5 Qy3S2MxMXD6w8a9IthjuuNsSfLbzaBJ4ENuj5ZeqY2msUfXg3jvx08qouRpBmZ9dC21E 83+A== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id p125si3100688pga.503.2018.04.19.08.02.52; Thu, 19 Apr 2018 08:03:09 -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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753581AbeDSPB0 (ORCPT + 99 others); Thu, 19 Apr 2018 11:01:26 -0400 Received: from iolanthe.rowland.org ([192.131.102.54]:60730 "HELO iolanthe.rowland.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with SMTP id S1753122AbeDSPBU (ORCPT ); Thu, 19 Apr 2018 11:01:20 -0400 Received: (qmail 1410 invoked by uid 2102); 19 Apr 2018 11:01:19 -0400 Received: from localhost (sendmail-bs@127.0.0.1) by localhost with SMTP; 19 Apr 2018 11:01:19 -0400 Date: Thu, 19 Apr 2018 11:01:19 -0400 (EDT) From: Alan Stern X-X-Sender: stern@iolanthe.rowland.org To: Ravi Chandra Sadineni cc: gregkh@linuxfoundation.org, , , , , , , , , , , , , , , , , , , Subject: Re: [PATCH] USB: Increment wakeup count on remote wakeup. In-Reply-To: <20180419001850.133110-1-ravisadineni@chromium.org> Message-ID: MIME-Version: 1.0 Content-Type: TEXT/PLAIN; charset=US-ASCII Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 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. 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.) > @@ -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? 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)) >