]> git.dujemihanovic.xyz Git - u-boot.git/commitdiff
usb: dwc3: Add support for usb3-phy PHY configuration
authorMichal Simek <michal.simek@xilinx.com>
Wed, 9 Mar 2022 09:05:45 +0000 (10:05 +0100)
committerMarek Vasut <marex@denx.de>
Fri, 22 Apr 2022 08:35:14 +0000 (10:35 +0200)
When usb3-phy label is found, PHY driver is called and serdes line is
initialized. This is preparation for serdes/psgtr driver to configure GT
lines based on description in DT.

Signed-off-by: Michal Simek <michal.simek@xilinx.com>
drivers/usb/dwc3/dwc3-generic.c

index 01bd0ca190e33474ee36c8452b26101d255ab379..2c5205df62cd17a3610215f81c78407d891520f5 100644 (file)
@@ -14,6 +14,7 @@
 #include <dm/device-internal.h>
 #include <dm/lists.h>
 #include <dwc3-uboot.h>
+#include <generic-phy.h>
 #include <linux/bitops.h>
 #include <linux/delay.h>
 #include <linux/usb/ch9.h>
@@ -409,6 +410,17 @@ static int dwc3_glue_probe(struct udevice *dev)
        struct udevice *child = NULL;
        int index = 0;
        int ret;
+       struct phy phy;
+
+       ret = generic_phy_get_by_name(dev, "usb3-phy", &phy);
+       if (!ret) {
+               ret = generic_phy_init(&phy);
+               if (ret)
+                       return ret;
+       } else if (ret != -ENOENT) {
+               debug("could not get phy (err %d)\n", ret);
+               return ret;
+       }
 
        glue->regs = dev_read_addr(dev);
 
@@ -420,6 +432,12 @@ static int dwc3_glue_probe(struct udevice *dev)
        if (ret)
                return ret;
 
+       if (phy.dev) {
+               ret = generic_phy_power_on(&phy);
+               if (ret)
+                       return ret;
+       }
+
        ret = device_find_first_child(dev, &child);
        if (ret)
                return ret;