Received: by 2002:ac0:a679:0:0:0:0:0 with SMTP id p54csp252727imp; Thu, 21 Feb 2019 00:23:52 -0800 (PST) X-Google-Smtp-Source: AHgI3IbNbV9v/sEmT7Z+S0d8d1tcmS+T7A/3SzTZFQAba5FP1Zn/1/uzeLlgX4zA22pqMEGAXEY9 X-Received: by 2002:a63:8441:: with SMTP id k62mr31567735pgd.219.1550737432836; Thu, 21 Feb 2019 00:23:52 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1550737432; cv=none; d=google.com; s=arc-20160816; b=XzSaTzEar2UM/G5Th6D6uPxV4FPfIYbeSfHG06Jt5Xh1FjswR7Ri9GS6tJBLr6AMab RCmbJCFVQpacprbb1YqjrDTbZAWlfOGDMkR/vO/fzliZhy9TZg8/WfUbbYFwIrFzgaHF ZYSThRPakMC3iW7AncYOmz+WNGSYN4P/FNZeoBWEuO5Iy/lu8sU+Mii64+lx+ZmaEk26 TUUKjpiRTTeN/GSanFqum6PZaxNWikkJ801ZVbvesTR0fZD/CAMXKmXHHMloU21QIfx2 XISN+fFqjZNSqkImb9N1mSHLn+2t/GzBBSBFHKP5hVr6Lv23jXDEDy+OO2fRJsYDLQ/H zNFQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :user-agent:organization:references:in-reply-to:date:cc:to:from :subject:message-id; bh=ilHL5xuOHk0tKHOj4YKnK0Aw5+EJ5mDwphjHiUsPDGU=; b=oI47fw0oS5COwzXgkoWXk1XShGHYs30ewEIeyfwEBX4mNvW4AsIP8/yYFkhWHI45Kt A7NGHsdtc7NZu230RvwxT/R/XVzUJjBCav9RRVqRrYSYavNrOUtiuWSs3JqBaZgmHdcW P6EFnzQOmgrutQqbqBFttghO/jCR4LUjSRwy1qw6EcHByPEwSU2L3FXRCcBBAoB6Hhfp jcyTHc1NGzSBR/iFkWItp6dZi7xt2TL7sdJHw0aMXBTdFKXvbnvo8iTE9bbh84VjdT/K eak2+qnpaoqOcUk8okglLrbQWOcFLf/bTPNLaVlwRufKiTFaNZ55YDtFBO0nwc9pLuUr ywaA== 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 h85si20909839pfd.27.2019.02.21.00.23.37; Thu, 21 Feb 2019 00:23:52 -0800 (PST) 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 S1727448AbfBUIWv (ORCPT + 99 others); Thu, 21 Feb 2019 03:22:51 -0500 Received: from relay6-d.mail.gandi.net ([217.70.183.198]:39241 "EHLO relay6-d.mail.gandi.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726075AbfBUIWu (ORCPT ); Thu, 21 Feb 2019 03:22:50 -0500 X-Originating-IP: 90.88.23.190 Received: from aptenodytes (aaubervilliers-681-1-81-190.w90-88.abo.wanadoo.fr [90.88.23.190]) (Authenticated sender: paul.kocialkowski@bootlin.com) by relay6-d.mail.gandi.net (Postfix) with ESMTPSA id CC31CC000C; Thu, 21 Feb 2019 08:22:47 +0000 (UTC) Message-ID: <3ed330798d31d01fdfbd40571d016a108c9c5040.camel@bootlin.com> Subject: Re: [PATCH v3] usb: chipidea: Grab the (legacy) USB PHY by phandle first From: Paul Kocialkowski To: Peter Chen , "linux-usb@vger.kernel.org" , "linux-kernel@vger.kernel.org" Cc: Greg Kroah-Hartman , Thomas Petazzoni Date: Thu, 21 Feb 2019 09:22:47 +0100 In-Reply-To: References: <20190215162225.19284-1-paul.kocialkowski@bootlin.com> Organization: Bootlin Content-Type: text/plain; charset="UTF-8" User-Agent: Evolution 3.30.5 MIME-Version: 1.0 Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi, On Thu, 2019-02-21 at 03:29 +0000, Peter Chen wrote: > > > On Mon, 2019-02-18 at 03:04 +0000, Peter Chen wrote: > > > > According to the chipidea driver bindings, the USB PHY is specified via the > > "phys" > > > > phandle node. However, this only takes effect for USB PHYs that use > > > > the common PHY framework. For legacy USB PHYs, a simple lookup based > > > > on the USB PHY type is done instead. > > > > > > > > This does not play out well when more than one USB PHY is > > > > registered, since the first registered PHY matching the type will > > > > always be returned regardless of what the driver was bound to. > > > > > > > > Fix this by looking up the PHY based on the "phys" phandle node. > > > > Although generic PHYs are rather matched by their "phys-name" and not the > > "phys" > > > > phandle directly, there is no helper for similar lookup on legacy > > > > PHYs and it's probably not worth the effort to add it. > > > > > > > > When no legacy USB PHY is found by phandle, fallback to grabbing any > > > > registered > > > > USB2 PHY. This ensures backward compatibility if some users were > > > > actually relying on this mechanism. > > > > > > > > Signed-off-by: Paul Kocialkowski > > > > --- > > > > Changes since v2: > > > > * Fixed typos in commit message. > > > > > > > > Changes since v1: > > > > * Only consider legacy USB PHY error for fallback as suggested; > > > > * Checked against EPROBE_DEFER before entering fallback. > > > > > > > > drivers/usb/chipidea/core.c | 9 ++++++++- > > > > 1 file changed, 8 insertions(+), 1 deletion(-) > > > > > > > > diff --git a/drivers/usb/chipidea/core.c > > > > b/drivers/usb/chipidea/core.c index 7bfcbb23c2a4..016e4004fe9d > > > > 100644 > > > > --- a/drivers/usb/chipidea/core.c > > > > +++ b/drivers/usb/chipidea/core.c > > > > @@ -954,8 +954,15 @@ static int ci_hdrc_probe(struct platform_device *pdev) > > > > } else if (ci->platdata->usb_phy) { > > > > ci->usb_phy = ci->platdata->usb_phy; > > > > } else { > > > > + ci->usb_phy = devm_usb_get_phy_by_phandle(dev->parent, "phys", > > > > + 0); > > > > ci->phy = devm_phy_get(dev->parent, "usb-phy"); > > > > - ci->usb_phy = devm_usb_get_phy(dev->parent, > > > > USB_PHY_TYPE_USB2); > > > > + > > > > + /* Fallback to grabbing any registered USB2 PHY */ > > > > + if (IS_ERR(ci->usb_phy) && > > > > + PTR_ERR(ci->usb_phy) != -EPROBE_DEFER) > > > > + ci->usb_phy = devm_usb_get_phy(dev->parent, > > > > + USB_PHY_TYPE_USB2); > > > > > > > > > > I think you may need to do above if ci->phy is error, and not the error is - > > EPROBE_DEFER. > > > > As Thomas pointed out during the review of v1, the initial flow is to try and get both > > ci->usb_phy and ci->phy and let the code use ci->phy in priority later. > > > > If there is a generic PHY node under USB controller, and there is a USB PHY > at other sides, both ci->phy and ci->usb_phy are valid, I original thought it is > the problem you met. Right, this is not the problem we are having. The problem is that legacy USB PHYs are not grabbed from device-tree. Instead, they are currently matched with their type in the list of registered USB PHYs, making it impossible to use 2 distinct USB PHYs this way. > Since you are trying to fix the legacy USB PHY grab issue, I hope you could consider > the generic PHY as well. What do you have in mind about generic PHYs? Everything already works as expected with them. Cheers, Paul > > This change attempts to keep this flow intact. The EPROBE_DEFER check is in > > case the initial ci->usb_phy is valid but deferred: we don't want to overwrite it by > > calling devm_usb_get_phy which might return an actual error and result in losing > > the EPROBE_DEFER information. > > > > Does that make sense to you? > > > > Cheers, > > > > Paul > > > > > Peter > > > > > > > /* if both generic PHY and USB PHY layers aren't enabled */ > > > > if (PTR_ERR(ci->phy) == -ENOSYS && > > > > -- > > > > 2.20.1 > > -- > > Paul Kocialkowski, Bootlin > > Embedded Linux and kernel engineering > > https://emea01.safelinks.protection.outlook.com/?url=https%3A%2F%2Fbootlin.com > > &data=02%7C01%7Cpeter.chen%40nxp.com%7Cadca65357daa4fe678dc08d > > 6957b9c49%7C686ea1d3bc2b4c6fa92cd99c5c301635%7C0%7C0%7C6368607554 > > 66805805&sdata=c%2FdLqUhFxe1yz7lrqUoXZCvINiq1rdKJmMAuaH6Fr1k%3 > > D&reserved=0 -- Paul Kocialkowski, Bootlin Embedded Linux and kernel engineering https://bootlin.com