Received: by 2002:ac0:946b:0:0:0:0:0 with SMTP id j40csp2150670imj; Mon, 18 Feb 2019 00:33:40 -0800 (PST) X-Google-Smtp-Source: AHgI3Ia4dAXJe/T25hADH1VhNTJHDQKbm6GRsyJSLnqBmcRIvhor8VQiJMHBAHMYr+bAMdB6B8eq X-Received: by 2002:a17:902:4503:: with SMTP id m3mr24084666pld.35.1550478820785; Mon, 18 Feb 2019 00:33:40 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1550478820; cv=none; d=google.com; s=arc-20160816; b=A2dS9xfjR4NpxlqWyXn0XwbUa4StYZgB2njqFEuQVFk1SbbZC59AG7/8JpblIH+Xny wS6ClXW//a42/VPFCzzqBrq9xNNVil1RB71XjOTOD0GuRU+r2TIffoGUN+T/Ow5Sznuw rqs86chun1AIsHwIS9j1odnP2mUCIHCnrVDq6ezhONJg8IcWDTvrd0aUrB7nxtWPmMUs PKPIOmCP1nKCSvtCDrbE89Cb10XS5lMima9tnOIhnSzvV1e09CDK8MtuD7NoNeIkHXFv S5YSPGbkLcb/Hfd+1JQ7sJQ2byn0hOSqWjSqJ2b1AkzMSCaoB9iN2hc+dB88v9UVbRqx xACw== 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=VR5sRObFFSNfD/2g41CDA+kjxeM0Brg8fuFNM/QBaEY=; b=oGp1v+MxzINWD5zeHCw6hqrZia9EqC9S2az+S5qF7Lz7zfjamaQPrMamw6KrqeOBVs /PtZoVTfPpsmXUG9UWz+T9YGev0LH1qlDrkqsnT9akshEnM9yLWSWq718IZw3nvMuuXr 4pyVI7vuJSXCssHrQ+IlvOL7HdVjxpofMXOcmsZ5N1XpgMKxWn97IZbykxatySSD2n3h FSofgF/8kz7W9074s2/dVNf6Lj4Yk6GTMH+6N+49l+SwoQ4OOAmeFvaBo/Ps8HW1FGHp GufubzcbA+NrY7u5e5recwug24hJUVNm305EzER+e+nGOCiLmTUqwB7nGNLP9ABieMtg UY0A== 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 s32si10091444pga.48.2019.02.18.00.33.25; Mon, 18 Feb 2019 00:33:40 -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 S1729287AbfBRIc3 (ORCPT + 99 others); Mon, 18 Feb 2019 03:32:29 -0500 Received: from relay2-d.mail.gandi.net ([217.70.183.194]:43249 "EHLO relay2-d.mail.gandi.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728342AbfBRIc3 (ORCPT ); Mon, 18 Feb 2019 03:32:29 -0500 X-Originating-IP: 90.88.30.68 Received: from aptenodytes (aaubervilliers-681-1-89-68.w90-88.abo.wanadoo.fr [90.88.30.68]) (Authenticated sender: paul.kocialkowski@bootlin.com) by relay2-d.mail.gandi.net (Postfix) with ESMTPSA id 1DE9340005; Mon, 18 Feb 2019 08:32:23 +0000 (UTC) Message-ID: 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: Mon, 18 Feb 2019 09:32:23 +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 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. 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://bootlin.com