struct mt65xx_phy_instance {
        struct phy *phy;
        void __iomem *port_base;
+       struct clk *ref_clk;    /* reference clock of anolog phy */
        u32 index;
        u8 type;
 };
 struct mt65xx_u3phy {
        struct device *dev;
        void __iomem *sif_base; /* only shared sif */
+       /* deprecated, use @ref_clk instead in phy instance */
        struct clk *u3phya_ref; /* reference clock of usb3 anolog phy */
        const struct mt65xx_phy_pdata *pdata;
        struct mt65xx_phy_instance **phys;
                return ret;
        }
 
+       ret = clk_prepare_enable(instance->ref_clk);
+       if (ret) {
+               dev_err(u3phy->dev, "failed to enable ref_clk\n");
+               return ret;
+       }
+
        if (instance->type == PHY_TYPE_USB2)
                phy_instance_init(u3phy, instance);
        else
        if (instance->type == PHY_TYPE_USB2)
                phy_instance_exit(u3phy, instance);
 
+       clk_disable_unprepare(instance->ref_clk);
        clk_disable_unprepare(u3phy->u3phya_ref);
        return 0;
 }
                return PTR_ERR(u3phy->sif_base);
        }
 
+       /* it's deprecated, make it optional for backward compatibility */
        u3phy->u3phya_ref = devm_clk_get(dev, "u3phya_ref");
        if (IS_ERR(u3phy->u3phya_ref)) {
-               dev_err(dev, "error to get u3phya_ref\n");
-               return PTR_ERR(u3phy->u3phya_ref);
+               if (PTR_ERR(u3phy->u3phya_ref) == -EPROBE_DEFER)
+                       return -EPROBE_DEFER;
+
+               u3phy->u3phya_ref = NULL;
        }
 
        port = 0;
                instance->index = port;
                phy_set_drvdata(phy, instance);
                port++;
+
+               /* if deprecated clock is provided, ignore instance's one */
+               if (u3phy->u3phya_ref)
+                       continue;
+
+               instance->ref_clk = devm_clk_get(&phy->dev, "ref");
+               if (IS_ERR(instance->ref_clk)) {
+                       dev_err(dev, "failed to get ref_clk(id-%d)\n", port);
+                       retval = PTR_ERR(instance->ref_clk);
+                       goto put_child;
+               }
        }
 
        provider = devm_of_phy_provider_register(dev, mt65xx_phy_xlate);