On 05/12/2017 07:27 PM, patrice.chot...@st.com wrote: > From: Patrice Chotard <patrice.chot...@st.com> > > Add support of generic PHY framework > > Signed-off-by: Patrice Chotard <patrice.chot...@st.com> > --- > > v2: _ split previous path 1, add generic PHY framework > > drivers/usb/host/ehci-generic.c | 11 +++++++++++ > 1 file changed, 11 insertions(+) > > diff --git a/drivers/usb/host/ehci-generic.c b/drivers/usb/host/ehci-generic.c > index 0c29f63..0000808 100644 > --- a/drivers/usb/host/ehci-generic.c > +++ b/drivers/usb/host/ehci-generic.c > @@ -6,6 +6,8 @@ > > #include <common.h> > #include <clk.h> > +#include <fdtdec.h> > +#include <generic-phy.h> > #include <reset.h> > #include <asm/io.h> > #include <dm.h> > @@ -23,6 +25,7 @@ struct generic_ehci { > struct ehci_ctrl ctrl; > struct clk clks[EHCI_MAX_CLOCKS]; > struct reset_ctl resets[EHCI_MAX_RESETS]; > + struct phy phy; > }; > > static void ehci_assert_resets(struct udevice *dev) { > @@ -92,6 +95,10 @@ static int ehci_usb_probe(struct udevice *dev) > reset_free(&reset); > } > > + if (!generic_phy_get_by_index(dev, 0, &priv->phy)) > + if (generic_phy_init(&priv->phy)) > + error("failed to init usb phy %d\n", i); > + > hccr = map_physmem(dev_get_addr(dev), 0x100, MAP_NOCACHE); > hcor = (struct ehci_hcor *)((uintptr_t)hccr + > HC_LENGTH(ehci_readl(&hccr->cr_capbase))); > @@ -100,6 +107,8 @@ static int ehci_usb_probe(struct udevice *dev) > if (!ret) > return ret; > > + generic_phy_exit(&priv->phy);
So you probe the EHCI controller driver and then you disable it's PHY ? That's a bit odd, isn't it ? > reset_err: > ehci_assert_resets(dev); > clk_err: > @@ -109,7 +118,9 @@ clk_err: > } > > static int ehci_usb_remove(struct udevice *dev) { > + struct generic_ehci *priv = dev_get_priv(dev); > > + generic_phy_exit(&priv->phy); > ehci_assert_resets(dev); > ehci_disable_clocks(dev); > > -- Best regards, Marek Vasut _______________________________________________ U-Boot mailing list U-Boot@lists.denx.de https://lists.denx.de/listinfo/u-boot