Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp5582448yba; Thu, 11 Apr 2019 00:58:06 -0700 (PDT) X-Google-Smtp-Source: APXvYqwL7PA6r3zArZAJ5E5lBHrDB87PunGHNnompEtfJsVLATsonZkbend0YvPCr6o1VcV4gPrR X-Received: by 2002:a62:6fc6:: with SMTP id k189mr30426739pfc.154.1554969486498; Thu, 11 Apr 2019 00:58:06 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1554969486; cv=none; d=google.com; s=arc-20160816; b=U9igdt7jG5Wd6EGl17kRaiqeID8/DTkJIDk6Z1je4YfNkl+W+3RruOJH92vwMe8i6V 5+RNhqPtCaftolV0VtWW6dlySBII7nGCRCkbnAOorzpfPg4RxrpvFdU8enzFp6nAeO7T mZY4XTg/ILZEIdBGcqb+3cZsI3zdlz+ojMqnp8fchlE6yWFg9ixBDlNFtzNQVJK+37KZ hbhDaCh73g9p+4DXXTPnWpkmCDQX3RzgAfMzj/VHhQgste+wyFgs6rB3AZ6htkLf4R+Z KfbhF4I5q9rDD6EYIz6X5mMsnKoxHxTD/wjKi6fOh8ycvRcKlfs+PkYalCZpQGjbQK4k T5mw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:to:references:message-id :content-transfer-encoding:cc:date:in-reply-to:from:subject :mime-version; bh=O8I6+QP8dAnvcFSf5snO01pHB909XvBWfAoeHtdYzI8=; b=ToujxeUlYvPPBVddXb9RRuAXRRwmVKRESLI6gEpMFxGc9J5UrBqJ15iSbF1perzewB 2vi1fM3q8AsYu60YtaDoML3jTMdVrTg3GzDAdeoxuHFS9QqNyzWf9b2vIJe8n0EA3rBb u+8sdp6OydIRBgybtI1/MBcKxyuB3UxyknU/ukbPy8QyvZCXEqFUEQOyKS94MmPNhbt/ aIZ0pEtl6CmPZ9DtC8165I3ZGqbM0GU7IuZZwG5w44HHZTj6FwL5tBsiWivSXGFhtBA3 yg9f5yiNsHtf8Lm1iXB5cwozht4fmnNhTajtcDqo1xGagf69NlLKuKnXd1F6+HA3Vwnp SqNg== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=canonical.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id cv17si32990325plb.380.2019.04.11.00.57.50; Thu, 11 Apr 2019 00:58:06 -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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=canonical.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726992AbfDKHzo (ORCPT + 99 others); Thu, 11 Apr 2019 03:55:44 -0400 Received: from youngberry.canonical.com ([91.189.89.112]:47036 "EHLO youngberry.canonical.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726635AbfDKHzo (ORCPT ); Thu, 11 Apr 2019 03:55:44 -0400 Received: from mail-pl1-f197.google.com ([209.85.214.197]) by youngberry.canonical.com with esmtps (TLS1.0:RSA_AES_128_CBC_SHA1:16) (Exim 4.76) (envelope-from ) id 1hEUYg-0006Lx-Bq for linux-kernel@vger.kernel.org; Thu, 11 Apr 2019 07:55:42 +0000 Received: by mail-pl1-f197.google.com with SMTP id 3so3577084ple.19 for ; Thu, 11 Apr 2019 00:55:42 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:subject:from:in-reply-to:date:cc :content-transfer-encoding:message-id:references:to; bh=O8I6+QP8dAnvcFSf5snO01pHB909XvBWfAoeHtdYzI8=; b=nM8JAkAcT9zaEvZdzipR5p64XdMwymvi7p7E7UBP8FyeqpJNyRcK5zhi8Qeft/9AqF 03UNmQoYuVplf5CzljAnLIYC6y5TFIFUVRfHglfuD9AnDSOIv1PYNwU8oj7ITZDgLB9C WQxF2TgitYboLCrNCT/dHHAsJd0MQa7QXmVl4i/j+L3Eipiw7fSvhjSunNkED3ZfF70i ZTRLS6Gy9IXUjd1E1bNV0qKdyFctJu+JgNgrXQXDJSYOrJkbfrcBX2f8d6r3sVD3Y4Dq 6N9kU93ivukGd9jq4RN9fxSfrbwKsUHWcdDWmif00EdRuA2aRVoWztZFgJvqXg75/TFu ghOQ== X-Gm-Message-State: APjAAAV+K0QclwQpqUaq4hUq2Dx3WfmdiedG86qaw2XCjs89gV5K2PSq mB9hNMV5IlEdQShax7VF9OeKLtqyE6Hz6OZvgqVwEYi2YV9q202tk++MrNHSUI2W6v/5rFzLLVY 9KQ4SkIaMqlyyFNXgVSZTT2kdsbhy0rRTfzyoS4nchg== X-Received: by 2002:a63:5d04:: with SMTP id r4mr45228664pgb.117.1554969340866; Thu, 11 Apr 2019 00:55:40 -0700 (PDT) X-Received: by 2002:a63:5d04:: with SMTP id r4mr45228644pgb.117.1554969340636; Thu, 11 Apr 2019 00:55:40 -0700 (PDT) Received: from 2001-b011-380f-14b9-9cff-45f9-ad8b-c268.dynamic-ip6.hinet.net (2001-b011-380f-14b9-9cff-45f9-ad8b-c268.dynamic-ip6.hinet.net. [2001:b011:380f:14b9:9cff:45f9:ad8b:c268]) by smtp.gmail.com with ESMTPSA id l2sm42048820pgl.2.2019.04.11.00.55.39 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Thu, 11 Apr 2019 00:55:40 -0700 (PDT) Content-Type: text/plain; charset=utf-8; delsp=yes; format=flowed Mime-Version: 1.0 (Mac OS X Mail 12.4 \(3445.104.8\)) Subject: Re: [PATCH v2] USB: Disable USB2 LPM at shutdown From: Kai-Heng Feng In-Reply-To: <9EC6DA7E-2503-40F8-AB5A-25A2424B6346@canonical.com> Date: Thu, 11 Apr 2019 15:55:38 +0800 Cc: Greg KH , Linux USB List , lkml Content-Transfer-Encoding: 8bit Message-Id: <80534332-7E39-42B9-8B64-580B483B83A5@canonical.com> References: <20190124061643.11663-1-kai.heng.feng@canonical.com> <20190130082133.GA32660@kroah.com> <9EC6DA7E-2503-40F8-AB5A-25A2424B6346@canonical.com> To: Alan Stern , Mathias Nyman X-Mailer: Apple Mail (2.3445.104.8) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org at 18:22, Kai-Heng Feng wrote: > at 00:01, Kai-Heng Feng wrote: > >>> On Jan 30, 2019, at 16:21, Greg KH wrote: >>> >>> On Thu, Jan 24, 2019 at 02:16:43PM +0800, Kai-Heng Feng wrote: >>>> The QCA Rome USB Bluetooth controller has several issues once LPM gets >>>> enabled: >>>> - Fails to get enumerated in coldboot. [1] >>>> - Drains more power (~ 0.2W) when the system is in S5. [2] >>>> - Disappears after a warmboot. [2] >>>> >>>> The issue happens because the device lingers at LPM L1 in S5, so device >>>> can't get enumerated even after a reboot. >>>> >>>> Disable LPM at shutdown to solve the issue. >>>> >>>> [1] https://bugs.launchpad.net/bugs/1757218 >>>> [2] https://patchwork.kernel.org/patch/10607097/ >>>> >>>> Signed-off-by: Kai-Heng Feng >>>> --- >>>> v2: Use new LPM helpers. >>>> >>>> drivers/usb/core/port.c | 9 +++++++++ >>>> 1 file changed, 9 insertions(+) >>>> >>>> diff --git a/drivers/usb/core/port.c b/drivers/usb/core/port.c >>>> index 1a06a4b5fbb1..bbbb35fa639f 100644 >>>> --- a/drivers/usb/core/port.c >>>> +++ b/drivers/usb/core/port.c >>>> @@ -285,6 +285,14 @@ static int usb_port_runtime_suspend(struct device >>>> *dev) >>>> } >>>> #endif >>>> >>>> +static void usb_port_shutdown(struct device *dev) >>>> +{ >>>> + struct usb_port *port_dev = to_usb_port(dev); >>>> + >>>> + if (port_dev->child) >>>> + usb_disable_usb2_hardware_lpm(port_dev->child); >>>> +} >>>> + >>>> static const struct dev_pm_ops usb_port_pm_ops = { >>>> #ifdef CONFIG_PM >>>> .runtime_suspend = usb_port_runtime_suspend, >>>> @@ -301,6 +309,7 @@ struct device_type usb_port_device_type = { >>>> static struct device_driver usb_port_driver = { >>>> .name = "usb", >>>> .owner = THIS_MODULE, >>>> + .shutdown = usb_port_shutdown, >>>> }; >>> >>> So you now do this for all ports in the system, no matter what is >>> plugged in or not. Are you _SURE_ you want to do that? It seems like a >>> big hammer to solve just one single device's problems. >> >> Yes I think this should be universally applied. >> >> I don’t think the bug only happens to one device. Users won’t find this >> unless they connect their laptop to a power meter. >> >> Platform may not completely cut off USB bus power during shutdown, >> so the device transits to L1 after system shutdown. Now xHC is disabled >> so nothing can bring it back to L0 or L2. > > It would be great if someone can come up with better ideas. > > We can also use other approaches, but currently this is the only way I > can think of. Alan and Mathias, It would be great if you can review this patch, or give me some suggestion. Kai-Heng > > Kai-Heng > >> Kai-Heng >> >>> thanks, >>> >>> greg k-h