return -ENXIO;
        }
 
+       cdns->phyrst_a_enable = device_property_read_bool(dev, "cdns,phyrst-a-enable");
+
        cdns->otg_res = *res;
 
        cdns->wakeup_irq = platform_get_irq_byname_optional(pdev, "wakeup");
 
                        reg = readl(&cdns->otg_v1_regs->override);
                        reg |= OVERRIDE_IDPULLUP;
                        writel(reg, &cdns->otg_v1_regs->override);
+
+                       /*
+                        * Enable work around feature built into the
+                        * controller to address issue with RX Sensitivity
+                        * est (EL_17) for USB2 PHY. The issue only occures
+                        * for 0x0002450D controller version.
+                        */
+                       if (cdns->phyrst_a_enable) {
+                               reg = readl(&cdns->otg_v1_regs->phyrst_cfg);
+                               reg |= PHYRST_CFG_PHYRST_A_ENABLE;
+                               writel(reg, &cdns->otg_v1_regs->phyrst_cfg);
+                       }
                } else {
                        reg = readl(&cdns->otg_v0_regs->ctrl1);
                        reg |= OVERRIDE_IDPULLUP_V0;
 
        __le32 simulate;
        __le32 override;
        __le32 susp_ctrl;
-       __le32 reserved4;
+       __le32 phyrst_cfg;
        __le32 anasts;
        __le32 adp_ramp_time;
        __le32 ctrl1;
 /* Only for CDNS3_CONTROLLER_V0 version */
 #define OVERRIDE_IDPULLUP_V0           BIT(24)
 
+/* PHYRST_CFG - bitmasks */
+#define PHYRST_CFG_PHYRST_A_ENABLE     BIT(0)
+
 #define CDNS3_ID_PERIPHERAL            1
 #define CDNS3_ID_HOST                  0