if (hw_pp->ops.setup_dsc)
                hw_pp->ops.setup_dsc(hw_pp);
 
+       if (hw_dsc->ops.dsc_bind_pingpong_blk)
+               hw_dsc->ops.dsc_bind_pingpong_blk(hw_dsc, true, hw_pp->idx);
+
        if (hw_pp->ops.enable_dsc)
                hw_pp->ops.enable_dsc(hw_pp);
 }
 
        DPU_VBIF_MAX
 };
 
+/**
+ * DSC features
+ * @DPU_DSC_OUTPUT_CTRL       Configure which PINGPONG block gets
+ *                            the pixel output from this DSC.
+ */
+enum {
+       DPU_DSC_OUTPUT_CTRL = 0x1,
+};
+
 /**
  * MACRO DPU_HW_BLK_INFO - information of HW blocks inside DPU
  * @name:              string name for debug purposes
 
 #define DSC_RANGE_MAX_QP                0x0B0
 #define DSC_RANGE_BPG_OFFSET            0x0EC
 
+#define DSC_CTL(m) (0x1800 - 0x3FC * (m - DSC_0))
+
 static void dpu_hw_dsc_disable(struct dpu_hw_dsc *dsc)
 {
        struct dpu_hw_blk_reg_map *c = &dsc->hw;
        }
 }
 
+static void dpu_hw_dsc_bind_pingpong_blk(
+               struct dpu_hw_dsc *hw_dsc,
+               bool enable,
+               const enum dpu_pingpong pp)
+{
+       struct dpu_hw_blk_reg_map *c = &hw_dsc->hw;
+       int mux_cfg = 0xF;
+       u32 dsc_ctl_offset;
+
+       dsc_ctl_offset = DSC_CTL(hw_dsc->idx);
+
+       if (enable)
+               mux_cfg = (pp - PINGPONG_0) & 0x7;
+
+       DRM_DEBUG_KMS("%s dsc:%d %s pp:%d\n",
+                       enable ? "Binding" : "Unbinding",
+                       hw_dsc->idx - DSC_0,
+                       enable ? "to" : "from",
+                       pp - PINGPONG_0);
+
+       DPU_REG_WRITE(c, dsc_ctl_offset, mux_cfg);
+}
+
 static struct dpu_dsc_cfg *_dsc_offset(enum dpu_dsc dsc,
                                       const struct dpu_mdss_cfg *m,
                                       void __iomem *addr,
        ops->dsc_disable = dpu_hw_dsc_disable;
        ops->dsc_config = dpu_hw_dsc_config;
        ops->dsc_config_thresh = dpu_hw_dsc_config_thresh;
+       if (cap & BIT(DPU_DSC_OUTPUT_CTRL))
+               ops->dsc_bind_pingpong_blk = dpu_hw_dsc_bind_pingpong_blk;
 };
 
 struct dpu_hw_dsc *dpu_hw_dsc_init(enum dpu_dsc idx, void __iomem *addr,