SRI(CURSOR0_CONTROL, CNVC_CUR, id), \
        SRI(CURSOR0_COLOR0, CNVC_CUR, id), \
        SRI(CURSOR0_COLOR1, CNVC_CUR, id), \
-       SRI(DPP_CONTROL, DPP_TOP, id)
+       SRI(DPP_CONTROL, DPP_TOP, id), \
+       SRI(CM_HDR_MULT_COEF, CM, id)
 
 
 
        TF_SF(CNVC_CUR0_CURSOR0_CONTROL, CUR0_ENABLE, mask_sh), \
        TF_SF(CNVC_CUR0_CURSOR0_COLOR0, CUR0_COLOR0, mask_sh), \
        TF_SF(CNVC_CUR0_CURSOR0_COLOR1, CUR0_COLOR1, mask_sh), \
-       TF_SF(DPP_TOP0_DPP_CONTROL, DPP_CLOCK_ENABLE, mask_sh)
+       TF_SF(DPP_TOP0_DPP_CONTROL, DPP_CLOCK_ENABLE, mask_sh), \
+       TF_SF(CM0_CM_HDR_MULT_COEF, CM_HDR_MULT_COEF, mask_sh)
 
 #define TF_REG_LIST_SH_MASK_DCN10(mask_sh)\
        TF_REG_LIST_SH_MASK_DCN(mask_sh),\
        type CUR0_COLOR0; \
        type CUR0_COLOR1; \
        type DPPCLK_RATE_CONTROL; \
-       type DPP_CLOCK_ENABLE;
+       type DPP_CLOCK_ENABLE; \
+       type CM_HDR_MULT_COEF;
 
 struct dcn_dpp_shift {
        TF_REG_FIELD_LIST(uint8_t)
        uint32_t CURSOR0_CONTROL; \
        uint32_t CURSOR0_COLOR0; \
        uint32_t CURSOR0_COLOR1; \
-       uint32_t DPP_CONTROL;
+       uint32_t DPP_CONTROL; \
+       uint32_t CM_HDR_MULT_COEF;
 
 struct dcn_dpp_registers {
        DPP_COMMON_REG_VARIABLE_LIST
                bool dppclk_div,
                bool enable);
 
+void dpp1_set_hdr_multiplier(
+               struct dpp *dpp_base,
+               uint32_t multiplier);
+
 void dpp1_construct(struct dcn10_dpp *dpp1,
        struct dc_context *ctx,
        uint32_t inst,
 
        }
 }
 
+static void set_hdr_multiplier(struct pipe_ctx *pipe_ctx)
+{
+       struct fixed31_32 multiplier = dal_fixed31_32_from_fraction(
+                       pipe_ctx->plane_state->sdr_white_level, 80);
+       uint32_t hw_mult = 0x1f000; // 1.0 default multiplier
+       struct custom_float_format fmt;
+
+       fmt.exponenta_bits = 6;
+       fmt.mantissa_bits = 12;
+       fmt.sign = true;
+
+       if (pipe_ctx->plane_state->sdr_white_level > 80)
+               convert_to_custom_float_format(multiplier, &fmt, &hw_mult);
+
+       pipe_ctx->plane_res.dpp->funcs->dpp_set_hdr_multiplier(
+                       pipe_ctx->plane_res.dpp, hw_mult);
+}
+
 static void program_all_pipe_in_tree(
                struct dc *dc,
                struct pipe_ctx *pipe_ctx,
 
                update_dchubp_dpp(dc, pipe_ctx, context);
 
+               set_hdr_multiplier(pipe_ctx);
+
                if (pipe_ctx->plane_state->update_flags.bits.full_update ||
                                pipe_ctx->plane_state->update_flags.bits.in_transfer_func_change ||
                                pipe_ctx->plane_state->update_flags.bits.gamma_change)