struct {
                bool i2c: 1;
                bool dmcu: 1;
+               bool dscl: 1;
                bool cm: 1;
                bool mpc: 1;
                bool optc: 1;
 
        SRI(CM_GAMUT_REMAP_C33_C34, CM, id),\
        SRI(DSCL_EXT_OVERSCAN_LEFT_RIGHT, DSCL, id), \
        SRI(DSCL_EXT_OVERSCAN_TOP_BOTTOM, DSCL, id), \
+       SRI(DSCL_MEM_PWR_STATUS, DSCL, id), \
+       SRI(DSCL_MEM_PWR_CTRL, DSCL, id), \
        SRI(OTG_H_BLANK, DSCL, id), \
        SRI(OTG_V_BLANK, DSCL, id), \
        SRI(SCL_MODE, DSCL, id), \
        TF_SF(DSCL0_SCL_VERT_FILTER_INIT_BOT_C, SCL_V_INIT_INT_BOT_C, mask_sh),\
        TF_SF(DSCL0_SCL_MODE, SCL_CHROMA_COEF_MODE, mask_sh),\
        TF_SF(DSCL0_SCL_MODE, SCL_COEF_RAM_SELECT_CURRENT, mask_sh), \
+       TF_SF(DSCL0_DSCL_MEM_PWR_CTRL, LUT_MEM_PWR_FORCE, mask_sh), \
+       TF_SF(DSCL0_DSCL_MEM_PWR_STATUS, LUT_MEM_PWR_STATE, mask_sh), \
        TF_SF(CM0_CM_ICSC_CONTROL, CM_ICSC_MODE, mask_sh), \
        TF_SF(CM0_CM_ICSC_C11_C12, CM_ICSC_C11, mask_sh), \
        TF_SF(CM0_CM_ICSC_C11_C12, CM_ICSC_C12, mask_sh), \
        type SCL_V_INIT_INT_BOT_C; \
        type SCL_CHROMA_COEF_MODE; \
        type SCL_COEF_RAM_SELECT_CURRENT; \
+       type LUT_MEM_PWR_FORCE; \
+       type LUT_MEM_PWR_STATE; \
        type CM_GAMUT_REMAP_MODE; \
        type CM_GAMUT_REMAP_C11; \
        type CM_GAMUT_REMAP_C12; \
        uint32_t DSCL_EXT_OVERSCAN_TOP_BOTTOM; \
        uint32_t OTG_H_BLANK; \
        uint32_t OTG_V_BLANK; \
+       uint32_t DSCL_MEM_PWR_CTRL; \
+       uint32_t DSCL_MEM_PWR_STATUS; \
        uint32_t SCL_MODE; \
        uint32_t LB_DATA_FORMAT; \
        uint32_t LB_MEMORY_CTRL; \
 
        return DSCL_MODE_SCALING_420_YCBCR_ENABLE;
 }
 
+static void dpp1_power_on_dscl(
+       struct dpp *dpp_base,
+       bool power_on)
+{
+       struct dcn10_dpp *dpp = TO_DCN10_DPP(dpp_base);
+
+       if (dpp->tf_regs->DSCL_MEM_PWR_CTRL) {
+               REG_UPDATE(DSCL_MEM_PWR_CTRL, LUT_MEM_PWR_FORCE, power_on ? 0 : 3);
+               if (power_on)
+                       REG_WAIT(DSCL_MEM_PWR_STATUS, LUT_MEM_PWR_STATE, 0, 1, 5);
+       }
+}
+
+
 static void dpp1_dscl_set_lb(
        struct dcn10_dpp *dpp,
        const struct line_buffer_params *lb_params,
 
        dpp->scl_data = *scl_data;
 
+       if (dpp_base->ctx->dc->debug.enable_mem_low_power.bits.dscl) {
+               if (dscl_mode != DSCL_MODE_DSCL_BYPASS)
+                       dpp1_power_on_dscl(dpp_base, true);
+       }
+
        /* Autocal off */
        REG_SET_3(DSCL_AUTOCAL, 0,
                AUTOCAL_MODE, AUTOCAL_MODE_OFF,
        /* SCL mode */
        REG_UPDATE(SCL_MODE, DSCL_MODE, dscl_mode);
 
-       if (dscl_mode == DSCL_MODE_DSCL_BYPASS)
+       if (dscl_mode == DSCL_MODE_DSCL_BYPASS) {
+               if (dpp_base->ctx->dc->debug.enable_mem_low_power.bits.dscl)
+                       dpp1_power_on_dscl(dpp_base, false);
                return;
+       }
 
        /* LB */
        lb_config =  dpp1_dscl_find_lb_memory_config(dpp, scl_data);
 
        type CUR0_PIX_INV_MODE; \
        type CUR0_PIXEL_ALPHA_MOD_EN; \
        type CUR0_ROM_EN;\
-       type OBUF_MEM_PWR_FORCE;\
-       type LUT_MEM_PWR_FORCE
+       type OBUF_MEM_PWR_FORCE
 
 
 struct dcn2_dpp_shift {
        uint32_t COLOR_KEYER_RED; \
        uint32_t COLOR_KEYER_GREEN; \
        uint32_t COLOR_KEYER_BLUE; \
-       uint32_t OBUF_MEM_PWR_CTRL; \
-       uint32_t DSCL_MEM_PWR_CTRL
+       uint32_t OBUF_MEM_PWR_CTRL
 
 #define DPP_DCN2_REG_VARIABLE_LIST_CM_APPEND \
        uint32_t CM_GAMUT_REMAP_B_C11_C12; \
 
        SRI(CM_SHAPER_LUT_DATA, CM, id),\
        SRI(CM_MEM_PWR_CTRL2, CM, id), \
        SRI(CM_MEM_PWR_STATUS2, CM, id), \
+       SRI(DSCL_MEM_PWR_STATUS, DSCL, id), \
+       SRI(DSCL_MEM_PWR_CTRL, DSCL, id), \
        SRI(CM_BLNDGAM_RAMA_START_SLOPE_CNTL_B, CM, id),\
        SRI(CM_BLNDGAM_RAMA_START_SLOPE_CNTL_G, CM, id),\
        SRI(CM_BLNDGAM_RAMA_START_SLOPE_CNTL_R, CM, id),\
        TF_SF(CNVC_CUR0_CURSOR0_CONTROL, CUR0_PIXEL_ALPHA_MOD_EN, mask_sh), \
        TF_SF(CNVC_CUR0_CURSOR0_CONTROL, CUR0_ROM_EN, mask_sh),\
        TF_SF(DSCL0_OBUF_MEM_PWR_CTRL, OBUF_MEM_PWR_FORCE, mask_sh),\
-       TF_SF(DSCL0_DSCL_MEM_PWR_CTRL, LUT_MEM_PWR_FORCE, mask_sh)
+       TF_SF(DSCL0_DSCL_MEM_PWR_CTRL, LUT_MEM_PWR_FORCE, mask_sh),\
+       TF_SF(DSCL0_DSCL_MEM_PWR_STATUS, LUT_MEM_PWR_STATE, mask_sh)
 
 #define DPP_REG_LIST_SH_MASK_DCN30_UPDATED(mask_sh)\
        TF_SF(CM0_CM_MEM_PWR_STATUS, BLNDGAM_MEM_PWR_STATE, mask_sh), \