struct drm_dp_aux *aux;
        struct dp_panel *panel;
        struct dp_link *link;
-       struct dp_parser *parser;
        struct dp_catalog *catalog;
 
+       struct phy *phy;
+
        unsigned int num_core_clks;
        struct clk_bulk_data *core_clks;
 
        phy_opts->dp.voltage[0] = v_level;
        phy_opts->dp.pre[0] = p_level;
        phy_opts->dp.set_voltages = 1;
-       phy_configure(ctrl->parser->io.phy, phy_opts);
+       phy_configure(ctrl->phy, phy_opts);
        phy_opts->dp.set_voltages = 0;
 
        return 0;
 static int dp_ctrl_enable_mainlink_clocks(struct dp_ctrl_private *ctrl)
 {
        int ret = 0;
-       struct phy *phy = ctrl->parser->io.phy;
+       struct phy *phy = ctrl->phy;
        const u8 *dpcd = ctrl->panel->dpcd;
 
        ctrl->phy_opts.dp.lanes = ctrl->link->link_params.num_lanes;
 void dp_ctrl_phy_init(struct dp_ctrl *dp_ctrl)
 {
        struct dp_ctrl_private *ctrl;
-       struct dp_io *dp_io;
        struct phy *phy;
 
        ctrl = container_of(dp_ctrl, struct dp_ctrl_private, dp_ctrl);
-       dp_io = &ctrl->parser->io;
-       phy = dp_io->phy;
+       phy = ctrl->phy;
 
        dp_catalog_ctrl_phy_reset(ctrl->catalog);
        phy_init(phy);
 void dp_ctrl_phy_exit(struct dp_ctrl *dp_ctrl)
 {
        struct dp_ctrl_private *ctrl;
-       struct dp_io *dp_io;
        struct phy *phy;
 
        ctrl = container_of(dp_ctrl, struct dp_ctrl_private, dp_ctrl);
-       dp_io = &ctrl->parser->io;
-       phy = dp_io->phy;
+       phy = ctrl->phy;
 
        dp_catalog_ctrl_phy_reset(ctrl->catalog);
        phy_exit(phy);
 
 static int dp_ctrl_reinitialize_mainlink(struct dp_ctrl_private *ctrl)
 {
-       struct phy *phy = ctrl->parser->io.phy;
+       struct phy *phy = ctrl->phy;
        int ret = 0;
 
        dp_catalog_ctrl_mainlink_ctrl(ctrl->catalog, false);
 
 static int dp_ctrl_deinitialize_mainlink(struct dp_ctrl_private *ctrl)
 {
-       struct dp_io *dp_io;
        struct phy *phy;
 
-       dp_io = &ctrl->parser->io;
-       phy = dp_io->phy;
+       phy = ctrl->phy;
 
        dp_catalog_ctrl_mainlink_ctrl(ctrl->catalog, false);
 
 void dp_ctrl_off_link_stream(struct dp_ctrl *dp_ctrl)
 {
        struct dp_ctrl_private *ctrl;
-       struct dp_io *dp_io;
        struct phy *phy;
 
        ctrl = container_of(dp_ctrl, struct dp_ctrl_private, dp_ctrl);
-       dp_io = &ctrl->parser->io;
-       phy = dp_io->phy;
+       phy = ctrl->phy;
 
        /* set dongle to D3 (power off) mode */
        dp_link_psm_config(ctrl->link, &ctrl->panel->link_info, true);
 void dp_ctrl_off_link(struct dp_ctrl *dp_ctrl)
 {
        struct dp_ctrl_private *ctrl;
-       struct dp_io *dp_io;
        struct phy *phy;
 
        ctrl = container_of(dp_ctrl, struct dp_ctrl_private, dp_ctrl);
-       dp_io = &ctrl->parser->io;
-       phy = dp_io->phy;
+       phy = ctrl->phy;
 
        dp_catalog_ctrl_mainlink_ctrl(ctrl->catalog, false);
 
 void dp_ctrl_off(struct dp_ctrl *dp_ctrl)
 {
        struct dp_ctrl_private *ctrl;
-       struct dp_io *dp_io;
        struct phy *phy;
 
        ctrl = container_of(dp_ctrl, struct dp_ctrl_private, dp_ctrl);
-       dp_io = &ctrl->parser->io;
-       phy = dp_io->phy;
+       phy = ctrl->phy;
 
        dp_catalog_ctrl_mainlink_ctrl(ctrl->catalog, false);
 
 struct dp_ctrl *dp_ctrl_get(struct device *dev, struct dp_link *link,
                        struct dp_panel *panel, struct drm_dp_aux *aux,
                        struct dp_catalog *catalog,
-                       struct dp_parser *parser)
+                       struct phy *phy)
 {
        struct dp_ctrl_private *ctrl;
        int ret;
        init_completion(&ctrl->video_comp);
 
        /* in parameters */
-       ctrl->parser   = parser;
        ctrl->panel    = panel;
        ctrl->aux      = aux;
        ctrl->link     = link;
        ctrl->catalog  = catalog;
        ctrl->dev      = dev;
+       ctrl->phy      = phy;
 
        ret = dp_ctrl_clk_init(&ctrl->dp_ctrl);
        if (ret) {