*/
 
 #include <linux/delay.h>
+#include <linux/phy/phy.h>
 #include <drm/drm_print.h>
 
 #include "dp_reg.h"
        struct device *dev;
        struct dp_catalog *catalog;
 
+       struct phy *phy;
+
        struct mutex mutex;
        struct completion comp;
 
                if (aux->native) {
                        aux->retry_cnt++;
                        if (!(aux->retry_cnt % MAX_AUX_RETRIES))
-                               dp_catalog_aux_update_cfg(aux->catalog);
+                               phy_calibrate(aux->phy);
                }
                /* reset aux if link is in connected state */
                if (dp_catalog_link_is_connected(aux->catalog))
 
        aux = container_of(dp_aux, struct dp_aux_private, dp_aux);
 
-       dp_catalog_aux_update_cfg(aux->catalog);
+       phy_calibrate(aux->phy);
        dp_catalog_aux_reset(aux->catalog);
 }
 
 }
 
 struct drm_dp_aux *dp_aux_get(struct device *dev, struct dp_catalog *catalog,
+                             struct phy *phy,
                              bool is_edp)
 {
        struct dp_aux_private *aux;
 
        aux->dev = dev;
        aux->catalog = catalog;
+       aux->phy = phy;
        aux->retry_cnt = 0;
 
        /*
 
 void dp_aux_reconfig(struct drm_dp_aux *dp_aux);
 
 struct drm_dp_aux *dp_aux_get(struct device *dev, struct dp_catalog *catalog,
+                             struct phy *phy,
                              bool is_edp);
 void dp_aux_put(struct drm_dp_aux *aux);
 
 
 
 #include <linux/delay.h>
 #include <linux/iopoll.h>
-#include <linux/phy/phy.h>
-#include <linux/phy/phy-dp.h>
 #include <linux/rational.h>
 #include <drm/display/drm_dp_helper.h>
 #include <drm/drm_print.h>
        dp_write_aux(catalog, REG_DP_AUX_CTRL, aux_ctrl);
 }
 
-void dp_catalog_aux_update_cfg(struct dp_catalog *dp_catalog)
-{
-       struct dp_catalog_private *catalog = container_of(dp_catalog,
-                               struct dp_catalog_private, dp_catalog);
-       struct dp_io *dp_io = catalog->io;
-       struct phy *phy = dp_io->phy;
-
-       phy_calibrate(phy);
-}
-
 int dp_catalog_aux_wait_for_hpd_connect_state(struct dp_catalog *dp_catalog)
 {
        u32 state;
 
 int dp_catalog_aux_clear_hw_interrupts(struct dp_catalog *dp_catalog);
 void dp_catalog_aux_reset(struct dp_catalog *dp_catalog);
 void dp_catalog_aux_enable(struct dp_catalog *dp_catalog, bool enable);
-void dp_catalog_aux_update_cfg(struct dp_catalog *dp_catalog);
 int dp_catalog_aux_wait_for_hpd_connect_state(struct dp_catalog *dp_catalog);
 u32 dp_catalog_aux_get_irq(struct dp_catalog *dp_catalog);
 
 
                goto error;
        }
 
-       dp->aux = dp_aux_get(dev, dp->catalog, dp->dp_display.is_edp);
+       dp->aux = dp_aux_get(dev, dp->catalog,
+                            dp->parser->io.phy,
+                            dp->dp_display.is_edp);
        if (IS_ERR(dp->aux)) {
                rc = PTR_ERR(dp->aux);
                DRM_ERROR("failed to initialize aux, rc = %d\n", rc);