From: "Peter Chen (CIX)" <peter.chen@kernel.org>
To: Svyatoslav Ryhel <clamor95@gmail.com>
Cc: Andrew Lunn <andrew+netdev@lunn.ch>,
"David S. Miller" <davem@davemloft.net>,
Eric Dumazet <edumazet@google.com>,
Jakub Kicinski <kuba@kernel.org>, Paolo Abeni <pabeni@redhat.com>,
Rob Herring <robh@kernel.org>,
Krzysztof Kozlowski <krzk+dt@kernel.org>,
Conor Dooley <conor+dt@kernel.org>, Vinod Koul <vkoul@kernel.org>,
Neil Armstrong <neil.armstrong@linaro.org>,
Thierry Reding <thierry.reding@kernel.org>,
Jonathan Hunter <jonathanh@nvidia.com>,
Greg Kroah-Hartman <gregkh@linuxfoundation.org>,
netdev@vger.kernel.org, devicetree@vger.kernel.org,
linux-kernel@vger.kernel.org, linux-phy@lists.infradead.org,
linux-tegra@vger.kernel.org, linux-usb@vger.kernel.org
Subject: Re: [PATCH v1 2/6] usb: chipidea: tegra: Avoid controller/PHY init if bus is externally controlled
Date: Tue, 12 May 2026 15:51:06 +0800 [thread overview]
Message-ID: <agLb6mgP45jHjvNt@nchen-desktop> (raw)
In-Reply-To: <CAPVz0n173syW9rXy7Qt_N=mChe6WBRLvjRDypcJEC50hPL4OMQ@mail.gmail.com>
On 26-05-12 09:13:40, Svyatoslav Ryhel wrote:
> вт, 12 трав. 2026 р. о 04:16 Peter Chen (CIX) <peter.chen@kernel.org> пише:
> >
> > On 26-05-11 16:56:57, Svyatoslav Ryhel wrote:
> > > If the USB controller and PHY are externally controlled, then the
> > > registration of the controller and the PHY initialization should be
> > > skipped, since these configurations must be done by the device that
> > > controls the bus to work correctly.
> > >
> >
> > I find you only control USB controller device add at PHY driver, most of USB drivers
> > has PHY control, for chipidea, it has PHY control at core.c, would please try to
> > adapt for it?
> >
>
> Usually yes, but this is not the case for Tegra unfortunately. As you
> can see Tegra specific section of Chipidea driver specifically
> describes why it has to set PHY manually.
>
> /*
> * USB controller registers shouldn't be touched before PHY is
> * initialized, otherwise CPU will hang because clocks are gated.
> * PHY driver controls gating of internal USB clocks on Tegra.
> */
>
> So in order to provide correct work of USB when set by an external
> device, both PHY and controller init/add must be skipped.
You could call generic PHY APIs at ci_hdrc_tegra.c, after PHY init or power on,
call controller initialization.
>
> > Peter
> >
> > > Signed-off-by: Svyatoslav Ryhel <clamor95@gmail.com>
> > > ---
> > > drivers/usb/chipidea/ci_hdrc_tegra.c | 36 +++++++++++++++++-----------
> > > 1 file changed, 22 insertions(+), 14 deletions(-)
> > >
> > > diff --git a/drivers/usb/chipidea/ci_hdrc_tegra.c b/drivers/usb/chipidea/ci_hdrc_tegra.c
> > > index 372788f0f970..593390a818d1 100644
> > > --- a/drivers/usb/chipidea/ci_hdrc_tegra.c
> > > +++ b/drivers/usb/chipidea/ci_hdrc_tegra.c
> > > @@ -32,6 +32,7 @@ struct tegra_usb {
> > > struct clk *clk;
> > >
> > > bool needs_double_reset;
> > > + bool externally_controlled;
> > > };
> > >
> > > struct tegra_usb_soc_info {
> > > @@ -312,20 +313,25 @@ static int tegra_usb_probe(struct platform_device *pdev)
> > > if (device_property_present(&pdev->dev, "nvidia,needs-double-reset"))
> > > usb->needs_double_reset = true;
> > >
> > > + if (device_property_present(&pdev->dev, "nvidia,external-control"))
> > > + usb->externally_controlled = true;
> > > +
> > > err = tegra_usb_reset_controller(&pdev->dev);
> > > if (err) {
> > > dev_err_probe(&pdev->dev, err, "failed to reset controller");
> > > goto fail_power_off;
> > > }
> > >
> > > - /*
> > > - * USB controller registers shouldn't be touched before PHY is
> > > - * initialized, otherwise CPU will hang because clocks are gated.
> > > - * PHY driver controls gating of internal USB clocks on Tegra.
> > > - */
> > > - err = usb_phy_init(usb->phy);
> > > - if (err)
> > > - goto fail_power_off;
> > > + if (!usb->externally_controlled) {
> > > + /*
> > > + * USB controller registers shouldn't be touched before PHY is
> > > + * initialized, otherwise CPU will hang because clocks are gated.
> > > + * PHY driver controls gating of internal USB clocks on Tegra.
> > > + */
> > > + err = usb_phy_init(usb->phy);
> > > + if (err)
> > > + goto fail_power_off;
> > > + }
> > >
> > > /* setup and register ChipIdea HDRC device */
> > > usb->soc = soc;
> > > @@ -342,12 +348,14 @@ static int tegra_usb_probe(struct platform_device *pdev)
> > > if (of_usb_get_phy_mode(pdev->dev.of_node) == USBPHY_INTERFACE_MODE_ULPI)
> > > usb->data.flags &= ~CI_HDRC_SUPPORTS_RUNTIME_PM;
> > >
> > > - usb->dev = ci_hdrc_add_device(&pdev->dev, pdev->resource,
> > > - pdev->num_resources, &usb->data);
> > > - if (IS_ERR(usb->dev)) {
> > > - err = dev_err_probe(&pdev->dev, PTR_ERR(usb->dev),
> > > - "failed to add HDRC device");
> > > - goto phy_shutdown;
> > > + if (!usb->externally_controlled) {
> > > + usb->dev = ci_hdrc_add_device(&pdev->dev, pdev->resource,
> > > + pdev->num_resources, &usb->data);
> > > + if (IS_ERR(usb->dev)) {
> > > + err = dev_err_probe(&pdev->dev, PTR_ERR(usb->dev),
> > > + "failed to add HDRC device");
> > > + goto phy_shutdown;
> > > + }
> > > }
> > >
> > > return 0;
> > > --
> > > 2.51.0
> > >
> >
> > --
> >
> > Best regards,
> > Peter
--
Best regards,
Peter
WARNING: multiple messages have this Message-ID (diff)
From: "Peter Chen (CIX)" <peter.chen@kernel.org>
To: Svyatoslav Ryhel <clamor95@gmail.com>
Cc: Andrew Lunn <andrew+netdev@lunn.ch>,
"David S. Miller" <davem@davemloft.net>,
Eric Dumazet <edumazet@google.com>,
Jakub Kicinski <kuba@kernel.org>, Paolo Abeni <pabeni@redhat.com>,
Rob Herring <robh@kernel.org>,
Krzysztof Kozlowski <krzk+dt@kernel.org>,
Conor Dooley <conor+dt@kernel.org>, Vinod Koul <vkoul@kernel.org>,
Neil Armstrong <neil.armstrong@linaro.org>,
Thierry Reding <thierry.reding@kernel.org>,
Jonathan Hunter <jonathanh@nvidia.com>,
Greg Kroah-Hartman <gregkh@linuxfoundation.org>,
netdev@vger.kernel.org, devicetree@vger.kernel.org,
linux-kernel@vger.kernel.org, linux-phy@lists.infradead.org,
linux-tegra@vger.kernel.org, linux-usb@vger.kernel.org
Subject: Re: [PATCH v1 2/6] usb: chipidea: tegra: Avoid controller/PHY init if bus is externally controlled
Date: Tue, 12 May 2026 15:51:06 +0800 [thread overview]
Message-ID: <agLb6mgP45jHjvNt@nchen-desktop> (raw)
In-Reply-To: <CAPVz0n173syW9rXy7Qt_N=mChe6WBRLvjRDypcJEC50hPL4OMQ@mail.gmail.com>
On 26-05-12 09:13:40, Svyatoslav Ryhel wrote:
> вт, 12 трав. 2026 р. о 04:16 Peter Chen (CIX) <peter.chen@kernel.org> пише:
> >
> > On 26-05-11 16:56:57, Svyatoslav Ryhel wrote:
> > > If the USB controller and PHY are externally controlled, then the
> > > registration of the controller and the PHY initialization should be
> > > skipped, since these configurations must be done by the device that
> > > controls the bus to work correctly.
> > >
> >
> > I find you only control USB controller device add at PHY driver, most of USB drivers
> > has PHY control, for chipidea, it has PHY control at core.c, would please try to
> > adapt for it?
> >
>
> Usually yes, but this is not the case for Tegra unfortunately. As you
> can see Tegra specific section of Chipidea driver specifically
> describes why it has to set PHY manually.
>
> /*
> * USB controller registers shouldn't be touched before PHY is
> * initialized, otherwise CPU will hang because clocks are gated.
> * PHY driver controls gating of internal USB clocks on Tegra.
> */
>
> So in order to provide correct work of USB when set by an external
> device, both PHY and controller init/add must be skipped.
You could call generic PHY APIs at ci_hdrc_tegra.c, after PHY init or power on,
call controller initialization.
>
> > Peter
> >
> > > Signed-off-by: Svyatoslav Ryhel <clamor95@gmail.com>
> > > ---
> > > drivers/usb/chipidea/ci_hdrc_tegra.c | 36 +++++++++++++++++-----------
> > > 1 file changed, 22 insertions(+), 14 deletions(-)
> > >
> > > diff --git a/drivers/usb/chipidea/ci_hdrc_tegra.c b/drivers/usb/chipidea/ci_hdrc_tegra.c
> > > index 372788f0f970..593390a818d1 100644
> > > --- a/drivers/usb/chipidea/ci_hdrc_tegra.c
> > > +++ b/drivers/usb/chipidea/ci_hdrc_tegra.c
> > > @@ -32,6 +32,7 @@ struct tegra_usb {
> > > struct clk *clk;
> > >
> > > bool needs_double_reset;
> > > + bool externally_controlled;
> > > };
> > >
> > > struct tegra_usb_soc_info {
> > > @@ -312,20 +313,25 @@ static int tegra_usb_probe(struct platform_device *pdev)
> > > if (device_property_present(&pdev->dev, "nvidia,needs-double-reset"))
> > > usb->needs_double_reset = true;
> > >
> > > + if (device_property_present(&pdev->dev, "nvidia,external-control"))
> > > + usb->externally_controlled = true;
> > > +
> > > err = tegra_usb_reset_controller(&pdev->dev);
> > > if (err) {
> > > dev_err_probe(&pdev->dev, err, "failed to reset controller");
> > > goto fail_power_off;
> > > }
> > >
> > > - /*
> > > - * USB controller registers shouldn't be touched before PHY is
> > > - * initialized, otherwise CPU will hang because clocks are gated.
> > > - * PHY driver controls gating of internal USB clocks on Tegra.
> > > - */
> > > - err = usb_phy_init(usb->phy);
> > > - if (err)
> > > - goto fail_power_off;
> > > + if (!usb->externally_controlled) {
> > > + /*
> > > + * USB controller registers shouldn't be touched before PHY is
> > > + * initialized, otherwise CPU will hang because clocks are gated.
> > > + * PHY driver controls gating of internal USB clocks on Tegra.
> > > + */
> > > + err = usb_phy_init(usb->phy);
> > > + if (err)
> > > + goto fail_power_off;
> > > + }
> > >
> > > /* setup and register ChipIdea HDRC device */
> > > usb->soc = soc;
> > > @@ -342,12 +348,14 @@ static int tegra_usb_probe(struct platform_device *pdev)
> > > if (of_usb_get_phy_mode(pdev->dev.of_node) == USBPHY_INTERFACE_MODE_ULPI)
> > > usb->data.flags &= ~CI_HDRC_SUPPORTS_RUNTIME_PM;
> > >
> > > - usb->dev = ci_hdrc_add_device(&pdev->dev, pdev->resource,
> > > - pdev->num_resources, &usb->data);
> > > - if (IS_ERR(usb->dev)) {
> > > - err = dev_err_probe(&pdev->dev, PTR_ERR(usb->dev),
> > > - "failed to add HDRC device");
> > > - goto phy_shutdown;
> > > + if (!usb->externally_controlled) {
> > > + usb->dev = ci_hdrc_add_device(&pdev->dev, pdev->resource,
> > > + pdev->num_resources, &usb->data);
> > > + if (IS_ERR(usb->dev)) {
> > > + err = dev_err_probe(&pdev->dev, PTR_ERR(usb->dev),
> > > + "failed to add HDRC device");
> > > + goto phy_shutdown;
> > > + }
> > > }
> > >
> > > return 0;
> > > --
> > > 2.51.0
> > >
> >
> > --
> >
> > Best regards,
> > Peter
--
Best regards,
Peter
--
linux-phy mailing list
linux-phy@lists.infradead.org
https://lists.infradead.org/mailman/listinfo/linux-phy
next prev parent reply other threads:[~2026-05-12 7:51 UTC|newest]
Thread overview: 62+ messages / expand[flat|nested] mbox.gz Atom feed top
2026-05-11 13:56 [PATCH v1 0/6] Add support for Infineon/Intel XMM6260 modem Svyatoslav Ryhel
2026-05-11 13:56 ` Svyatoslav Ryhel
2026-05-11 13:56 ` [PATCH v1 1/6] dt-bindings: usb: ci-hdrc-usb2: Document nvidia,external-control property Svyatoslav Ryhel
2026-05-11 13:56 ` Svyatoslav Ryhel
2026-05-12 23:29 ` sashiko-bot
2026-05-12 23:29 ` sashiko-bot
2026-05-13 17:34 ` Svyatoslav Ryhel
2026-05-13 17:34 ` Svyatoslav Ryhel
2026-05-15 8:15 ` Krzysztof Kozlowski
2026-05-15 8:15 ` Krzysztof Kozlowski
2026-05-11 13:56 ` [PATCH v1 2/6] usb: chipidea: tegra: Avoid controller/PHY init if bus is externally controlled Svyatoslav Ryhel
2026-05-11 13:56 ` Svyatoslav Ryhel
2026-05-12 1:15 ` Peter Chen (CIX)
2026-05-12 1:15 ` Peter Chen (CIX)
2026-05-12 6:13 ` Svyatoslav Ryhel
2026-05-12 6:13 ` Svyatoslav Ryhel
2026-05-12 7:51 ` Peter Chen (CIX) [this message]
2026-05-12 7:51 ` Peter Chen (CIX)
2026-05-12 9:14 ` Svyatoslav Ryhel
2026-05-12 9:14 ` Svyatoslav Ryhel
2026-05-13 17:30 ` Svyatoslav Ryhel
2026-05-13 17:30 ` Svyatoslav Ryhel
2026-05-14 1:42 ` Peter Chen (CIX)
2026-05-14 1:42 ` Peter Chen (CIX)
2026-05-12 23:29 ` sashiko-bot
2026-05-12 23:29 ` sashiko-bot
2026-05-11 13:56 ` [PATCH v1 3/6] dt-bindings: net: Document Infineon/Intel XMM6260 modem Svyatoslav Ryhel
2026-05-11 13:56 ` Svyatoslav Ryhel
2026-05-12 23:29 ` sashiko-bot
2026-05-12 23:29 ` sashiko-bot
2026-05-15 8:18 ` Krzysztof Kozlowski
2026-05-15 8:18 ` Krzysztof Kozlowski
2026-05-15 8:39 ` Svyatoslav Ryhel
2026-05-15 8:39 ` Svyatoslav Ryhel
2026-05-18 12:04 ` Krzysztof Kozlowski
2026-05-18 12:04 ` Krzysztof Kozlowski
2026-05-11 13:56 ` [PATCH v1 4/6] net: usb: Add Infineon XMM6260 Baseband modem support Svyatoslav Ryhel
2026-05-11 13:56 ` Svyatoslav Ryhel
2026-05-12 23:29 ` sashiko-bot
2026-05-12 23:29 ` sashiko-bot
2026-05-11 13:57 ` [PATCH v1 5/6] dt-bindings: phy: tegra: Document Nvidia Tegra XMM6260 PHY Svyatoslav Ryhel
2026-05-11 13:57 ` Svyatoslav Ryhel
2026-05-12 23:29 ` sashiko-bot
2026-05-12 23:29 ` sashiko-bot
2026-05-15 8:20 ` Krzysztof Kozlowski
2026-05-15 8:20 ` Krzysztof Kozlowski
2026-05-15 8:37 ` Svyatoslav Ryhel
2026-05-15 8:37 ` Svyatoslav Ryhel
2026-05-18 12:14 ` Krzysztof Kozlowski
2026-05-18 12:14 ` Krzysztof Kozlowski
2026-05-18 12:23 ` Svyatoslav Ryhel
2026-05-18 12:23 ` Svyatoslav Ryhel
2026-05-19 6:14 ` Svyatoslav Ryhel
2026-05-19 6:14 ` Svyatoslav Ryhel
2026-05-11 13:57 ` [PATCH v1 6/6] phy: tegra: Add support for " Svyatoslav Ryhel
2026-05-11 13:57 ` Svyatoslav Ryhel
2026-05-12 23:29 ` sashiko-bot
2026-05-12 23:29 ` sashiko-bot
2026-05-12 0:05 ` [PATCH v1 0/6] Add support for Infineon/Intel XMM6260 modem Jakub Kicinski
2026-05-12 0:05 ` Jakub Kicinski
2026-05-12 6:05 ` Svyatoslav Ryhel
2026-05-12 6:05 ` Svyatoslav Ryhel
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=agLb6mgP45jHjvNt@nchen-desktop \
--to=peter.chen@kernel.org \
--cc=andrew+netdev@lunn.ch \
--cc=clamor95@gmail.com \
--cc=conor+dt@kernel.org \
--cc=davem@davemloft.net \
--cc=devicetree@vger.kernel.org \
--cc=edumazet@google.com \
--cc=gregkh@linuxfoundation.org \
--cc=jonathanh@nvidia.com \
--cc=krzk+dt@kernel.org \
--cc=kuba@kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=linux-phy@lists.infradead.org \
--cc=linux-tegra@vger.kernel.org \
--cc=linux-usb@vger.kernel.org \
--cc=neil.armstrong@linaro.org \
--cc=netdev@vger.kernel.org \
--cc=pabeni@redhat.com \
--cc=robh@kernel.org \
--cc=thierry.reding@kernel.org \
--cc=vkoul@kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.