return POWER_DOMAIN_TRANSCODER_VDSC_PW2;
 }
 
+static int intel_dsc_get_vdsc_per_pipe(const struct intel_crtc_state *crtc_state)
+{
+       return crtc_state->dsc.dsc_split ? 2 : 1;
+}
+
 int intel_dsc_get_num_vdsc_instances(const struct intel_crtc_state *crtc_state)
 {
-       int num_vdsc_instances = (crtc_state->dsc.dsc_split) ? 2 : 1;
+       int num_vdsc_instances = intel_dsc_get_vdsc_per_pipe(crtc_state);
 
        if (crtc_state->bigjoiner_pipes)
                num_vdsc_instances *= 2;
        u32 rc_range_params_dword[8];
        int i = 0;
        int num_vdsc_instances = intel_dsc_get_num_vdsc_instances(crtc_state);
+       int vdsc_instances_per_pipe = intel_dsc_get_vdsc_per_pipe(crtc_state);
 
        /* Populate PICTURE_PARAMETER_SET_0 registers */
        pps_val = DSC_VER_MAJ | vdsc_cfg->dsc_version_minor <<
                 * If 2 VDSC instances are needed, configure PPS for second
                 * VDSC
                 */
-               if (crtc_state->dsc.dsc_split)
+               if (vdsc_instances_per_pipe > 1)
                        intel_de_write(dev_priv, DSCC_PICTURE_PARAMETER_SET_0,
                                       pps_val);
        } else {
                intel_de_write(dev_priv,
                               ICL_DSC0_PICTURE_PARAMETER_SET_0(pipe),
                               pps_val);
-               if (crtc_state->dsc.dsc_split)
+               if (vdsc_instances_per_pipe > 1)
                        intel_de_write(dev_priv,
                                       ICL_DSC1_PICTURE_PARAMETER_SET_0(pipe),
                                       pps_val);
                 * If 2 VDSC instances are needed, configure PPS for second
                 * VDSC
                 */
-               if (crtc_state->dsc.dsc_split)
+               if (vdsc_instances_per_pipe > 1)
                        intel_de_write(dev_priv, DSCC_PICTURE_PARAMETER_SET_1,
                                       pps_val);
        } else {
                intel_de_write(dev_priv,
                               ICL_DSC0_PICTURE_PARAMETER_SET_1(pipe),
                               pps_val);
-               if (crtc_state->dsc.dsc_split)
+               if (vdsc_instances_per_pipe > 1)
                        intel_de_write(dev_priv,
                                       ICL_DSC1_PICTURE_PARAMETER_SET_1(pipe),
                                       pps_val);
                 * If 2 VDSC instances are needed, configure PPS for second
                 * VDSC
                 */
-               if (crtc_state->dsc.dsc_split)
+               if (vdsc_instances_per_pipe > 1)
                        intel_de_write(dev_priv, DSCC_PICTURE_PARAMETER_SET_2,
                                       pps_val);
        } else {
                intel_de_write(dev_priv,
                               ICL_DSC0_PICTURE_PARAMETER_SET_2(pipe),
                               pps_val);
-               if (crtc_state->dsc.dsc_split)
+               if (vdsc_instances_per_pipe > 1)
                        intel_de_write(dev_priv,
                                       ICL_DSC1_PICTURE_PARAMETER_SET_2(pipe),
                                       pps_val);
                 * If 2 VDSC instances are needed, configure PPS for second
                 * VDSC
                 */
-               if (crtc_state->dsc.dsc_split)
+               if (vdsc_instances_per_pipe > 1)
                        intel_de_write(dev_priv, DSCC_PICTURE_PARAMETER_SET_3,
                                       pps_val);
        } else {
                intel_de_write(dev_priv,
                               ICL_DSC0_PICTURE_PARAMETER_SET_3(pipe),
                               pps_val);
-               if (crtc_state->dsc.dsc_split)
+               if (vdsc_instances_per_pipe > 1)
                        intel_de_write(dev_priv,
                                       ICL_DSC1_PICTURE_PARAMETER_SET_3(pipe),
                                       pps_val);
                 * If 2 VDSC instances are needed, configure PPS for second
                 * VDSC
                 */
-               if (crtc_state->dsc.dsc_split)
+               if (vdsc_instances_per_pipe > 1)
                        intel_de_write(dev_priv, DSCC_PICTURE_PARAMETER_SET_4,
                                       pps_val);
        } else {
                intel_de_write(dev_priv,
                               ICL_DSC0_PICTURE_PARAMETER_SET_4(pipe),
                               pps_val);
-               if (crtc_state->dsc.dsc_split)
+               if (vdsc_instances_per_pipe > 1)
                        intel_de_write(dev_priv,
                                       ICL_DSC1_PICTURE_PARAMETER_SET_4(pipe),
                                       pps_val);
                 * If 2 VDSC instances are needed, configure PPS for second
                 * VDSC
                 */
-               if (crtc_state->dsc.dsc_split)
+               if (vdsc_instances_per_pipe > 1)
                        intel_de_write(dev_priv, DSCC_PICTURE_PARAMETER_SET_5,
                                       pps_val);
        } else {
                intel_de_write(dev_priv,
                               ICL_DSC0_PICTURE_PARAMETER_SET_5(pipe),
                               pps_val);
-               if (crtc_state->dsc.dsc_split)
+               if (vdsc_instances_per_pipe > 1)
                        intel_de_write(dev_priv,
                                       ICL_DSC1_PICTURE_PARAMETER_SET_5(pipe),
                                       pps_val);
                 * If 2 VDSC instances are needed, configure PPS for second
                 * VDSC
                 */
-               if (crtc_state->dsc.dsc_split)
+               if (vdsc_instances_per_pipe > 1)
                        intel_de_write(dev_priv, DSCC_PICTURE_PARAMETER_SET_6,
                                       pps_val);
        } else {
                intel_de_write(dev_priv,
                               ICL_DSC0_PICTURE_PARAMETER_SET_6(pipe),
                               pps_val);
-               if (crtc_state->dsc.dsc_split)
+               if (vdsc_instances_per_pipe > 1)
                        intel_de_write(dev_priv,
                                       ICL_DSC1_PICTURE_PARAMETER_SET_6(pipe),
                                       pps_val);
                 * If 2 VDSC instances are needed, configure PPS for second
                 * VDSC
                 */
-               if (crtc_state->dsc.dsc_split)
+               if (vdsc_instances_per_pipe > 1)
                        intel_de_write(dev_priv, DSCC_PICTURE_PARAMETER_SET_7,
                                       pps_val);
        } else {
                intel_de_write(dev_priv,
                               ICL_DSC0_PICTURE_PARAMETER_SET_7(pipe),
                               pps_val);
-               if (crtc_state->dsc.dsc_split)
+               if (vdsc_instances_per_pipe > 1)
                        intel_de_write(dev_priv,
                                       ICL_DSC1_PICTURE_PARAMETER_SET_7(pipe),
                                       pps_val);
                 * If 2 VDSC instances are needed, configure PPS for second
                 * VDSC
                 */
-               if (crtc_state->dsc.dsc_split)
+               if (vdsc_instances_per_pipe > 1)
                        intel_de_write(dev_priv, DSCC_PICTURE_PARAMETER_SET_8,
                                       pps_val);
        } else {
                intel_de_write(dev_priv,
                               ICL_DSC0_PICTURE_PARAMETER_SET_8(pipe),
                               pps_val);
-               if (crtc_state->dsc.dsc_split)
+               if (vdsc_instances_per_pipe > 1)
                        intel_de_write(dev_priv,
                                       ICL_DSC1_PICTURE_PARAMETER_SET_8(pipe),
                                       pps_val);
                 * If 2 VDSC instances are needed, configure PPS for second
                 * VDSC
                 */
-               if (crtc_state->dsc.dsc_split)
+               if (vdsc_instances_per_pipe > 1)
                        intel_de_write(dev_priv, DSCC_PICTURE_PARAMETER_SET_9,
                                       pps_val);
        } else {
                intel_de_write(dev_priv,
                               ICL_DSC0_PICTURE_PARAMETER_SET_9(pipe),
                               pps_val);
-               if (crtc_state->dsc.dsc_split)
+               if (vdsc_instances_per_pipe > 1)
                        intel_de_write(dev_priv,
                                       ICL_DSC1_PICTURE_PARAMETER_SET_9(pipe),
                                       pps_val);
                 * If 2 VDSC instances are needed, configure PPS for second
                 * VDSC
                 */
-               if (crtc_state->dsc.dsc_split)
+               if (vdsc_instances_per_pipe > 1)
                        intel_de_write(dev_priv,
                                       DSCC_PICTURE_PARAMETER_SET_10, pps_val);
        } else {
                intel_de_write(dev_priv,
                               ICL_DSC0_PICTURE_PARAMETER_SET_10(pipe),
                               pps_val);
-               if (crtc_state->dsc.dsc_split)
+               if (vdsc_instances_per_pipe > 1)
                        intel_de_write(dev_priv,
                                       ICL_DSC1_PICTURE_PARAMETER_SET_10(pipe),
                                       pps_val);
                 * If 2 VDSC instances are needed, configure PPS for second
                 * VDSC
                 */
-               if (crtc_state->dsc.dsc_split)
+               if (vdsc_instances_per_pipe > 1)
                        intel_de_write(dev_priv,
                                       DSCC_PICTURE_PARAMETER_SET_16, pps_val);
        } else {
                intel_de_write(dev_priv,
                               ICL_DSC0_PICTURE_PARAMETER_SET_16(pipe),
                               pps_val);
-               if (crtc_state->dsc.dsc_split)
+               if (vdsc_instances_per_pipe > 1)
                        intel_de_write(dev_priv,
                                       ICL_DSC1_PICTURE_PARAMETER_SET_16(pipe),
                                       pps_val);
                intel_de_write(dev_priv,
                               MTL_DSC0_PICTURE_PARAMETER_SET_17(pipe),
                               pps_val);
-               if (crtc_state->dsc.dsc_split)
+               if (vdsc_instances_per_pipe > 1)
                        intel_de_write(dev_priv,
                                       MTL_DSC1_PICTURE_PARAMETER_SET_17(pipe),
                                       pps_val);
                intel_de_write(dev_priv,
                               MTL_DSC0_PICTURE_PARAMETER_SET_18(pipe),
                               pps_val);
-               if (crtc_state->dsc.dsc_split)
+               if (vdsc_instances_per_pipe > 1)
                        intel_de_write(dev_priv,
                                       MTL_DSC1_PICTURE_PARAMETER_SET_18(pipe),
                                       pps_val);
                               rc_buf_thresh_dword[2]);
                intel_de_write(dev_priv, DSCA_RC_BUF_THRESH_1_UDW,
                               rc_buf_thresh_dword[3]);
-               if (crtc_state->dsc.dsc_split) {
+               if (vdsc_instances_per_pipe > 1) {
                        intel_de_write(dev_priv, DSCC_RC_BUF_THRESH_0,
                                       rc_buf_thresh_dword[0]);
                        intel_de_write(dev_priv, DSCC_RC_BUF_THRESH_0_UDW,
                               rc_buf_thresh_dword[2]);
                intel_de_write(dev_priv, ICL_DSC0_RC_BUF_THRESH_1_UDW(pipe),
                               rc_buf_thresh_dword[3]);
-               if (crtc_state->dsc.dsc_split) {
+               if (vdsc_instances_per_pipe > 1) {
                        intel_de_write(dev_priv,
                                       ICL_DSC1_RC_BUF_THRESH_0(pipe),
                                       rc_buf_thresh_dword[0]);
                               rc_range_params_dword[6]);
                intel_de_write(dev_priv, DSCA_RC_RANGE_PARAMETERS_3_UDW,
                               rc_range_params_dword[7]);
-               if (crtc_state->dsc.dsc_split) {
+               if (vdsc_instances_per_pipe > 1) {
                        intel_de_write(dev_priv, DSCC_RC_RANGE_PARAMETERS_0,
                                       rc_range_params_dword[0]);
                        intel_de_write(dev_priv,
                intel_de_write(dev_priv,
                               ICL_DSC0_RC_RANGE_PARAMETERS_3_UDW(pipe),
                               rc_range_params_dword[7]);
-               if (crtc_state->dsc.dsc_split) {
+               if (vdsc_instances_per_pipe > 1) {
                        intel_de_write(dev_priv,
                                       ICL_DSC1_RC_RANGE_PARAMETERS_0(pipe),
                                       rc_range_params_dword[0]);
        struct drm_i915_private *dev_priv = to_i915(crtc->base.dev);
        u32 dss_ctl1_val = 0;
        u32 dss_ctl2_val = 0;
+       int vdsc_instances_per_pipe = intel_dsc_get_vdsc_per_pipe(crtc_state);
 
        if (!crtc_state->dsc.compression_enable)
                return;
        intel_dsc_pps_configure(crtc_state);
 
        dss_ctl2_val |= LEFT_BRANCH_VDSC_ENABLE;
-       if (crtc_state->dsc.dsc_split) {
+       if (vdsc_instances_per_pipe > 1) {
                dss_ctl2_val |= RIGHT_BRANCH_VDSC_ENABLE;
                dss_ctl1_val |= JOINER_ENABLE;
        }
        enum intel_display_power_domain power_domain;
        intel_wakeref_t wakeref;
        u32 dss_ctl1, dss_ctl2, pps0 = 0, pps1 = 0, pps_temp0, pps_temp1;
+       int vdsc_instances_per_pipe;
 
        if (!intel_dsc_source_support(crtc_state))
                return;
 
        /* FIXME: add more state readout as needed */
 
+       vdsc_instances_per_pipe = intel_dsc_get_vdsc_per_pipe(crtc_state);
+
        /* PPS0 & PPS1 */
        if (!is_pipe_dsc(crtc, cpu_transcoder)) {
                pps1 = intel_de_read(dev_priv, DSCA_PICTURE_PARAMETER_SET_1);
-               if (crtc_state->dsc.dsc_split) {
+               if (vdsc_instances_per_pipe > 1) {
                        pps_temp1 = intel_de_read(dev_priv, DSCC_PICTURE_PARAMETER_SET_1);
                        drm_WARN_ON(&dev_priv->drm, pps1 != pps_temp1);
                }
                                     ICL_DSC0_PICTURE_PARAMETER_SET_0(pipe));
                pps1 = intel_de_read(dev_priv,
                                     ICL_DSC0_PICTURE_PARAMETER_SET_1(pipe));
-               if (crtc_state->dsc.dsc_split) {
+               if (vdsc_instances_per_pipe > 1) {
                        pps_temp0 = intel_de_read(dev_priv,
                                                  ICL_DSC1_PICTURE_PARAMETER_SET_0(pipe));
                        pps_temp1 = intel_de_read(dev_priv,