u32 top_margin = 100, bottom_margin = 100;
        u16 hsize = hdisplay * (left_margin + right_margin) / 200;
        u16 vsize = vdisplay * (top_margin + bottom_margin) / 200;
+       u16 hsync_len = mode->crtc_hsync_end - mode->crtc_hsync_start;
        u16 hact_end, vact_end;
        u32 val;
+       u32 bg_dly;
+       u32 pre_scan_dly;
+
+       bg_dly = vp->data->pre_scan_max_dly[3];
+       vop2_writel(vp->vop2, RK3568_VP_BG_MIX_CTRL(vp->id),
+                   FIELD_PREP(RK3568_VP_BG_MIX_CTRL__BG_DLY, bg_dly));
+
+       pre_scan_dly = ((bg_dly + (hdisplay >> 1) - 1) << 16) | hsync_len;
+       vop2_vp_write(vp, RK3568_VP_PRE_SCAN_HTIMING, pre_scan_dly);
 
        vsize = rounddown(vsize, 2);
        hsize = rounddown(hsize, 2);
        u32 layer_sel = 0;
        u32 port_sel;
        unsigned int nlayer, ofs;
-       struct drm_display_mode *adjusted_mode;
-       u16 hsync_len;
-       u16 hdisplay;
-       u32 bg_dly;
-       u32 pre_scan_dly;
        u32 ovl_ctrl;
        int i;
        struct vop2_video_port *vp0 = &vop2->vps[0];
        struct vop2_video_port *vp2 = &vop2->vps[2];
        struct rockchip_crtc_state *vcstate = to_rockchip_crtc_state(vp->crtc.state);
 
-       adjusted_mode = &vp->crtc.state->adjusted_mode;
-       hsync_len = adjusted_mode->crtc_hsync_end - adjusted_mode->crtc_hsync_start;
-       hdisplay = adjusted_mode->crtc_hdisplay;
-
-       bg_dly = vp->data->pre_scan_max_dly[3];
-       vop2_writel(vop2, RK3568_VP_BG_MIX_CTRL(vp->id),
-                   FIELD_PREP(RK3568_VP_BG_MIX_CTRL__BG_DLY, bg_dly));
-
-       pre_scan_dly = ((bg_dly + (hdisplay >> 1) - 1) << 16) | hsync_len;
-       vop2_vp_write(vp, RK3568_VP_PRE_SCAN_HTIMING, pre_scan_dly);
-
        ovl_ctrl = vop2_readl(vop2, RK3568_OVL_CTRL);
        ovl_ctrl |= RK3568_OVL_CTRL__LAYERSEL_REGDONE_IMD;
        if (vcstate->yuv_overlay)