drm/amd/display: Refactoring MPC
authorMounika Adhuri <moadhuri@amd.com>
Wed, 26 Jun 2024 13:21:04 +0000 (18:51 +0530)
committerAlex Deucher <alexander.deucher@amd.com>
Tue, 23 Jul 2024 21:07:11 +0000 (17:07 -0400)
[Why]
To refactor MPC files

[How]
Moved MPC files to respective folders and
updated makefiles appropriately.

Reviewed-by: Martin Leung <martin.leung@amd.com>
Signed-off-by: Jerry Zuo <jerry.zuo@amd.com>
Signed-off-by: Mounika Adhuri <moadhuri@amd.com>
Tested-by: Daniel Wheeler <daniel.wheeler@amd.com>
Signed-off-by: Alex Deucher <alexander.deucher@amd.com>
16 files changed:
drivers/gpu/drm/amd/display/dc/dcn10/Makefile
drivers/gpu/drm/amd/display/dc/dcn10/dcn10_mpc.c [deleted file]
drivers/gpu/drm/amd/display/dc/dcn10/dcn10_mpc.h [deleted file]
drivers/gpu/drm/amd/display/dc/dcn20/Makefile
drivers/gpu/drm/amd/display/dc/dcn20/dcn20_mpc.c [deleted file]
drivers/gpu/drm/amd/display/dc/dcn20/dcn20_mpc.h [deleted file]
drivers/gpu/drm/amd/display/dc/dcn30/Makefile
drivers/gpu/drm/amd/display/dc/dcn30/dcn30_mpc.c [deleted file]
drivers/gpu/drm/amd/display/dc/dcn30/dcn30_mpc.h [deleted file]
drivers/gpu/drm/amd/display/dc/mpc/Makefile
drivers/gpu/drm/amd/display/dc/mpc/dcn10/dcn10_mpc.c [new file with mode: 0644]
drivers/gpu/drm/amd/display/dc/mpc/dcn10/dcn10_mpc.h [new file with mode: 0644]
drivers/gpu/drm/amd/display/dc/mpc/dcn20/dcn20_mpc.c [new file with mode: 0644]
drivers/gpu/drm/amd/display/dc/mpc/dcn20/dcn20_mpc.h [new file with mode: 0644]
drivers/gpu/drm/amd/display/dc/mpc/dcn30/dcn30_mpc.c [new file with mode: 0644]
drivers/gpu/drm/amd/display/dc/mpc/dcn30/dcn30_mpc.h [new file with mode: 0644]

index 75e088b..e1f6623 100644 (file)
@@ -24,7 +24,6 @@
 
 DCN10 = dcn10_ipp.o \
                dcn10_hw_sequencer_debug.o \
-               dcn10_mpc.o \
                dcn10_cm_common.o \
 
 AMD_DAL_DCN10 = $(addprefix $(AMDDALPATH)/dc/dcn10/,$(DCN10))
diff --git a/drivers/gpu/drm/amd/display/dc/dcn10/dcn10_mpc.c b/drivers/gpu/drm/amd/display/dc/dcn10/dcn10_mpc.c
deleted file mode 100644 (file)
index f2f5556..0000000
+++ /dev/null
@@ -1,537 +0,0 @@
-/*
- * Copyright 2012-15 Advanced Micro Devices, Inc.
- *
- * Permission is hereby granted, free of charge, to any person obtaining a
- * copy of this software and associated documentation files (the "Software"),
- * to deal in the Software without restriction, including without limitation
- * the rights to use, copy, modify, merge, publish, distribute, sublicense,
- * and/or sell copies of the Software, and to permit persons to whom the
- * Software is furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice shall be included in
- * all copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
- * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
- * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
- * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
- * OTHER DEALINGS IN THE SOFTWARE.
- *
- * Authors: AMD
- *
- */
-
-#include "reg_helper.h"
-#include "dcn10_mpc.h"
-
-#define REG(reg)\
-       mpc10->mpc_regs->reg
-
-#define CTX \
-       mpc10->base.ctx
-
-#undef FN
-#define FN(reg_name, field_name) \
-       mpc10->mpc_shift->field_name, mpc10->mpc_mask->field_name
-
-
-void mpc1_set_bg_color(struct mpc *mpc,
-               struct tg_color *bg_color,
-               int mpcc_id)
-{
-       struct dcn10_mpc *mpc10 = TO_DCN10_MPC(mpc);
-       struct mpcc *bottommost_mpcc = mpc1_get_mpcc(mpc, mpcc_id);
-       uint32_t bg_r_cr, bg_g_y, bg_b_cb;
-
-       bottommost_mpcc->blnd_cfg.black_color = *bg_color;
-
-       /* find bottommost mpcc. */
-       while (bottommost_mpcc->mpcc_bot) {
-               /* avoid circular linked link */
-               ASSERT(bottommost_mpcc != bottommost_mpcc->mpcc_bot);
-               if (bottommost_mpcc == bottommost_mpcc->mpcc_bot)
-                       break;
-
-               bottommost_mpcc = bottommost_mpcc->mpcc_bot;
-       }
-
-       /* mpc color is 12 bit.  tg_color is 10 bit */
-       /* todo: might want to use 16 bit to represent color and have each
-        * hw block translate to correct color depth.
-        */
-       bg_r_cr = bg_color->color_r_cr << 2;
-       bg_g_y = bg_color->color_g_y << 2;
-       bg_b_cb = bg_color->color_b_cb << 2;
-
-       REG_SET(MPCC_BG_R_CR[bottommost_mpcc->mpcc_id], 0,
-                       MPCC_BG_R_CR, bg_r_cr);
-       REG_SET(MPCC_BG_G_Y[bottommost_mpcc->mpcc_id], 0,
-                       MPCC_BG_G_Y, bg_g_y);
-       REG_SET(MPCC_BG_B_CB[bottommost_mpcc->mpcc_id], 0,
-                       MPCC_BG_B_CB, bg_b_cb);
-}
-
-static void mpc1_update_blending(
-       struct mpc *mpc,
-       struct mpcc_blnd_cfg *blnd_cfg,
-       int mpcc_id)
-{
-       struct dcn10_mpc *mpc10 = TO_DCN10_MPC(mpc);
-       struct mpcc *mpcc = mpc1_get_mpcc(mpc, mpcc_id);
-
-       REG_UPDATE_5(MPCC_CONTROL[mpcc_id],
-                       MPCC_ALPHA_BLND_MODE,           blnd_cfg->alpha_mode,
-                       MPCC_ALPHA_MULTIPLIED_MODE,     blnd_cfg->pre_multiplied_alpha,
-                       MPCC_BLND_ACTIVE_OVERLAP_ONLY,  blnd_cfg->overlap_only,
-                       MPCC_GLOBAL_ALPHA,              blnd_cfg->global_alpha,
-                       MPCC_GLOBAL_GAIN,               blnd_cfg->global_gain);
-
-       mpcc->blnd_cfg = *blnd_cfg;
-}
-
-void mpc1_update_stereo_mix(
-       struct mpc *mpc,
-       struct mpcc_sm_cfg *sm_cfg,
-       int mpcc_id)
-{
-       struct dcn10_mpc *mpc10 = TO_DCN10_MPC(mpc);
-
-       REG_UPDATE_6(MPCC_SM_CONTROL[mpcc_id],
-                       MPCC_SM_EN,                     sm_cfg->enable,
-                       MPCC_SM_MODE,                   sm_cfg->sm_mode,
-                       MPCC_SM_FRAME_ALT,              sm_cfg->frame_alt,
-                       MPCC_SM_FIELD_ALT,              sm_cfg->field_alt,
-                       MPCC_SM_FORCE_NEXT_FRAME_POL,   sm_cfg->force_next_frame_porlarity,
-                       MPCC_SM_FORCE_NEXT_TOP_POL,     sm_cfg->force_next_field_polarity);
-}
-void mpc1_assert_idle_mpcc(struct mpc *mpc, int id)
-{
-       struct dcn10_mpc *mpc10 = TO_DCN10_MPC(mpc);
-
-       ASSERT(!(mpc10->mpcc_in_use_mask & 1 << id));
-       REG_WAIT(MPCC_STATUS[id],
-                       MPCC_IDLE, 1,
-                       1, 100000);
-}
-
-struct mpcc *mpc1_get_mpcc(struct mpc *mpc, int mpcc_id)
-{
-       struct dcn10_mpc *mpc10 = TO_DCN10_MPC(mpc);
-
-       ASSERT(mpcc_id < mpc10->num_mpcc);
-       return &(mpc->mpcc_array[mpcc_id]);
-}
-
-struct mpcc *mpc1_get_mpcc_for_dpp(struct mpc_tree *tree, int dpp_id)
-{
-       struct mpcc *tmp_mpcc = tree->opp_list;
-
-       while (tmp_mpcc != NULL) {
-               if (tmp_mpcc->dpp_id == dpp_id)
-                       return tmp_mpcc;
-
-               /* avoid circular linked list */
-               ASSERT(tmp_mpcc != tmp_mpcc->mpcc_bot);
-               if (tmp_mpcc == tmp_mpcc->mpcc_bot)
-                       break;
-
-               tmp_mpcc = tmp_mpcc->mpcc_bot;
-       }
-       return NULL;
-}
-
-bool mpc1_is_mpcc_idle(struct mpc *mpc, int mpcc_id)
-{
-       struct dcn10_mpc *mpc10 = TO_DCN10_MPC(mpc);
-       unsigned int top_sel;
-       unsigned int opp_id;
-       unsigned int idle;
-
-       REG_GET(MPCC_TOP_SEL[mpcc_id], MPCC_TOP_SEL, &top_sel);
-       REG_GET(MPCC_OPP_ID[mpcc_id],  MPCC_OPP_ID, &opp_id);
-       REG_GET(MPCC_STATUS[mpcc_id],  MPCC_IDLE,   &idle);
-       if (top_sel == 0xf && opp_id == 0xf && idle)
-               return true;
-       else
-               return false;
-}
-
-void mpc1_assert_mpcc_idle_before_connect(struct mpc *mpc, int mpcc_id)
-{
-       struct dcn10_mpc *mpc10 = TO_DCN10_MPC(mpc);
-       unsigned int top_sel, mpc_busy, mpc_idle;
-
-       REG_GET(MPCC_TOP_SEL[mpcc_id],
-                       MPCC_TOP_SEL, &top_sel);
-
-       if (top_sel == 0xf) {
-               REG_GET_2(MPCC_STATUS[mpcc_id],
-                               MPCC_BUSY, &mpc_busy,
-                               MPCC_IDLE, &mpc_idle);
-
-               ASSERT(mpc_busy == 0);
-               ASSERT(mpc_idle == 1);
-       }
-}
-
-/*
- * Insert DPP into MPC tree based on specified blending position.
- * Only used for planes that are part of blending chain for OPP output
- *
- * Parameters:
- * [in/out] mpc                - MPC context.
- * [in/out] tree       - MPC tree structure that plane will be added to.
- * [in]        blnd_cfg        - MPCC blending configuration for the new blending layer.
- * [in]        sm_cfg          - MPCC stereo mix configuration for the new blending layer.
- *                       stereo mix must disable for the very bottom layer of the tree config.
- * [in]        insert_above_mpcc - Insert new plane above this MPCC.  If NULL, insert as bottom plane.
- * [in]        dpp_id          - DPP instance for the plane to be added.
- * [in]        mpcc_id         - The MPCC physical instance to use for blending.
- *
- * Return:  struct mpcc* - MPCC that was added.
- */
-struct mpcc *mpc1_insert_plane(
-       struct mpc *mpc,
-       struct mpc_tree *tree,
-       struct mpcc_blnd_cfg *blnd_cfg,
-       struct mpcc_sm_cfg *sm_cfg,
-       struct mpcc *insert_above_mpcc,
-       int dpp_id,
-       int mpcc_id)
-{
-       struct dcn10_mpc *mpc10 = TO_DCN10_MPC(mpc);
-       struct mpcc *new_mpcc = NULL;
-
-       /* sanity check parameters */
-       ASSERT(mpcc_id < mpc10->num_mpcc);
-       ASSERT(!(mpc10->mpcc_in_use_mask & 1 << mpcc_id));
-
-       if (insert_above_mpcc) {
-               /* check insert_above_mpcc exist in tree->opp_list */
-               struct mpcc *temp_mpcc = tree->opp_list;
-
-               if (temp_mpcc != insert_above_mpcc)
-                       while (temp_mpcc && temp_mpcc->mpcc_bot != insert_above_mpcc)
-                               temp_mpcc = temp_mpcc->mpcc_bot;
-               if (temp_mpcc == NULL)
-                       return NULL;
-       }
-
-       /* Get and update MPCC struct parameters */
-       new_mpcc = mpc1_get_mpcc(mpc, mpcc_id);
-       new_mpcc->dpp_id = dpp_id;
-
-       /* program mux and MPCC_MODE */
-       if (insert_above_mpcc) {
-               new_mpcc->mpcc_bot = insert_above_mpcc;
-               REG_SET(MPCC_BOT_SEL[mpcc_id], 0, MPCC_BOT_SEL, insert_above_mpcc->mpcc_id);
-               REG_UPDATE(MPCC_CONTROL[mpcc_id], MPCC_MODE, MPCC_BLEND_MODE_TOP_BOT_BLENDING);
-       } else {
-               new_mpcc->mpcc_bot = NULL;
-               REG_SET(MPCC_BOT_SEL[mpcc_id], 0, MPCC_BOT_SEL, 0xf);
-               REG_UPDATE(MPCC_CONTROL[mpcc_id], MPCC_MODE, MPCC_BLEND_MODE_TOP_LAYER_ONLY);
-       }
-       REG_SET(MPCC_TOP_SEL[mpcc_id], 0, MPCC_TOP_SEL, dpp_id);
-       REG_SET(MPCC_OPP_ID[mpcc_id], 0, MPCC_OPP_ID, tree->opp_id);
-
-       /* Configure VUPDATE lock set for this MPCC to map to the OPP */
-       REG_SET(MPCC_UPDATE_LOCK_SEL[mpcc_id], 0, MPCC_UPDATE_LOCK_SEL, tree->opp_id);
-
-       /* update mpc tree mux setting */
-       if (tree->opp_list == insert_above_mpcc) {
-               /* insert the toppest mpcc */
-               tree->opp_list = new_mpcc;
-               REG_UPDATE(MUX[tree->opp_id], MPC_OUT_MUX, mpcc_id);
-       } else {
-               /* find insert position */
-               struct mpcc *temp_mpcc = tree->opp_list;
-
-               while (temp_mpcc && temp_mpcc->mpcc_bot != insert_above_mpcc)
-                       temp_mpcc = temp_mpcc->mpcc_bot;
-               if (temp_mpcc && temp_mpcc->mpcc_bot == insert_above_mpcc) {
-                       REG_SET(MPCC_BOT_SEL[temp_mpcc->mpcc_id], 0, MPCC_BOT_SEL, mpcc_id);
-                       temp_mpcc->mpcc_bot = new_mpcc;
-                       if (!insert_above_mpcc)
-                               REG_UPDATE(MPCC_CONTROL[temp_mpcc->mpcc_id],
-                                               MPCC_MODE, MPCC_BLEND_MODE_TOP_BOT_BLENDING);
-               }
-       }
-
-       /* update the blending configuration */
-       mpc->funcs->update_blending(mpc, blnd_cfg, mpcc_id);
-
-       /* update the stereo mix settings, if provided */
-       if (sm_cfg != NULL) {
-               new_mpcc->sm_cfg = *sm_cfg;
-               mpc1_update_stereo_mix(mpc, sm_cfg, mpcc_id);
-       }
-
-       /* mark this mpcc as in use */
-       mpc10->mpcc_in_use_mask |= 1 << mpcc_id;
-
-       return new_mpcc;
-}
-
-/*
- * Remove a specified MPCC from the MPC tree.
- *
- * Parameters:
- * [in/out] mpc                - MPC context.
- * [in/out] tree       - MPC tree structure that plane will be removed from.
- * [in/out] mpcc       - MPCC to be removed from tree.
- *
- * Return:  void
- */
-void mpc1_remove_mpcc(
-       struct mpc *mpc,
-       struct mpc_tree *tree,
-       struct mpcc *mpcc_to_remove)
-{
-       struct dcn10_mpc *mpc10 = TO_DCN10_MPC(mpc);
-       bool found = false;
-       int mpcc_id = mpcc_to_remove->mpcc_id;
-
-       if (tree->opp_list == mpcc_to_remove) {
-               found = true;
-               /* remove MPCC from top of tree */
-               if (mpcc_to_remove->mpcc_bot) {
-                       /* set the next MPCC in list to be the top MPCC */
-                       tree->opp_list = mpcc_to_remove->mpcc_bot;
-                       REG_UPDATE(MUX[tree->opp_id], MPC_OUT_MUX, tree->opp_list->mpcc_id);
-               } else {
-                       /* there are no other MPCC is list */
-                       tree->opp_list = NULL;
-                       REG_UPDATE(MUX[tree->opp_id], MPC_OUT_MUX, 0xf);
-               }
-       } else {
-               /* find mpcc to remove MPCC list */
-               struct mpcc *temp_mpcc = tree->opp_list;
-
-               while (temp_mpcc && temp_mpcc->mpcc_bot != mpcc_to_remove)
-                       temp_mpcc = temp_mpcc->mpcc_bot;
-
-               if (temp_mpcc && temp_mpcc->mpcc_bot == mpcc_to_remove) {
-                       found = true;
-                       temp_mpcc->mpcc_bot = mpcc_to_remove->mpcc_bot;
-                       if (mpcc_to_remove->mpcc_bot) {
-                               /* remove MPCC in middle of list */
-                               REG_SET(MPCC_BOT_SEL[temp_mpcc->mpcc_id], 0,
-                                               MPCC_BOT_SEL, mpcc_to_remove->mpcc_bot->mpcc_id);
-                       } else {
-                               /* remove MPCC from bottom of list */
-                               REG_SET(MPCC_BOT_SEL[temp_mpcc->mpcc_id], 0,
-                                               MPCC_BOT_SEL, 0xf);
-                               REG_UPDATE(MPCC_CONTROL[temp_mpcc->mpcc_id],
-                                               MPCC_MODE, MPCC_BLEND_MODE_TOP_LAYER_PASSTHROUGH);
-                       }
-               }
-       }
-
-       if (found) {
-               /* turn off MPCC mux registers */
-               REG_SET(MPCC_TOP_SEL[mpcc_id], 0, MPCC_TOP_SEL, 0xf);
-               REG_SET(MPCC_BOT_SEL[mpcc_id], 0, MPCC_BOT_SEL, 0xf);
-               REG_SET(MPCC_OPP_ID[mpcc_id],  0, MPCC_OPP_ID,  0xf);
-               REG_SET(MPCC_UPDATE_LOCK_SEL[mpcc_id], 0, MPCC_UPDATE_LOCK_SEL, 0xf);
-
-               /* mark this mpcc as not in use */
-               mpc10->mpcc_in_use_mask &= ~(1 << mpcc_id);
-               mpcc_to_remove->dpp_id = 0xf;
-               mpcc_to_remove->mpcc_bot = NULL;
-       } else {
-               /* In case of resume from S3/S4, remove mpcc from bios left over */
-               REG_SET(MPCC_TOP_SEL[mpcc_id], 0, MPCC_TOP_SEL, 0xf);
-               REG_SET(MPCC_BOT_SEL[mpcc_id], 0, MPCC_BOT_SEL, 0xf);
-               REG_SET(MPCC_OPP_ID[mpcc_id],  0, MPCC_OPP_ID,  0xf);
-               REG_SET(MPCC_UPDATE_LOCK_SEL[mpcc_id], 0, MPCC_UPDATE_LOCK_SEL, 0xf);
-       }
-}
-
-static void mpc1_init_mpcc(struct mpcc *mpcc, int mpcc_inst)
-{
-       mpcc->mpcc_id = mpcc_inst;
-       mpcc->dpp_id = 0xf;
-       mpcc->mpcc_bot = NULL;
-       mpcc->blnd_cfg.overlap_only = false;
-       mpcc->blnd_cfg.global_alpha = 0xff;
-       mpcc->blnd_cfg.global_gain = 0xff;
-       mpcc->sm_cfg.enable = false;
-}
-
-/*
- * Reset the MPCC HW status by disconnecting all muxes.
- *
- * Parameters:
- * [in/out] mpc                - MPC context.
- *
- * Return:  void
- */
-void mpc1_mpc_init(struct mpc *mpc)
-{
-       struct dcn10_mpc *mpc10 = TO_DCN10_MPC(mpc);
-       int mpcc_id;
-       int opp_id;
-
-       mpc10->mpcc_in_use_mask = 0;
-       for (mpcc_id = 0; mpcc_id < mpc10->num_mpcc; mpcc_id++) {
-               REG_SET(MPCC_TOP_SEL[mpcc_id], 0, MPCC_TOP_SEL, 0xf);
-               REG_SET(MPCC_BOT_SEL[mpcc_id], 0, MPCC_BOT_SEL, 0xf);
-               REG_SET(MPCC_OPP_ID[mpcc_id],  0, MPCC_OPP_ID,  0xf);
-               REG_SET(MPCC_UPDATE_LOCK_SEL[mpcc_id], 0, MPCC_UPDATE_LOCK_SEL, 0xf);
-
-               mpc1_init_mpcc(&(mpc->mpcc_array[mpcc_id]), mpcc_id);
-       }
-
-       for (opp_id = 0; opp_id < MAX_OPP; opp_id++) {
-               if (REG(MUX[opp_id]))
-                       REG_UPDATE(MUX[opp_id], MPC_OUT_MUX, 0xf);
-       }
-}
-
-void mpc1_mpc_init_single_inst(struct mpc *mpc, unsigned int mpcc_id)
-{
-       struct dcn10_mpc *mpc10 = TO_DCN10_MPC(mpc);
-       int opp_id;
-
-       REG_GET(MPCC_OPP_ID[mpcc_id], MPCC_OPP_ID, &opp_id);
-
-       REG_SET(MPCC_TOP_SEL[mpcc_id], 0, MPCC_TOP_SEL, 0xf);
-       REG_SET(MPCC_BOT_SEL[mpcc_id], 0, MPCC_BOT_SEL, 0xf);
-       REG_SET(MPCC_OPP_ID[mpcc_id],  0, MPCC_OPP_ID,  0xf);
-       REG_SET(MPCC_UPDATE_LOCK_SEL[mpcc_id], 0, MPCC_UPDATE_LOCK_SEL, 0xf);
-
-       mpc1_init_mpcc(&(mpc->mpcc_array[mpcc_id]), mpcc_id);
-
-       if (opp_id < MAX_OPP && REG(MUX[opp_id]))
-               REG_UPDATE(MUX[opp_id], MPC_OUT_MUX, 0xf);
-}
-
-
-void mpc1_init_mpcc_list_from_hw(
-       struct mpc *mpc,
-       struct mpc_tree *tree)
-{
-       struct dcn10_mpc *mpc10 = TO_DCN10_MPC(mpc);
-       unsigned int opp_id;
-       unsigned int top_sel;
-       unsigned int bot_sel;
-       unsigned int out_mux;
-       struct mpcc *mpcc;
-       int mpcc_id;
-       int bot_mpcc_id;
-
-       REG_GET(MUX[tree->opp_id], MPC_OUT_MUX, &out_mux);
-
-       if (out_mux != 0xf) {
-               for (mpcc_id = 0; mpcc_id < mpc10->num_mpcc; mpcc_id++) {
-                       REG_GET(MPCC_OPP_ID[mpcc_id],  MPCC_OPP_ID,  &opp_id);
-                       REG_GET(MPCC_TOP_SEL[mpcc_id], MPCC_TOP_SEL, &top_sel);
-                       REG_GET(MPCC_BOT_SEL[mpcc_id],  MPCC_BOT_SEL, &bot_sel);
-
-                       if (bot_sel == mpcc_id)
-                               bot_sel = 0xf;
-
-                       if ((opp_id == tree->opp_id) && (top_sel != 0xf)) {
-                               mpcc = mpc1_get_mpcc(mpc, mpcc_id);
-                               mpcc->dpp_id = top_sel;
-                               mpc10->mpcc_in_use_mask |= 1 << mpcc_id;
-
-                               if (out_mux == mpcc_id)
-                                       tree->opp_list = mpcc;
-                               if (bot_sel != 0xf && bot_sel < mpc10->num_mpcc) {
-                                       bot_mpcc_id = bot_sel;
-                                       REG_GET(MPCC_OPP_ID[bot_mpcc_id],  MPCC_OPP_ID,  &opp_id);
-                                       REG_GET(MPCC_TOP_SEL[bot_mpcc_id], MPCC_TOP_SEL, &top_sel);
-                                       if ((opp_id == tree->opp_id) && (top_sel != 0xf)) {
-                                               struct mpcc *mpcc_bottom = mpc1_get_mpcc(mpc, bot_mpcc_id);
-
-                                               mpcc->mpcc_bot = mpcc_bottom;
-                                       }
-                               }
-                       }
-               }
-       }
-}
-
-void mpc1_read_mpcc_state(
-               struct mpc *mpc,
-               int mpcc_inst,
-               struct mpcc_state *s)
-{
-       struct dcn10_mpc *mpc10 = TO_DCN10_MPC(mpc);
-
-       REG_GET(MPCC_OPP_ID[mpcc_inst], MPCC_OPP_ID, &s->opp_id);
-       REG_GET(MPCC_TOP_SEL[mpcc_inst], MPCC_TOP_SEL, &s->dpp_id);
-       REG_GET(MPCC_BOT_SEL[mpcc_inst], MPCC_BOT_SEL, &s->bot_mpcc_id);
-       REG_GET_4(MPCC_CONTROL[mpcc_inst], MPCC_MODE, &s->mode,
-                       MPCC_ALPHA_BLND_MODE, &s->alpha_mode,
-                       MPCC_ALPHA_MULTIPLIED_MODE, &s->pre_multiplied_alpha,
-                       MPCC_BLND_ACTIVE_OVERLAP_ONLY, &s->overlap_only);
-       REG_GET_2(MPCC_STATUS[mpcc_inst], MPCC_IDLE, &s->idle,
-                       MPCC_BUSY, &s->busy);
-}
-
-void mpc1_cursor_lock(struct mpc *mpc, int opp_id, bool lock)
-{
-       struct dcn10_mpc *mpc10 = TO_DCN10_MPC(mpc);
-
-       REG_SET(CUR[opp_id], 0, CUR_VUPDATE_LOCK_SET, lock ? 1 : 0);
-}
-
-unsigned int mpc1_get_mpc_out_mux(struct mpc *mpc, int opp_id)
-{
-       struct dcn10_mpc *mpc10 = TO_DCN10_MPC(mpc);
-       uint32_t val = 0xf;
-
-       if (opp_id < MAX_OPP && REG(MUX[opp_id]))
-               REG_GET(MUX[opp_id], MPC_OUT_MUX, &val);
-
-       return val;
-}
-
-static const struct mpc_funcs dcn10_mpc_funcs = {
-       .read_mpcc_state = mpc1_read_mpcc_state,
-       .insert_plane = mpc1_insert_plane,
-       .remove_mpcc = mpc1_remove_mpcc,
-       .mpc_init = mpc1_mpc_init,
-       .mpc_init_single_inst = mpc1_mpc_init_single_inst,
-       .get_mpcc_for_dpp = mpc1_get_mpcc_for_dpp,
-       .wait_for_idle = mpc1_assert_idle_mpcc,
-       .assert_mpcc_idle_before_connect = mpc1_assert_mpcc_idle_before_connect,
-       .init_mpcc_list_from_hw = mpc1_init_mpcc_list_from_hw,
-       .update_blending = mpc1_update_blending,
-       .cursor_lock = mpc1_cursor_lock,
-       .set_denorm = NULL,
-       .set_denorm_clamp = NULL,
-       .set_output_csc = NULL,
-       .set_output_gamma = NULL,
-       .get_mpc_out_mux = mpc1_get_mpc_out_mux,
-       .set_bg_color = mpc1_set_bg_color,
-};
-
-void dcn10_mpc_construct(struct dcn10_mpc *mpc10,
-       struct dc_context *ctx,
-       const struct dcn_mpc_registers *mpc_regs,
-       const struct dcn_mpc_shift *mpc_shift,
-       const struct dcn_mpc_mask *mpc_mask,
-       int num_mpcc)
-{
-       int i;
-
-       mpc10->base.ctx = ctx;
-
-       mpc10->base.funcs = &dcn10_mpc_funcs;
-
-       mpc10->mpc_regs = mpc_regs;
-       mpc10->mpc_shift = mpc_shift;
-       mpc10->mpc_mask = mpc_mask;
-
-       mpc10->mpcc_in_use_mask = 0;
-       mpc10->num_mpcc = num_mpcc;
-
-       for (i = 0; i < MAX_MPCC; i++)
-               mpc1_init_mpcc(&mpc10->base.mpcc_array[i], i);
-}
-
diff --git a/drivers/gpu/drm/amd/display/dc/dcn10/dcn10_mpc.h b/drivers/gpu/drm/amd/display/dc/dcn10/dcn10_mpc.h
deleted file mode 100644 (file)
index dbfffc6..0000000
+++ /dev/null
@@ -1,204 +0,0 @@
-/* Copyright 2012-15 Advanced Micro Devices, Inc.
- *
- * Permission is hereby granted, free of charge, to any person obtaining a
- * copy of this software and associated documentation files (the "Software"),
- * to deal in the Software without restriction, including without limitation
- * the rights to use, copy, modify, merge, publish, distribute, sublicense,
- * and/or sell copies of the Software, and to permit persons to whom the
- * Software is furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice shall be included in
- * all copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
- * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
- * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
- * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
- * OTHER DEALINGS IN THE SOFTWARE.
- *
- * Authors: AMD
- *
- */
-
-#ifndef __DC_MPCC_DCN10_H__
-#define __DC_MPCC_DCN10_H__
-
-#include "mpc.h"
-
-#define TO_DCN10_MPC(mpc_base) \
-       container_of(mpc_base, struct dcn10_mpc, base)
-
-#define MPC_COMMON_REG_LIST_DCN1_0(inst) \
-       SRII(MPCC_TOP_SEL, MPCC, inst),\
-       SRII(MPCC_BOT_SEL, MPCC, inst),\
-       SRII(MPCC_CONTROL, MPCC, inst),\
-       SRII(MPCC_STATUS, MPCC, inst),\
-       SRII(MPCC_OPP_ID, MPCC, inst),\
-       SRII(MPCC_BG_G_Y, MPCC, inst),\
-       SRII(MPCC_BG_R_CR, MPCC, inst),\
-       SRII(MPCC_BG_B_CB, MPCC, inst),\
-       SRII(MPCC_SM_CONTROL, MPCC, inst),\
-       SRII(MPCC_UPDATE_LOCK_SEL, MPCC, inst)
-
-#define MPC_OUT_MUX_COMMON_REG_LIST_DCN1_0(inst) \
-       SRII(MUX, MPC_OUT, inst),\
-       VUPDATE_SRII(CUR, VUPDATE_LOCK_SET, inst)
-
-#define MPC_COMMON_REG_VARIABLE_LIST \
-       uint32_t MPCC_TOP_SEL[MAX_MPCC]; \
-       uint32_t MPCC_BOT_SEL[MAX_MPCC]; \
-       uint32_t MPCC_CONTROL[MAX_MPCC]; \
-       uint32_t MPCC_STATUS[MAX_MPCC]; \
-       uint32_t MPCC_OPP_ID[MAX_MPCC]; \
-       uint32_t MPCC_BG_G_Y[MAX_MPCC]; \
-       uint32_t MPCC_BG_R_CR[MAX_MPCC]; \
-       uint32_t MPCC_BG_B_CB[MAX_MPCC]; \
-       uint32_t MPCC_SM_CONTROL[MAX_MPCC]; \
-       uint32_t MUX[MAX_OPP]; \
-       uint32_t MPCC_UPDATE_LOCK_SEL[MAX_MPCC]; \
-       uint32_t CUR[MAX_OPP];
-
-#define MPC_COMMON_MASK_SH_LIST_DCN1_0(mask_sh)\
-       SF(MPCC0_MPCC_TOP_SEL, MPCC_TOP_SEL, mask_sh),\
-       SF(MPCC0_MPCC_BOT_SEL, MPCC_BOT_SEL, mask_sh),\
-       SF(MPCC0_MPCC_CONTROL, MPCC_MODE, mask_sh),\
-       SF(MPCC0_MPCC_CONTROL, MPCC_ALPHA_BLND_MODE, mask_sh),\
-       SF(MPCC0_MPCC_CONTROL, MPCC_ALPHA_MULTIPLIED_MODE, mask_sh),\
-       SF(MPCC0_MPCC_CONTROL, MPCC_BLND_ACTIVE_OVERLAP_ONLY, mask_sh),\
-       SF(MPCC0_MPCC_CONTROL, MPCC_GLOBAL_ALPHA, mask_sh),\
-       SF(MPCC0_MPCC_CONTROL, MPCC_GLOBAL_GAIN, mask_sh),\
-       SF(MPCC0_MPCC_STATUS, MPCC_IDLE, mask_sh),\
-       SF(MPCC0_MPCC_STATUS, MPCC_BUSY, mask_sh),\
-       SF(MPCC0_MPCC_OPP_ID, MPCC_OPP_ID, mask_sh),\
-       SF(MPCC0_MPCC_BG_G_Y, MPCC_BG_G_Y, mask_sh),\
-       SF(MPCC0_MPCC_BG_R_CR, MPCC_BG_R_CR, mask_sh),\
-       SF(MPCC0_MPCC_BG_B_CB, MPCC_BG_B_CB, mask_sh),\
-       SF(MPCC0_MPCC_SM_CONTROL, MPCC_SM_EN, mask_sh),\
-       SF(MPCC0_MPCC_SM_CONTROL, MPCC_SM_MODE, mask_sh),\
-       SF(MPCC0_MPCC_SM_CONTROL, MPCC_SM_FRAME_ALT, mask_sh),\
-       SF(MPCC0_MPCC_SM_CONTROL, MPCC_SM_FIELD_ALT, mask_sh),\
-       SF(MPCC0_MPCC_SM_CONTROL, MPCC_SM_FORCE_NEXT_FRAME_POL, mask_sh),\
-       SF(MPCC0_MPCC_SM_CONTROL, MPCC_SM_FORCE_NEXT_TOP_POL, mask_sh),\
-       SF(MPC_OUT0_MUX, MPC_OUT_MUX, mask_sh),\
-       SF(MPCC0_MPCC_UPDATE_LOCK_SEL, MPCC_UPDATE_LOCK_SEL, mask_sh)
-
-#define MPC_REG_FIELD_LIST(type) \
-       type MPCC_TOP_SEL;\
-       type MPCC_BOT_SEL;\
-       type MPCC_MODE;\
-       type MPCC_ALPHA_BLND_MODE;\
-       type MPCC_ALPHA_MULTIPLIED_MODE;\
-       type MPCC_BLND_ACTIVE_OVERLAP_ONLY;\
-       type MPCC_GLOBAL_ALPHA;\
-       type MPCC_GLOBAL_GAIN;\
-       type MPCC_IDLE;\
-       type MPCC_BUSY;\
-       type MPCC_OPP_ID;\
-       type MPCC_BG_G_Y;\
-       type MPCC_BG_R_CR;\
-       type MPCC_BG_B_CB;\
-       type MPCC_SM_EN;\
-       type MPCC_SM_MODE;\
-       type MPCC_SM_FRAME_ALT;\
-       type MPCC_SM_FIELD_ALT;\
-       type MPCC_SM_FORCE_NEXT_FRAME_POL;\
-       type MPCC_SM_FORCE_NEXT_TOP_POL;\
-       type MPC_OUT_MUX;\
-       type MPCC_UPDATE_LOCK_SEL;\
-       type CUR_VUPDATE_LOCK_SET;
-
-struct dcn_mpc_registers {
-       MPC_COMMON_REG_VARIABLE_LIST
-};
-
-struct dcn_mpc_shift {
-       MPC_REG_FIELD_LIST(uint8_t)
-};
-
-struct dcn_mpc_mask {
-       MPC_REG_FIELD_LIST(uint32_t)
-};
-
-struct dcn10_mpc {
-       struct mpc base;
-
-       int mpcc_in_use_mask;
-       int num_mpcc;
-       const struct dcn_mpc_registers *mpc_regs;
-       const struct dcn_mpc_shift *mpc_shift;
-       const struct dcn_mpc_mask *mpc_mask;
-};
-
-void dcn10_mpc_construct(struct dcn10_mpc *mpcc10,
-       struct dc_context *ctx,
-       const struct dcn_mpc_registers *mpc_regs,
-       const struct dcn_mpc_shift *mpc_shift,
-       const struct dcn_mpc_mask *mpc_mask,
-       int num_mpcc);
-
-struct mpcc *mpc1_insert_plane(
-       struct mpc *mpc,
-       struct mpc_tree *tree,
-       struct mpcc_blnd_cfg *blnd_cfg,
-       struct mpcc_sm_cfg *sm_cfg,
-       struct mpcc *insert_above_mpcc,
-       int dpp_id,
-       int mpcc_id);
-
-void mpc1_remove_mpcc(
-       struct mpc *mpc,
-       struct mpc_tree *tree,
-       struct mpcc *mpcc);
-
-void mpc1_mpc_init(
-       struct mpc *mpc);
-
-void mpc1_mpc_init_single_inst(
-       struct mpc *mpc,
-       unsigned int mpcc_id);
-
-void mpc1_assert_idle_mpcc(
-       struct mpc *mpc,
-       int id);
-
-void mpc1_set_bg_color(
-       struct mpc *mpc,
-       struct tg_color *bg_color,
-       int id);
-
-void mpc1_update_stereo_mix(
-       struct mpc *mpc,
-       struct mpcc_sm_cfg *sm_cfg,
-       int mpcc_id);
-
-bool mpc1_is_mpcc_idle(
-       struct mpc *mpc,
-       int mpcc_id);
-
-void mpc1_assert_mpcc_idle_before_connect(
-       struct mpc *mpc,
-       int mpcc_id);
-
-void mpc1_init_mpcc_list_from_hw(
-       struct mpc *mpc,
-       struct mpc_tree *tree);
-
-struct mpcc *mpc1_get_mpcc(
-       struct mpc *mpc,
-       int mpcc_id);
-
-struct mpcc *mpc1_get_mpcc_for_dpp(
-       struct mpc_tree *tree,
-       int dpp_id);
-
-void mpc1_read_mpcc_state(
-               struct mpc *mpc,
-               int mpcc_inst,
-               struct mpcc_state *s);
-
-void mpc1_cursor_lock(struct mpc *mpc, int opp_id, bool lock);
-
-unsigned int mpc1_get_mpc_out_mux(struct mpc *mpc, int opp_id);
-#endif
index d92d2b4..25ba0d3 100644 (file)
@@ -1,8 +1,7 @@
 # SPDX-License-Identifier: MIT
 # Copyright Â© 2019-2024 Advanced Micro Devices, Inc. All rights reserved.
 
-DCN20 = dcn20_mpc.o \
-               dcn20_vmid.o dcn20_dwb.o dcn20_dwb_scl.o
+DCN20 = dcn20_vmid.o dcn20_dwb.o dcn20_dwb_scl.o
 
 AMD_DAL_DCN20 = $(addprefix $(AMDDALPATH)/dc/dcn20/,$(DCN20))
 
diff --git a/drivers/gpu/drm/amd/display/dc/dcn20/dcn20_mpc.c b/drivers/gpu/drm/amd/display/dc/dcn20/dcn20_mpc.c
deleted file mode 100644 (file)
index ea73473..0000000
+++ /dev/null
@@ -1,610 +0,0 @@
-/*
- * Copyright 2012-15 Advanced Micro Devices, Inc.
- *
- * Permission is hereby granted, free of charge, to any person obtaining a
- * copy of this software and associated documentation files (the "Software"),
- * to deal in the Software without restriction, including without limitation
- * the rights to use, copy, modify, merge, publish, distribute, sublicense,
- * and/or sell copies of the Software, and to permit persons to whom the
- * Software is furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice shall be included in
- * all copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
- * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
- * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
- * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
- * OTHER DEALINGS IN THE SOFTWARE.
- *
- * Authors: AMD
- *
- */
-
-#include "dcn20_mpc.h"
-
-#include "reg_helper.h"
-#include "dc.h"
-#include "mem_input.h"
-#include "dcn10/dcn10_cm_common.h"
-
-#define REG(reg)\
-       mpc20->mpc_regs->reg
-
-#define IND_REG(index) \
-       (index)
-
-#define CTX \
-       mpc20->base.ctx
-
-#undef FN
-#define FN(reg_name, field_name) \
-       mpc20->mpc_shift->field_name, mpc20->mpc_mask->field_name
-
-#define NUM_ELEMENTS(a) (sizeof(a) / sizeof((a)[0]))
-
-void mpc2_update_blending(
-       struct mpc *mpc,
-       struct mpcc_blnd_cfg *blnd_cfg,
-       int mpcc_id)
-{
-       struct dcn20_mpc *mpc20 = TO_DCN20_MPC(mpc);
-
-       struct mpcc *mpcc = mpc1_get_mpcc(mpc, mpcc_id);
-
-       REG_UPDATE_7(MPCC_CONTROL[mpcc_id],
-                       MPCC_ALPHA_BLND_MODE,           blnd_cfg->alpha_mode,
-                       MPCC_ALPHA_MULTIPLIED_MODE,     blnd_cfg->pre_multiplied_alpha,
-                       MPCC_BLND_ACTIVE_OVERLAP_ONLY,  blnd_cfg->overlap_only,
-                       MPCC_GLOBAL_ALPHA,              blnd_cfg->global_alpha,
-                       MPCC_GLOBAL_GAIN,               blnd_cfg->global_gain,
-                       MPCC_BG_BPC,                    blnd_cfg->background_color_bpc,
-                       MPCC_BOT_GAIN_MODE,             blnd_cfg->bottom_gain_mode);
-
-       REG_SET(MPCC_TOP_GAIN[mpcc_id], 0, MPCC_TOP_GAIN, blnd_cfg->top_gain);
-       REG_SET(MPCC_BOT_GAIN_INSIDE[mpcc_id], 0, MPCC_BOT_GAIN_INSIDE, blnd_cfg->bottom_inside_gain);
-       REG_SET(MPCC_BOT_GAIN_OUTSIDE[mpcc_id], 0, MPCC_BOT_GAIN_OUTSIDE, blnd_cfg->bottom_outside_gain);
-
-       mpcc->blnd_cfg = *blnd_cfg;
-}
-
-void mpc2_set_denorm(
-               struct mpc *mpc,
-               int opp_id,
-               enum dc_color_depth output_depth)
-{
-       struct dcn20_mpc *mpc20 = TO_DCN20_MPC(mpc);
-       int denorm_mode = 0;
-
-       switch (output_depth) {
-       case COLOR_DEPTH_666:
-               denorm_mode = 1;
-               break;
-       case COLOR_DEPTH_888:
-               denorm_mode = 2;
-               break;
-       case COLOR_DEPTH_999:
-               denorm_mode = 3;
-               break;
-       case COLOR_DEPTH_101010:
-               denorm_mode = 4;
-               break;
-       case COLOR_DEPTH_111111:
-               denorm_mode = 5;
-               break;
-       case COLOR_DEPTH_121212:
-               denorm_mode = 6;
-               break;
-       case COLOR_DEPTH_141414:
-       case COLOR_DEPTH_161616:
-       default:
-               /* not valid used case! */
-               break;
-       }
-
-       REG_UPDATE(DENORM_CONTROL[opp_id],
-                       MPC_OUT_DENORM_MODE, denorm_mode);
-}
-
-void mpc2_set_denorm_clamp(
-               struct mpc *mpc,
-               int opp_id,
-               struct mpc_denorm_clamp denorm_clamp)
-{
-       struct dcn20_mpc *mpc20 = TO_DCN20_MPC(mpc);
-
-       REG_UPDATE_2(DENORM_CONTROL[opp_id],
-                       MPC_OUT_DENORM_CLAMP_MAX_R_CR, denorm_clamp.clamp_max_r_cr,
-                       MPC_OUT_DENORM_CLAMP_MIN_R_CR, denorm_clamp.clamp_min_r_cr);
-       REG_UPDATE_2(DENORM_CLAMP_G_Y[opp_id],
-                       MPC_OUT_DENORM_CLAMP_MAX_G_Y, denorm_clamp.clamp_max_g_y,
-                       MPC_OUT_DENORM_CLAMP_MIN_G_Y, denorm_clamp.clamp_min_g_y);
-       REG_UPDATE_2(DENORM_CLAMP_B_CB[opp_id],
-                       MPC_OUT_DENORM_CLAMP_MAX_B_CB, denorm_clamp.clamp_max_b_cb,
-                       MPC_OUT_DENORM_CLAMP_MIN_B_CB, denorm_clamp.clamp_min_b_cb);
-}
-
-
-
-void mpc2_set_output_csc(
-               struct mpc *mpc,
-               int opp_id,
-               const uint16_t *regval,
-               enum mpc_output_csc_mode ocsc_mode)
-{
-       uint32_t cur_mode;
-       struct dcn20_mpc *mpc20 = TO_DCN20_MPC(mpc);
-       struct color_matrices_reg ocsc_regs;
-
-       if (ocsc_mode == MPC_OUTPUT_CSC_DISABLE) {
-               REG_SET(CSC_MODE[opp_id], 0, MPC_OCSC_MODE, ocsc_mode);
-               return;
-       }
-
-       if (regval == NULL) {
-               BREAK_TO_DEBUGGER();
-               return;
-       }
-
-       /* determine which CSC coefficients (A or B) we are using
-        * currently.  select the alternate set to double buffer
-        * the CSC update so CSC is updated on frame boundary
-        */
-       IX_REG_GET(MPC_OCSC_TEST_DEBUG_INDEX, MPC_OCSC_TEST_DEBUG_DATA,
-                                               MPC_OCSC_TEST_DEBUG_DATA_STATUS_IDX,
-                                               MPC_OCSC_TEST_DEBUG_DATA_OCSC_MODE, &cur_mode);
-
-       if (cur_mode != MPC_OUTPUT_CSC_COEF_A)
-               ocsc_mode = MPC_OUTPUT_CSC_COEF_A;
-       else
-               ocsc_mode = MPC_OUTPUT_CSC_COEF_B;
-
-       ocsc_regs.shifts.csc_c11 = mpc20->mpc_shift->MPC_OCSC_C11_A;
-       ocsc_regs.masks.csc_c11  = mpc20->mpc_mask->MPC_OCSC_C11_A;
-       ocsc_regs.shifts.csc_c12 = mpc20->mpc_shift->MPC_OCSC_C12_A;
-       ocsc_regs.masks.csc_c12 = mpc20->mpc_mask->MPC_OCSC_C12_A;
-
-       if (ocsc_mode == MPC_OUTPUT_CSC_COEF_A) {
-               ocsc_regs.csc_c11_c12 = REG(CSC_C11_C12_A[opp_id]);
-               ocsc_regs.csc_c33_c34 = REG(CSC_C33_C34_A[opp_id]);
-       } else {
-               ocsc_regs.csc_c11_c12 = REG(CSC_C11_C12_B[opp_id]);
-               ocsc_regs.csc_c33_c34 = REG(CSC_C33_C34_B[opp_id]);
-       }
-
-       cm_helper_program_color_matrices(
-                       mpc20->base.ctx,
-                       regval,
-                       &ocsc_regs);
-
-       REG_SET(CSC_MODE[opp_id], 0, MPC_OCSC_MODE, ocsc_mode);
-}
-
-void mpc2_set_ocsc_default(
-               struct mpc *mpc,
-               int opp_id,
-               enum dc_color_space color_space,
-               enum mpc_output_csc_mode ocsc_mode)
-{
-       uint32_t cur_mode;
-       struct dcn20_mpc *mpc20 = TO_DCN20_MPC(mpc);
-       uint32_t arr_size;
-       struct color_matrices_reg ocsc_regs;
-       const uint16_t *regval = NULL;
-
-       if (ocsc_mode == MPC_OUTPUT_CSC_DISABLE) {
-               REG_SET(CSC_MODE[opp_id], 0, MPC_OCSC_MODE, ocsc_mode);
-               return;
-       }
-
-       regval = find_color_matrix(color_space, &arr_size);
-
-       if (regval == NULL) {
-               BREAK_TO_DEBUGGER();
-               return;
-       }
-
-       /* determine which CSC coefficients (A or B) we are using
-        * currently.  select the alternate set to double buffer
-        * the CSC update so CSC is updated on frame boundary
-        */
-       IX_REG_GET(MPC_OCSC_TEST_DEBUG_INDEX, MPC_OCSC_TEST_DEBUG_DATA,
-                                               MPC_OCSC_TEST_DEBUG_DATA_STATUS_IDX,
-                                               MPC_OCSC_TEST_DEBUG_DATA_OCSC_MODE, &cur_mode);
-
-       if (cur_mode != MPC_OUTPUT_CSC_COEF_A)
-               ocsc_mode = MPC_OUTPUT_CSC_COEF_A;
-       else
-               ocsc_mode = MPC_OUTPUT_CSC_COEF_B;
-
-       ocsc_regs.shifts.csc_c11 = mpc20->mpc_shift->MPC_OCSC_C11_A;
-       ocsc_regs.masks.csc_c11  = mpc20->mpc_mask->MPC_OCSC_C11_A;
-       ocsc_regs.shifts.csc_c12 = mpc20->mpc_shift->MPC_OCSC_C12_A;
-       ocsc_regs.masks.csc_c12 = mpc20->mpc_mask->MPC_OCSC_C12_A;
-
-
-       if (ocsc_mode == MPC_OUTPUT_CSC_COEF_A) {
-               ocsc_regs.csc_c11_c12 = REG(CSC_C11_C12_A[opp_id]);
-               ocsc_regs.csc_c33_c34 = REG(CSC_C33_C34_A[opp_id]);
-       } else {
-               ocsc_regs.csc_c11_c12 = REG(CSC_C11_C12_B[opp_id]);
-               ocsc_regs.csc_c33_c34 = REG(CSC_C33_C34_B[opp_id]);
-       }
-
-       cm_helper_program_color_matrices(
-                       mpc20->base.ctx,
-                       regval,
-                       &ocsc_regs);
-
-       REG_SET(CSC_MODE[opp_id], 0, MPC_OCSC_MODE, ocsc_mode);
-}
-
-static void mpc2_ogam_get_reg_field(
-               struct mpc *mpc,
-               struct xfer_func_reg *reg)
-{
-       struct dcn20_mpc *mpc20 = TO_DCN20_MPC(mpc);
-
-       reg->shifts.exp_region0_lut_offset = mpc20->mpc_shift->MPCC_OGAM_RAMA_EXP_REGION0_LUT_OFFSET;
-       reg->masks.exp_region0_lut_offset = mpc20->mpc_mask->MPCC_OGAM_RAMA_EXP_REGION0_LUT_OFFSET;
-       reg->shifts.exp_region0_num_segments = mpc20->mpc_shift->MPCC_OGAM_RAMA_EXP_REGION0_NUM_SEGMENTS;
-       reg->masks.exp_region0_num_segments = mpc20->mpc_mask->MPCC_OGAM_RAMA_EXP_REGION0_NUM_SEGMENTS;
-       reg->shifts.exp_region1_lut_offset = mpc20->mpc_shift->MPCC_OGAM_RAMA_EXP_REGION1_LUT_OFFSET;
-       reg->masks.exp_region1_lut_offset = mpc20->mpc_mask->MPCC_OGAM_RAMA_EXP_REGION1_LUT_OFFSET;
-       reg->shifts.exp_region1_num_segments = mpc20->mpc_shift->MPCC_OGAM_RAMA_EXP_REGION1_NUM_SEGMENTS;
-       reg->masks.exp_region1_num_segments = mpc20->mpc_mask->MPCC_OGAM_RAMA_EXP_REGION1_NUM_SEGMENTS;
-       reg->shifts.field_region_end = mpc20->mpc_shift->MPCC_OGAM_RAMA_EXP_REGION_END_B;
-       reg->masks.field_region_end = mpc20->mpc_mask->MPCC_OGAM_RAMA_EXP_REGION_END_B;
-       reg->shifts.field_region_end_slope = mpc20->mpc_shift->MPCC_OGAM_RAMA_EXP_REGION_END_SLOPE_B;
-       reg->masks.field_region_end_slope = mpc20->mpc_mask->MPCC_OGAM_RAMA_EXP_REGION_END_SLOPE_B;
-       reg->shifts.field_region_end_base = mpc20->mpc_shift->MPCC_OGAM_RAMA_EXP_REGION_END_BASE_B;
-       reg->masks.field_region_end_base = mpc20->mpc_mask->MPCC_OGAM_RAMA_EXP_REGION_END_BASE_B;
-       reg->shifts.field_region_linear_slope = mpc20->mpc_shift->MPCC_OGAM_RAMA_EXP_REGION_LINEAR_SLOPE_B;
-       reg->masks.field_region_linear_slope = mpc20->mpc_mask->MPCC_OGAM_RAMA_EXP_REGION_LINEAR_SLOPE_B;
-       reg->shifts.exp_region_start = mpc20->mpc_shift->MPCC_OGAM_RAMA_EXP_REGION_START_B;
-       reg->masks.exp_region_start = mpc20->mpc_mask->MPCC_OGAM_RAMA_EXP_REGION_START_B;
-       reg->shifts.exp_resion_start_segment = mpc20->mpc_shift->MPCC_OGAM_RAMA_EXP_REGION_START_SEGMENT_B;
-       reg->masks.exp_resion_start_segment = mpc20->mpc_mask->MPCC_OGAM_RAMA_EXP_REGION_START_SEGMENT_B;
-}
-
-void mpc20_power_on_ogam_lut(
-               struct mpc *mpc, int mpcc_id,
-               bool power_on)
-{
-       struct dcn20_mpc *mpc20 = TO_DCN20_MPC(mpc);
-
-       REG_SET(MPCC_MEM_PWR_CTRL[mpcc_id], 0,
-                       MPCC_OGAM_MEM_PWR_DIS, power_on == true ? 1:0);
-
-}
-
-static void mpc20_configure_ogam_lut(
-               struct mpc *mpc, int mpcc_id,
-               bool is_ram_a)
-{
-       struct dcn20_mpc *mpc20 = TO_DCN20_MPC(mpc);
-
-       REG_UPDATE_2(MPCC_OGAM_LUT_RAM_CONTROL[mpcc_id],
-                       MPCC_OGAM_LUT_WRITE_EN_MASK, 7,
-                       MPCC_OGAM_LUT_RAM_SEL, is_ram_a == true ? 0:1);
-
-       REG_SET(MPCC_OGAM_LUT_INDEX[mpcc_id], 0, MPCC_OGAM_LUT_INDEX, 0);
-}
-
-static enum dc_lut_mode mpc20_get_ogam_current(struct mpc *mpc, int mpcc_id)
-{
-       enum dc_lut_mode mode;
-       uint32_t state_mode;
-       struct dcn20_mpc *mpc20 = TO_DCN20_MPC(mpc);
-
-       REG_GET(MPCC_OGAM_LUT_RAM_CONTROL[mpcc_id], MPCC_OGAM_CONFIG_STATUS, &state_mode);
-
-       switch (state_mode) {
-       case 0:
-               mode = LUT_BYPASS;
-               break;
-       case 1:
-               mode = LUT_RAM_A;
-               break;
-       case 2:
-               mode = LUT_RAM_B;
-               break;
-       default:
-               mode = LUT_BYPASS;
-               break;
-       }
-
-       return mode;
-}
-
-static void mpc2_program_lutb(struct mpc *mpc, int mpcc_id,
-                       const struct pwl_params *params)
-{
-       struct dcn20_mpc *mpc20 = TO_DCN20_MPC(mpc);
-       struct xfer_func_reg gam_regs;
-
-       mpc2_ogam_get_reg_field(mpc, &gam_regs);
-
-       gam_regs.start_cntl_b = REG(MPCC_OGAM_RAMB_START_CNTL_B[mpcc_id]);
-       gam_regs.start_cntl_g = REG(MPCC_OGAM_RAMB_START_CNTL_G[mpcc_id]);
-       gam_regs.start_cntl_r = REG(MPCC_OGAM_RAMB_START_CNTL_R[mpcc_id]);
-       gam_regs.start_slope_cntl_b = REG(MPCC_OGAM_RAMB_SLOPE_CNTL_B[mpcc_id]);
-       gam_regs.start_slope_cntl_g = REG(MPCC_OGAM_RAMB_SLOPE_CNTL_G[mpcc_id]);
-       gam_regs.start_slope_cntl_r = REG(MPCC_OGAM_RAMB_SLOPE_CNTL_R[mpcc_id]);
-       gam_regs.start_end_cntl1_b = REG(MPCC_OGAM_RAMB_END_CNTL1_B[mpcc_id]);
-       gam_regs.start_end_cntl2_b = REG(MPCC_OGAM_RAMB_END_CNTL2_B[mpcc_id]);
-       gam_regs.start_end_cntl1_g = REG(MPCC_OGAM_RAMB_END_CNTL1_G[mpcc_id]);
-       gam_regs.start_end_cntl2_g = REG(MPCC_OGAM_RAMB_END_CNTL2_G[mpcc_id]);
-       gam_regs.start_end_cntl1_r = REG(MPCC_OGAM_RAMB_END_CNTL1_R[mpcc_id]);
-       gam_regs.start_end_cntl2_r = REG(MPCC_OGAM_RAMB_END_CNTL2_R[mpcc_id]);
-       gam_regs.region_start = REG(MPCC_OGAM_RAMB_REGION_0_1[mpcc_id]);
-       gam_regs.region_end = REG(MPCC_OGAM_RAMB_REGION_32_33[mpcc_id]);
-
-       cm_helper_program_xfer_func(mpc20->base.ctx, params, &gam_regs);
-
-}
-
-static void mpc2_program_luta(struct mpc *mpc, int mpcc_id,
-               const struct pwl_params *params)
-{
-       struct dcn20_mpc *mpc20 = TO_DCN20_MPC(mpc);
-       struct xfer_func_reg gam_regs;
-
-       mpc2_ogam_get_reg_field(mpc, &gam_regs);
-
-       gam_regs.start_cntl_b = REG(MPCC_OGAM_RAMA_START_CNTL_B[mpcc_id]);
-       gam_regs.start_cntl_g = REG(MPCC_OGAM_RAMA_START_CNTL_G[mpcc_id]);
-       gam_regs.start_cntl_r = REG(MPCC_OGAM_RAMA_START_CNTL_R[mpcc_id]);
-       gam_regs.start_slope_cntl_b = REG(MPCC_OGAM_RAMA_SLOPE_CNTL_B[mpcc_id]);
-       gam_regs.start_slope_cntl_g = REG(MPCC_OGAM_RAMA_SLOPE_CNTL_G[mpcc_id]);
-       gam_regs.start_slope_cntl_r = REG(MPCC_OGAM_RAMA_SLOPE_CNTL_R[mpcc_id]);
-       gam_regs.start_end_cntl1_b = REG(MPCC_OGAM_RAMA_END_CNTL1_B[mpcc_id]);
-       gam_regs.start_end_cntl2_b = REG(MPCC_OGAM_RAMA_END_CNTL2_B[mpcc_id]);
-       gam_regs.start_end_cntl1_g = REG(MPCC_OGAM_RAMA_END_CNTL1_G[mpcc_id]);
-       gam_regs.start_end_cntl2_g = REG(MPCC_OGAM_RAMA_END_CNTL2_G[mpcc_id]);
-       gam_regs.start_end_cntl1_r = REG(MPCC_OGAM_RAMA_END_CNTL1_R[mpcc_id]);
-       gam_regs.start_end_cntl2_r = REG(MPCC_OGAM_RAMA_END_CNTL2_R[mpcc_id]);
-       gam_regs.region_start = REG(MPCC_OGAM_RAMA_REGION_0_1[mpcc_id]);
-       gam_regs.region_end = REG(MPCC_OGAM_RAMA_REGION_32_33[mpcc_id]);
-
-       cm_helper_program_xfer_func(mpc20->base.ctx, params, &gam_regs);
-
-}
-
-static void mpc20_program_ogam_pwl(
-               struct mpc *mpc, int mpcc_id,
-               const struct pwl_result_data *rgb,
-               uint32_t num)
-{
-       uint32_t i;
-       struct dcn20_mpc *mpc20 = TO_DCN20_MPC(mpc);
-
-       PERF_TRACE();
-       REG_SEQ_START();
-
-       for (i = 0 ; i < num; i++) {
-               REG_SET(MPCC_OGAM_LUT_DATA[mpcc_id], 0, MPCC_OGAM_LUT_DATA, rgb[i].red_reg);
-               REG_SET(MPCC_OGAM_LUT_DATA[mpcc_id], 0, MPCC_OGAM_LUT_DATA, rgb[i].green_reg);
-               REG_SET(MPCC_OGAM_LUT_DATA[mpcc_id], 0, MPCC_OGAM_LUT_DATA, rgb[i].blue_reg);
-
-               REG_SET(MPCC_OGAM_LUT_DATA[mpcc_id], 0,
-                               MPCC_OGAM_LUT_DATA, rgb[i].delta_red_reg);
-               REG_SET(MPCC_OGAM_LUT_DATA[mpcc_id], 0,
-                               MPCC_OGAM_LUT_DATA, rgb[i].delta_green_reg);
-               REG_SET(MPCC_OGAM_LUT_DATA[mpcc_id], 0,
-                               MPCC_OGAM_LUT_DATA, rgb[i].delta_blue_reg);
-       }
-
-       REG_SEQ_SUBMIT();
-       PERF_TRACE();
-       REG_SEQ_WAIT_DONE();
-       PERF_TRACE();
-}
-
-static void apply_DEDCN20_305_wa(struct mpc *mpc, int mpcc_id,
-                                enum dc_lut_mode current_mode,
-                                enum dc_lut_mode next_mode)
-{
-       struct dcn20_mpc *mpc20 = TO_DCN20_MPC(mpc);
-
-       if (mpc->ctx->dc->debug.cm_in_bypass) {
-               REG_SET(MPCC_OGAM_MODE[mpcc_id], 0, MPCC_OGAM_MODE, 0);
-               return;
-       }
-
-       if (mpc->ctx->dc->work_arounds.dedcn20_305_wa == false) {
-               /*hw fixed in new review*/
-               return;
-       }
-       if (current_mode == LUT_BYPASS)
-               /*this will only work if OTG is locked.
-                *if we were to support OTG unlock case,
-                *the workaround will be more complex
-                */
-               REG_SET(MPCC_OGAM_MODE[mpcc_id], 0, MPCC_OGAM_MODE,
-                       next_mode == LUT_RAM_A ? 1:2);
-}
-
-void mpc2_set_output_gamma(
-               struct mpc *mpc,
-               int mpcc_id,
-               const struct pwl_params *params)
-{
-       enum dc_lut_mode current_mode;
-       enum dc_lut_mode next_mode;
-       struct dcn20_mpc *mpc20 = TO_DCN20_MPC(mpc);
-
-       if (mpc->ctx->dc->debug.cm_in_bypass) {
-               REG_SET(MPCC_OGAM_MODE[mpcc_id], 0, MPCC_OGAM_MODE, 0);
-               return;
-       }
-
-       if (params == NULL) {
-               REG_SET(MPCC_OGAM_MODE[mpcc_id], 0, MPCC_OGAM_MODE, 0);
-               return;
-       }
-
-       current_mode = mpc20_get_ogam_current(mpc, mpcc_id);
-       if (current_mode == LUT_BYPASS || current_mode == LUT_RAM_A)
-               next_mode = LUT_RAM_B;
-       else
-               next_mode = LUT_RAM_A;
-
-       mpc20_power_on_ogam_lut(mpc, mpcc_id, true);
-       mpc20_configure_ogam_lut(mpc, mpcc_id, next_mode == LUT_RAM_A);
-
-       if (next_mode == LUT_RAM_A)
-               mpc2_program_luta(mpc, mpcc_id, params);
-       else
-               mpc2_program_lutb(mpc, mpcc_id, params);
-
-       apply_DEDCN20_305_wa(mpc, mpcc_id, current_mode, next_mode);
-
-       mpc20_program_ogam_pwl(
-                       mpc, mpcc_id, params->rgb_resulted, params->hw_points_num);
-
-       REG_SET(MPCC_OGAM_MODE[mpcc_id], 0, MPCC_OGAM_MODE,
-               next_mode == LUT_RAM_A ? 1:2);
-}
-void mpc2_assert_idle_mpcc(struct mpc *mpc, int id)
-{
-       struct dcn20_mpc *mpc20 = TO_DCN20_MPC(mpc);
-       unsigned int mpc_disabled;
-
-       ASSERT(!(mpc20->mpcc_in_use_mask & 1 << id));
-       REG_GET(MPCC_STATUS[id], MPCC_DISABLED, &mpc_disabled);
-       if (mpc_disabled)
-               return;
-
-       REG_WAIT(MPCC_STATUS[id],
-                       MPCC_IDLE, 1,
-                       1, 100000);
-}
-
-void mpc2_assert_mpcc_idle_before_connect(struct mpc *mpc, int mpcc_id)
-{
-       struct dcn20_mpc *mpc20 = TO_DCN20_MPC(mpc);
-       unsigned int top_sel, mpc_busy, mpc_idle, mpc_disabled;
-
-       REG_GET(MPCC_TOP_SEL[mpcc_id],
-                       MPCC_TOP_SEL, &top_sel);
-
-       REG_GET_3(MPCC_STATUS[mpcc_id],
-                       MPCC_BUSY, &mpc_busy,
-                       MPCC_IDLE, &mpc_idle,
-                       MPCC_DISABLED, &mpc_disabled);
-
-       if (top_sel == 0xf) {
-               ASSERT(!mpc_busy);
-               ASSERT(mpc_idle);
-               ASSERT(mpc_disabled);
-       } else {
-               ASSERT(!mpc_disabled);
-               ASSERT(!mpc_idle);
-       }
-}
-
-static void mpc2_init_mpcc(struct mpcc *mpcc, int mpcc_inst)
-{
-       mpcc->mpcc_id = mpcc_inst;
-       mpcc->dpp_id = 0xf;
-       mpcc->mpcc_bot = NULL;
-       mpcc->blnd_cfg.overlap_only = false;
-       mpcc->blnd_cfg.global_alpha = 0xff;
-       mpcc->blnd_cfg.global_gain = 0xff;
-       mpcc->blnd_cfg.background_color_bpc = 4;
-       mpcc->blnd_cfg.bottom_gain_mode = 0;
-       mpcc->blnd_cfg.top_gain = 0x1f000;
-       mpcc->blnd_cfg.bottom_inside_gain = 0x1f000;
-       mpcc->blnd_cfg.bottom_outside_gain = 0x1f000;
-       mpcc->sm_cfg.enable = false;
-}
-
-static struct mpcc *mpc2_get_mpcc_for_dpp(struct mpc_tree *tree, int dpp_id)
-{
-       struct mpcc *tmp_mpcc = tree->opp_list;
-
-       while (tmp_mpcc != NULL) {
-               if (tmp_mpcc->dpp_id == 0xf || tmp_mpcc->dpp_id == dpp_id)
-                       return tmp_mpcc;
-
-               /* avoid circular linked list */
-               ASSERT(tmp_mpcc != tmp_mpcc->mpcc_bot);
-               if (tmp_mpcc == tmp_mpcc->mpcc_bot)
-                       break;
-
-               tmp_mpcc = tmp_mpcc->mpcc_bot;
-       }
-       return NULL;
-}
-
-static void mpc2_read_mpcc_state(
-               struct mpc *mpc,
-               int mpcc_inst,
-               struct mpcc_state *s)
-{
-       struct dcn20_mpc *mpc20 = TO_DCN20_MPC(mpc);
-
-       REG_GET(MPCC_OPP_ID[mpcc_inst], MPCC_OPP_ID, &s->opp_id);
-       REG_GET(MPCC_TOP_SEL[mpcc_inst], MPCC_TOP_SEL, &s->dpp_id);
-       REG_GET(MPCC_BOT_SEL[mpcc_inst], MPCC_BOT_SEL, &s->bot_mpcc_id);
-       REG_GET_4(MPCC_CONTROL[mpcc_inst], MPCC_MODE, &s->mode,
-                       MPCC_ALPHA_BLND_MODE, &s->alpha_mode,
-                       MPCC_ALPHA_MULTIPLIED_MODE, &s->pre_multiplied_alpha,
-                       MPCC_BLND_ACTIVE_OVERLAP_ONLY, &s->overlap_only);
-       REG_GET_2(MPCC_STATUS[mpcc_inst], MPCC_IDLE, &s->idle,
-                       MPCC_BUSY, &s->busy);
-
-       /* Gamma block state */
-       REG_GET(MPCC_OGAM_LUT_RAM_CONTROL[mpcc_inst],
-               MPCC_OGAM_CONFIG_STATUS, &s->rgam_mode);
-}
-
-static const struct mpc_funcs dcn20_mpc_funcs = {
-       .read_mpcc_state = mpc2_read_mpcc_state,
-       .insert_plane = mpc1_insert_plane,
-       .remove_mpcc = mpc1_remove_mpcc,
-       .mpc_init = mpc1_mpc_init,
-       .mpc_init_single_inst = mpc1_mpc_init_single_inst,
-       .update_blending = mpc2_update_blending,
-       .cursor_lock = mpc1_cursor_lock,
-       .get_mpcc_for_dpp = mpc2_get_mpcc_for_dpp,
-       .wait_for_idle = mpc2_assert_idle_mpcc,
-       .assert_mpcc_idle_before_connect = mpc2_assert_mpcc_idle_before_connect,
-       .init_mpcc_list_from_hw = mpc1_init_mpcc_list_from_hw,
-       .set_denorm = mpc2_set_denorm,
-       .set_denorm_clamp = mpc2_set_denorm_clamp,
-       .set_output_csc = mpc2_set_output_csc,
-       .set_ocsc_default = mpc2_set_ocsc_default,
-       .set_output_gamma = mpc2_set_output_gamma,
-       .power_on_mpc_mem_pwr = mpc20_power_on_ogam_lut,
-       .get_mpc_out_mux = mpc1_get_mpc_out_mux,
-       .set_bg_color = mpc1_set_bg_color,
-};
-
-void dcn20_mpc_construct(struct dcn20_mpc *mpc20,
-       struct dc_context *ctx,
-       const struct dcn20_mpc_registers *mpc_regs,
-       const struct dcn20_mpc_shift *mpc_shift,
-       const struct dcn20_mpc_mask *mpc_mask,
-       int num_mpcc)
-{
-       int i;
-
-       mpc20->base.ctx = ctx;
-
-       mpc20->base.funcs = &dcn20_mpc_funcs;
-
-       mpc20->mpc_regs = mpc_regs;
-       mpc20->mpc_shift = mpc_shift;
-       mpc20->mpc_mask = mpc_mask;
-
-       mpc20->mpcc_in_use_mask = 0;
-       mpc20->num_mpcc = num_mpcc;
-
-       for (i = 0; i < MAX_MPCC; i++)
-               mpc2_init_mpcc(&mpc20->base.mpcc_array[i], i);
-}
-
diff --git a/drivers/gpu/drm/amd/display/dc/dcn20/dcn20_mpc.h b/drivers/gpu/drm/amd/display/dc/dcn20/dcn20_mpc.h
deleted file mode 100644 (file)
index 496658f..0000000
+++ /dev/null
@@ -1,312 +0,0 @@
-/* Copyright 2012-15 Advanced Micro Devices, Inc.
- *
- * Permission is hereby granted, free of charge, to any person obtaining a
- * copy of this software and associated documentation files (the "Software"),
- * to deal in the Software without restriction, including without limitation
- * the rights to use, copy, modify, merge, publish, distribute, sublicense,
- * and/or sell copies of the Software, and to permit persons to whom the
- * Software is furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice shall be included in
- * all copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
- * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
- * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
- * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
- * OTHER DEALINGS IN THE SOFTWARE.
- *
- * Authors: AMD
- *
- */
-
-#ifndef __DC_MPCC_DCN20_H__
-#define __DC_MPCC_DCN20_H__
-
-#include "dcn10/dcn10_mpc.h"
-
-#define TO_DCN20_MPC(mpc_base) \
-       container_of(mpc_base, struct dcn20_mpc, base)
-
-#define MPC_REG_LIST_DCN2_0(inst)\
-       MPC_COMMON_REG_LIST_DCN1_0(inst),\
-       SRII(MPCC_TOP_GAIN, MPCC, inst),\
-       SRII(MPCC_BOT_GAIN_INSIDE, MPCC, inst),\
-       SRII(MPCC_BOT_GAIN_OUTSIDE, MPCC, inst),\
-       SRII(MPCC_OGAM_RAMA_START_CNTL_B, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMA_START_CNTL_G, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMA_START_CNTL_R, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMA_SLOPE_CNTL_B, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMA_SLOPE_CNTL_G, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMA_SLOPE_CNTL_R, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMA_END_CNTL1_B, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMA_END_CNTL2_B, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMA_END_CNTL1_G, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMA_END_CNTL2_G, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMA_END_CNTL1_R, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMA_END_CNTL2_R, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMA_REGION_0_1, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMA_REGION_32_33, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMB_START_CNTL_B, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMB_START_CNTL_G, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMB_START_CNTL_R, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMB_SLOPE_CNTL_B, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMB_SLOPE_CNTL_G, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMB_SLOPE_CNTL_R, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMB_END_CNTL1_B, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMB_END_CNTL2_B, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMB_END_CNTL1_G, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMB_END_CNTL2_G, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMB_END_CNTL1_R, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMB_END_CNTL2_R, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMB_REGION_0_1, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMB_REGION_32_33, MPCC_OGAM, inst),\
-       SRII(MPCC_MEM_PWR_CTRL, MPCC, inst),\
-       SRII(MPCC_OGAM_LUT_INDEX, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_LUT_RAM_CONTROL, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_LUT_DATA, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_MODE, MPCC_OGAM, inst)
-
-#define MPC_OUT_MUX_REG_LIST_DCN2_0(inst) \
-       MPC_OUT_MUX_COMMON_REG_LIST_DCN1_0(inst),\
-       SRII(CSC_MODE, MPC_OUT, inst),\
-       SRII(CSC_C11_C12_A, MPC_OUT, inst),\
-       SRII(CSC_C33_C34_A, MPC_OUT, inst),\
-       SRII(CSC_C11_C12_B, MPC_OUT, inst),\
-       SRII(CSC_C33_C34_B, MPC_OUT, inst),\
-       SRII(DENORM_CONTROL, MPC_OUT, inst),\
-       SRII(DENORM_CLAMP_G_Y, MPC_OUT, inst),\
-       SRII(DENORM_CLAMP_B_CB, MPC_OUT, inst)
-
-#define MPC_DBG_REG_LIST_DCN2_0() \
-       SR(MPC_OCSC_TEST_DEBUG_DATA),\
-       SR(MPC_OCSC_TEST_DEBUG_INDEX)
-
-#define MPC_REG_VARIABLE_LIST_DCN2_0 \
-       MPC_COMMON_REG_VARIABLE_LIST \
-       uint32_t MPCC_TOP_GAIN[MAX_MPCC]; \
-       uint32_t MPCC_BOT_GAIN_INSIDE[MAX_MPCC]; \
-       uint32_t MPCC_BOT_GAIN_OUTSIDE[MAX_MPCC]; \
-       uint32_t MPCC_OGAM_RAMA_START_CNTL_B[MAX_MPCC]; \
-       uint32_t MPCC_OGAM_RAMA_START_CNTL_G[MAX_MPCC]; \
-       uint32_t MPCC_OGAM_RAMA_START_CNTL_R[MAX_MPCC]; \
-       uint32_t MPCC_OGAM_RAMA_SLOPE_CNTL_B[MAX_MPCC]; \
-       uint32_t MPCC_OGAM_RAMA_SLOPE_CNTL_G[MAX_MPCC]; \
-       uint32_t MPCC_OGAM_RAMA_SLOPE_CNTL_R[MAX_MPCC]; \
-       uint32_t MPCC_OGAM_RAMA_END_CNTL1_B[MAX_MPCC]; \
-       uint32_t MPCC_OGAM_RAMA_END_CNTL2_B[MAX_MPCC]; \
-       uint32_t MPCC_OGAM_RAMA_END_CNTL1_G[MAX_MPCC]; \
-       uint32_t MPCC_OGAM_RAMA_END_CNTL2_G[MAX_MPCC]; \
-       uint32_t MPCC_OGAM_RAMA_END_CNTL1_R[MAX_MPCC]; \
-       uint32_t MPCC_OGAM_RAMA_END_CNTL2_R[MAX_MPCC]; \
-       uint32_t MPCC_OGAM_RAMA_REGION_0_1[MAX_MPCC]; \
-       uint32_t MPCC_OGAM_RAMA_REGION_32_33[MAX_MPCC]; \
-       uint32_t MPCC_OGAM_RAMB_START_CNTL_B[MAX_MPCC]; \
-       uint32_t MPCC_OGAM_RAMB_START_CNTL_G[MAX_MPCC]; \
-       uint32_t MPCC_OGAM_RAMB_START_CNTL_R[MAX_MPCC]; \
-       uint32_t MPCC_OGAM_RAMB_SLOPE_CNTL_B[MAX_MPCC]; \
-       uint32_t MPCC_OGAM_RAMB_SLOPE_CNTL_G[MAX_MPCC]; \
-       uint32_t MPCC_OGAM_RAMB_SLOPE_CNTL_R[MAX_MPCC]; \
-       uint32_t MPCC_OGAM_RAMB_END_CNTL1_B[MAX_MPCC]; \
-       uint32_t MPCC_OGAM_RAMB_END_CNTL2_B[MAX_MPCC]; \
-       uint32_t MPCC_OGAM_RAMB_END_CNTL1_G[MAX_MPCC]; \
-       uint32_t MPCC_OGAM_RAMB_END_CNTL2_G[MAX_MPCC]; \
-       uint32_t MPCC_OGAM_RAMB_END_CNTL1_R[MAX_MPCC]; \
-       uint32_t MPCC_OGAM_RAMB_END_CNTL2_R[MAX_MPCC]; \
-       uint32_t MPCC_OGAM_RAMB_REGION_0_1[MAX_MPCC]; \
-       uint32_t MPCC_OGAM_RAMB_REGION_32_33[MAX_MPCC];\
-       uint32_t MPCC_MEM_PWR_CTRL[MAX_MPCC];\
-       uint32_t MPCC_OGAM_LUT_INDEX[MAX_MPCC];\
-       uint32_t MPCC_OGAM_LUT_RAM_CONTROL[MAX_MPCC];\
-       uint32_t MPCC_OGAM_LUT_DATA[MAX_MPCC];\
-       uint32_t MPCC_OGAM_MODE[MAX_MPCC];\
-       uint32_t MPC_OCSC_TEST_DEBUG_DATA;\
-       uint32_t MPC_OCSC_TEST_DEBUG_INDEX;\
-       uint32_t CSC_MODE[MAX_OPP]; \
-       uint32_t CSC_C11_C12_A[MAX_OPP]; \
-       uint32_t CSC_C33_C34_A[MAX_OPP]; \
-       uint32_t CSC_C11_C12_B[MAX_OPP]; \
-       uint32_t CSC_C33_C34_B[MAX_OPP]; \
-       uint32_t DENORM_CONTROL[MAX_OPP]; \
-       uint32_t DENORM_CLAMP_G_Y[MAX_OPP]; \
-       uint32_t DENORM_CLAMP_B_CB[MAX_OPP];
-
-#define MPC_COMMON_MASK_SH_LIST_DCN2_0(mask_sh) \
-       MPC_COMMON_MASK_SH_LIST_DCN1_0(mask_sh),\
-       SF(MPCC0_MPCC_CONTROL, MPCC_BG_BPC, mask_sh),\
-       SF(MPCC0_MPCC_CONTROL, MPCC_BOT_GAIN_MODE, mask_sh),\
-       SF(MPCC0_MPCC_TOP_GAIN, MPCC_TOP_GAIN, mask_sh),\
-       SF(MPCC0_MPCC_BOT_GAIN_INSIDE, MPCC_BOT_GAIN_INSIDE, mask_sh),\
-       SF(MPCC0_MPCC_BOT_GAIN_OUTSIDE, MPCC_BOT_GAIN_OUTSIDE, mask_sh),\
-       SF(MPC_OCSC_TEST_DEBUG_INDEX, MPC_OCSC_TEST_DEBUG_INDEX, mask_sh),\
-       SF(MPC_OUT0_CSC_MODE, MPC_OCSC_MODE, mask_sh),\
-       SF(MPC_OUT0_CSC_C11_C12_A, MPC_OCSC_C11_A, mask_sh),\
-       SF(MPC_OUT0_CSC_C11_C12_A, MPC_OCSC_C12_A, mask_sh),\
-       SF(MPCC0_MPCC_STATUS, MPCC_DISABLED, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_REGION_0_1, MPCC_OGAM_RAMA_EXP_REGION0_LUT_OFFSET, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_REGION_0_1, MPCC_OGAM_RAMA_EXP_REGION0_NUM_SEGMENTS, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_REGION_0_1, MPCC_OGAM_RAMA_EXP_REGION1_LUT_OFFSET, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_REGION_0_1, MPCC_OGAM_RAMA_EXP_REGION1_NUM_SEGMENTS, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_END_CNTL1_B, MPCC_OGAM_RAMA_EXP_REGION_END_B, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_END_CNTL2_B, MPCC_OGAM_RAMA_EXP_REGION_END_SLOPE_B, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_END_CNTL2_B, MPCC_OGAM_RAMA_EXP_REGION_END_BASE_B, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_SLOPE_CNTL_B, MPCC_OGAM_RAMA_EXP_REGION_LINEAR_SLOPE_B, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_START_CNTL_B, MPCC_OGAM_RAMA_EXP_REGION_START_B, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_START_CNTL_B, MPCC_OGAM_RAMA_EXP_REGION_START_SEGMENT_B, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMB_REGION_0_1, MPCC_OGAM_RAMB_EXP_REGION0_LUT_OFFSET, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMB_REGION_0_1, MPCC_OGAM_RAMB_EXP_REGION0_NUM_SEGMENTS, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMB_REGION_0_1, MPCC_OGAM_RAMB_EXP_REGION1_LUT_OFFSET, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMB_REGION_0_1, MPCC_OGAM_RAMB_EXP_REGION1_NUM_SEGMENTS, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMB_END_CNTL1_B, MPCC_OGAM_RAMB_EXP_REGION_END_B, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMB_END_CNTL2_B, MPCC_OGAM_RAMB_EXP_REGION_END_SLOPE_B, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMB_END_CNTL2_B, MPCC_OGAM_RAMB_EXP_REGION_END_BASE_B, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMB_SLOPE_CNTL_B, MPCC_OGAM_RAMB_EXP_REGION_LINEAR_SLOPE_B, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMB_START_CNTL_B, MPCC_OGAM_RAMB_EXP_REGION_START_B, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMB_START_CNTL_B, MPCC_OGAM_RAMB_EXP_REGION_START_SEGMENT_B, mask_sh),\
-       SF(MPCC0_MPCC_MEM_PWR_CTRL, MPCC_OGAM_MEM_PWR_FORCE, mask_sh),\
-       SF(MPCC0_MPCC_MEM_PWR_CTRL, MPCC_OGAM_MEM_PWR_DIS, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_LUT_INDEX, MPCC_OGAM_LUT_INDEX, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_LUT_RAM_CONTROL, MPCC_OGAM_LUT_WRITE_EN_MASK, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_LUT_RAM_CONTROL, MPCC_OGAM_LUT_RAM_SEL, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_LUT_RAM_CONTROL, MPCC_OGAM_CONFIG_STATUS, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_LUT_DATA, MPCC_OGAM_LUT_DATA, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_MODE, MPCC_OGAM_MODE, mask_sh),\
-       SF(MPC_OUT0_DENORM_CONTROL, MPC_OUT_DENORM_MODE, mask_sh),\
-       SF(MPC_OUT0_DENORM_CONTROL, MPC_OUT_DENORM_CLAMP_MAX_R_CR, mask_sh),\
-       SF(MPC_OUT0_DENORM_CONTROL, MPC_OUT_DENORM_CLAMP_MIN_R_CR, mask_sh),\
-       SF(MPC_OUT0_DENORM_CLAMP_G_Y, MPC_OUT_DENORM_CLAMP_MAX_G_Y, mask_sh),\
-       SF(MPC_OUT0_DENORM_CLAMP_G_Y, MPC_OUT_DENORM_CLAMP_MIN_G_Y, mask_sh),\
-       SF(MPC_OUT0_DENORM_CLAMP_B_CB, MPC_OUT_DENORM_CLAMP_MAX_B_CB, mask_sh),\
-       SF(MPC_OUT0_DENORM_CLAMP_B_CB, MPC_OUT_DENORM_CLAMP_MIN_B_CB, mask_sh),\
-       SF(CUR_VUPDATE_LOCK_SET0, CUR_VUPDATE_LOCK_SET, mask_sh)
-
-/*
- *     DCN2 MPC_OCSC debug status register:
- *
- *             Status index including current OCSC Mode is 1
- *                     OCSC Mode: [1..0]
- */
-#define MPC_OCSC_TEST_DEBUG_DATA_STATUS_IDX 1
-
-#define MPC_DEBUG_REG_LIST_SH_DCN20 \
-       .MPC_OCSC_TEST_DEBUG_DATA_OCSC_MODE = 0
-
-#define MPC_DEBUG_REG_LIST_MASK_DCN20 \
-       .MPC_OCSC_TEST_DEBUG_DATA_OCSC_MODE = 0x3
-
-#define MPC_REG_FIELD_LIST_DCN2_0(type) \
-       MPC_REG_FIELD_LIST(type)\
-       type MPCC_BG_BPC;\
-       type MPCC_BOT_GAIN_MODE;\
-       type MPCC_TOP_GAIN;\
-       type MPCC_BOT_GAIN_INSIDE;\
-       type MPCC_BOT_GAIN_OUTSIDE;\
-       type MPC_OCSC_TEST_DEBUG_DATA_OCSC_MODE;\
-       type MPC_OCSC_TEST_DEBUG_INDEX;\
-       type MPC_OCSC_MODE;\
-       type MPC_OCSC_C11_A;\
-       type MPC_OCSC_C12_A;\
-       type MPCC_OGAM_RAMA_EXP_REGION0_LUT_OFFSET;\
-       type MPCC_OGAM_RAMA_EXP_REGION0_NUM_SEGMENTS;\
-       type MPCC_OGAM_RAMA_EXP_REGION1_LUT_OFFSET;\
-       type MPCC_OGAM_RAMA_EXP_REGION1_NUM_SEGMENTS;\
-       type MPCC_OGAM_RAMA_EXP_REGION_END_B;\
-       type MPCC_OGAM_RAMA_EXP_REGION_END_SLOPE_B;\
-       type MPCC_OGAM_RAMA_EXP_REGION_END_BASE_B;\
-       type MPCC_OGAM_RAMA_EXP_REGION_LINEAR_SLOPE_B;\
-       type MPCC_OGAM_RAMA_EXP_REGION_START_B;\
-       type MPCC_OGAM_RAMA_EXP_REGION_START_SEGMENT_B;\
-       type MPCC_OGAM_RAMB_EXP_REGION0_LUT_OFFSET;\
-       type MPCC_OGAM_RAMB_EXP_REGION0_NUM_SEGMENTS;\
-       type MPCC_OGAM_RAMB_EXP_REGION1_LUT_OFFSET;\
-       type MPCC_OGAM_RAMB_EXP_REGION1_NUM_SEGMENTS;\
-       type MPCC_OGAM_RAMB_EXP_REGION_END_B;\
-       type MPCC_OGAM_RAMB_EXP_REGION_END_SLOPE_B;\
-       type MPCC_OGAM_RAMB_EXP_REGION_END_BASE_B;\
-       type MPCC_OGAM_RAMB_EXP_REGION_LINEAR_SLOPE_B;\
-       type MPCC_OGAM_RAMB_EXP_REGION_START_B;\
-       type MPCC_OGAM_RAMB_EXP_REGION_START_SEGMENT_B;\
-       type MPCC_OGAM_MEM_PWR_FORCE;\
-       type MPCC_OGAM_LUT_INDEX;\
-       type MPCC_OGAM_LUT_WRITE_EN_MASK;\
-       type MPCC_OGAM_LUT_RAM_SEL;\
-       type MPCC_OGAM_CONFIG_STATUS;\
-       type MPCC_OGAM_LUT_DATA;\
-       type MPCC_OGAM_MODE;\
-       type MPC_OUT_DENORM_MODE;\
-       type MPC_OUT_DENORM_CLAMP_MAX_R_CR;\
-       type MPC_OUT_DENORM_CLAMP_MIN_R_CR;\
-       type MPC_OUT_DENORM_CLAMP_MAX_G_Y;\
-       type MPC_OUT_DENORM_CLAMP_MIN_G_Y;\
-       type MPC_OUT_DENORM_CLAMP_MAX_B_CB;\
-       type MPC_OUT_DENORM_CLAMP_MIN_B_CB;\
-       type MPCC_DISABLED;\
-       type MPCC_OGAM_MEM_PWR_DIS;
-
-struct dcn20_mpc_registers {
-       MPC_REG_VARIABLE_LIST_DCN2_0
-};
-
-struct dcn20_mpc_shift {
-       MPC_REG_FIELD_LIST_DCN2_0(uint8_t)
-};
-
-struct dcn20_mpc_mask {
-       MPC_REG_FIELD_LIST_DCN2_0(uint32_t)
-};
-
-struct dcn20_mpc {
-       struct mpc base;
-
-       int mpcc_in_use_mask;
-       int num_mpcc;
-       const struct dcn20_mpc_registers *mpc_regs;
-       const struct dcn20_mpc_shift *mpc_shift;
-       const struct dcn20_mpc_mask *mpc_mask;
-};
-
-void dcn20_mpc_construct(struct dcn20_mpc *mpcc20,
-       struct dc_context *ctx,
-       const struct dcn20_mpc_registers *mpc_regs,
-       const struct dcn20_mpc_shift *mpc_shift,
-       const struct dcn20_mpc_mask *mpc_mask,
-       int num_mpcc);
-
-void mpc2_update_blending(
-       struct mpc *mpc,
-       struct mpcc_blnd_cfg *blnd_cfg,
-       int mpcc_id);
-
-void mpc2_set_denorm(
-       struct mpc *mpc,
-       int opp_id,
-       enum dc_color_depth output_depth);
-
-void mpc2_set_denorm_clamp(
-       struct mpc *mpc,
-       int opp_id,
-       struct mpc_denorm_clamp denorm_clamp);
-
-void mpc2_set_output_csc(
-       struct mpc *mpc,
-       int opp_id,
-       const uint16_t *regval,
-       enum mpc_output_csc_mode ocsc_mode);
-
-void mpc2_set_ocsc_default(
-       struct mpc *mpc,
-       int opp_id,
-       enum dc_color_space color_space,
-       enum mpc_output_csc_mode ocsc_mode);
-
-void mpc2_set_output_gamma(
-       struct mpc *mpc,
-       int mpcc_id,
-       const struct pwl_params *params);
-
-void mpc2_assert_idle_mpcc(struct mpc *mpc, int id);
-void mpc2_assert_mpcc_idle_before_connect(struct mpc *mpc, int mpcc_id);
-void mpc20_power_on_ogam_lut(struct mpc *mpc, int mpcc_id, bool power_on);
-#endif
index 4c43af8..8048512 100644 (file)
@@ -23,7 +23,7 @@
 #
 #
 
-DCN30 := dcn30_mpc.o dcn30_vpg.o \
+DCN30 := dcn30_vpg.o \
        dcn30_afmt.o \
        dcn30_dwb.o \
        dcn30_dwb_cm.o \
diff --git a/drivers/gpu/drm/amd/display/dc/dcn30/dcn30_mpc.c b/drivers/gpu/drm/amd/display/dc/dcn30/dcn30_mpc.c
deleted file mode 100644 (file)
index 3aeb85e..0000000
+++ /dev/null
@@ -1,1558 +0,0 @@
-/*
- * Copyright 2020 Advanced Micro Devices, Inc.
- *
- * Permission is hereby granted, free of charge, to any person obtaining a
- * copy of this software and associated documentation files (the "Software"),
- * to deal in the Software without restriction, including without limitation
- * the rights to use, copy, modify, merge, publish, distribute, sublicense,
- * and/or sell copies of the Software, and to permit persons to whom the
- * Software is furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice shall be included in
- * all copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
- * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
- * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
- * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
- * OTHER DEALINGS IN THE SOFTWARE.
- *
- * Authors: AMD
- *
- */
-
-#include "reg_helper.h"
-#include "dcn30_mpc.h"
-#include "dcn30_cm_common.h"
-#include "basics/conversion.h"
-#include "dcn10/dcn10_cm_common.h"
-#include "dc.h"
-
-#define REG(reg)\
-       mpc30->mpc_regs->reg
-
-#define CTX \
-       mpc30->base.ctx
-
-#undef FN
-#define FN(reg_name, field_name) \
-       mpc30->mpc_shift->field_name, mpc30->mpc_mask->field_name
-
-
-#define NUM_ELEMENTS(a) (sizeof(a) / sizeof((a)[0]))
-
-
-void mpc3_mpc_init(struct mpc *mpc)
-{
-       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
-       int opp_id;
-
-       mpc1_mpc_init(mpc);
-
-       for (opp_id = 0; opp_id < MAX_OPP; opp_id++) {
-               if (REG(MUX[opp_id]))
-                       /* disable mpc out rate and flow control */
-                       REG_UPDATE_2(MUX[opp_id], MPC_OUT_RATE_CONTROL_DISABLE,
-                                       1, MPC_OUT_FLOW_CONTROL_COUNT, 0);
-       }
-}
-
-void mpc3_mpc_init_single_inst(struct mpc *mpc, unsigned int mpcc_id)
-{
-       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
-
-       mpc1_mpc_init_single_inst(mpc, mpcc_id);
-
-       /* assuming mpc out mux is connected to opp with the same index at this
-        * point in time (e.g. transitioning from vbios to driver)
-        */
-       if (mpcc_id < MAX_OPP && REG(MUX[mpcc_id]))
-               /* disable mpc out rate and flow control */
-               REG_UPDATE_2(MUX[mpcc_id], MPC_OUT_RATE_CONTROL_DISABLE,
-                               1, MPC_OUT_FLOW_CONTROL_COUNT, 0);
-}
-
-bool mpc3_is_dwb_idle(
-       struct mpc *mpc,
-       int dwb_id)
-{
-       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
-       unsigned int status;
-
-       REG_GET(DWB_MUX[dwb_id], MPC_DWB0_MUX_STATUS, &status);
-
-       if (status == 0xf)
-               return true;
-       else
-               return false;
-}
-
-void mpc3_set_dwb_mux(
-       struct mpc *mpc,
-       int dwb_id,
-       int mpcc_id)
-{
-       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
-
-       REG_SET(DWB_MUX[dwb_id], 0,
-               MPC_DWB0_MUX, mpcc_id);
-}
-
-void mpc3_disable_dwb_mux(
-       struct mpc *mpc,
-       int dwb_id)
-{
-       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
-
-       REG_SET(DWB_MUX[dwb_id], 0,
-               MPC_DWB0_MUX, 0xf);
-}
-
-enum dc_lut_mode mpc3_get_ogam_current(struct mpc *mpc, int mpcc_id)
-{
-       /*Contrary to DCN2 and DCN1 wherein a single status register field holds this info;
-        *in DCN3/3AG, we need to read two separate fields to retrieve the same info
-        */
-       enum dc_lut_mode mode;
-       uint32_t state_mode;
-       uint32_t state_ram_lut_in_use;
-       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
-
-       REG_GET_2(MPCC_OGAM_CONTROL[mpcc_id], MPCC_OGAM_MODE_CURRENT, &state_mode,
-                 MPCC_OGAM_SELECT_CURRENT, &state_ram_lut_in_use);
-
-       switch (state_mode) {
-       case 0:
-               mode = LUT_BYPASS;
-               break;
-       case 2:
-               switch (state_ram_lut_in_use) {
-               case 0:
-                       mode = LUT_RAM_A;
-                       break;
-               case 1:
-                       mode = LUT_RAM_B;
-                       break;
-               default:
-                       mode = LUT_BYPASS;
-                       break;
-               }
-               break;
-       default:
-               mode = LUT_BYPASS;
-               break;
-       }
-
-       return mode;
-}
-
-void mpc3_power_on_ogam_lut(
-               struct mpc *mpc, int mpcc_id,
-               bool power_on)
-{
-       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
-
-       /*
-        * Powering on: force memory active so the LUT can be updated.
-        * Powering off: allow entering memory low power mode
-        *
-        * Memory low power mode is controlled during MPC OGAM LUT init.
-        */
-       REG_UPDATE(MPCC_MEM_PWR_CTRL[mpcc_id],
-                  MPCC_OGAM_MEM_PWR_DIS, power_on != 0);
-
-       /* Wait for memory to be powered on - we won't be able to write to it otherwise. */
-       if (power_on)
-               REG_WAIT(MPCC_MEM_PWR_CTRL[mpcc_id], MPCC_OGAM_MEM_PWR_STATE, 0, 10, 10);
-}
-
-static void mpc3_configure_ogam_lut(
-               struct mpc *mpc, int mpcc_id,
-               bool is_ram_a)
-{
-       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
-
-       REG_UPDATE_2(MPCC_OGAM_LUT_CONTROL[mpcc_id],
-                       MPCC_OGAM_LUT_WRITE_COLOR_MASK, 7,
-                       MPCC_OGAM_LUT_HOST_SEL, is_ram_a == true ? 0:1);
-
-       REG_SET(MPCC_OGAM_LUT_INDEX[mpcc_id], 0, MPCC_OGAM_LUT_INDEX, 0);
-}
-
-static void mpc3_ogam_get_reg_field(
-               struct mpc *mpc,
-               struct dcn3_xfer_func_reg *reg)
-{
-       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
-
-       reg->shifts.field_region_start_base = mpc30->mpc_shift->MPCC_OGAM_RAMA_EXP_REGION_START_BASE_B;
-       reg->masks.field_region_start_base = mpc30->mpc_mask->MPCC_OGAM_RAMA_EXP_REGION_START_BASE_B;
-       reg->shifts.field_offset = mpc30->mpc_shift->MPCC_OGAM_RAMA_OFFSET_B;
-       reg->masks.field_offset = mpc30->mpc_mask->MPCC_OGAM_RAMA_OFFSET_B;
-
-       reg->shifts.exp_region0_lut_offset = mpc30->mpc_shift->MPCC_OGAM_RAMA_EXP_REGION0_LUT_OFFSET;
-       reg->masks.exp_region0_lut_offset = mpc30->mpc_mask->MPCC_OGAM_RAMA_EXP_REGION0_LUT_OFFSET;
-       reg->shifts.exp_region0_num_segments = mpc30->mpc_shift->MPCC_OGAM_RAMA_EXP_REGION0_NUM_SEGMENTS;
-       reg->masks.exp_region0_num_segments = mpc30->mpc_mask->MPCC_OGAM_RAMA_EXP_REGION0_NUM_SEGMENTS;
-       reg->shifts.exp_region1_lut_offset = mpc30->mpc_shift->MPCC_OGAM_RAMA_EXP_REGION1_LUT_OFFSET;
-       reg->masks.exp_region1_lut_offset = mpc30->mpc_mask->MPCC_OGAM_RAMA_EXP_REGION1_LUT_OFFSET;
-       reg->shifts.exp_region1_num_segments = mpc30->mpc_shift->MPCC_OGAM_RAMA_EXP_REGION1_NUM_SEGMENTS;
-       reg->masks.exp_region1_num_segments = mpc30->mpc_mask->MPCC_OGAM_RAMA_EXP_REGION1_NUM_SEGMENTS;
-
-       reg->shifts.field_region_end = mpc30->mpc_shift->MPCC_OGAM_RAMA_EXP_REGION_END_B;
-       reg->masks.field_region_end = mpc30->mpc_mask->MPCC_OGAM_RAMA_EXP_REGION_END_B;
-       reg->shifts.field_region_end_slope = mpc30->mpc_shift->MPCC_OGAM_RAMA_EXP_REGION_END_SLOPE_B;
-       reg->masks.field_region_end_slope = mpc30->mpc_mask->MPCC_OGAM_RAMA_EXP_REGION_END_SLOPE_B;
-       reg->shifts.field_region_end_base = mpc30->mpc_shift->MPCC_OGAM_RAMA_EXP_REGION_END_BASE_B;
-       reg->masks.field_region_end_base = mpc30->mpc_mask->MPCC_OGAM_RAMA_EXP_REGION_END_BASE_B;
-       reg->shifts.field_region_linear_slope = mpc30->mpc_shift->MPCC_OGAM_RAMA_EXP_REGION_START_SLOPE_B;
-       reg->masks.field_region_linear_slope = mpc30->mpc_mask->MPCC_OGAM_RAMA_EXP_REGION_START_SLOPE_B;
-       reg->shifts.exp_region_start = mpc30->mpc_shift->MPCC_OGAM_RAMA_EXP_REGION_START_B;
-       reg->masks.exp_region_start = mpc30->mpc_mask->MPCC_OGAM_RAMA_EXP_REGION_START_B;
-       reg->shifts.exp_resion_start_segment = mpc30->mpc_shift->MPCC_OGAM_RAMA_EXP_REGION_START_SEGMENT_B;
-       reg->masks.exp_resion_start_segment = mpc30->mpc_mask->MPCC_OGAM_RAMA_EXP_REGION_START_SEGMENT_B;
-}
-
-static void mpc3_program_luta(struct mpc *mpc, int mpcc_id,
-               const struct pwl_params *params)
-{
-       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
-       struct dcn3_xfer_func_reg gam_regs;
-
-       mpc3_ogam_get_reg_field(mpc, &gam_regs);
-
-       gam_regs.start_cntl_b = REG(MPCC_OGAM_RAMA_START_CNTL_B[mpcc_id]);
-       gam_regs.start_cntl_g = REG(MPCC_OGAM_RAMA_START_CNTL_G[mpcc_id]);
-       gam_regs.start_cntl_r = REG(MPCC_OGAM_RAMA_START_CNTL_R[mpcc_id]);
-       gam_regs.start_slope_cntl_b = REG(MPCC_OGAM_RAMA_START_SLOPE_CNTL_B[mpcc_id]);
-       gam_regs.start_slope_cntl_g = REG(MPCC_OGAM_RAMA_START_SLOPE_CNTL_G[mpcc_id]);
-       gam_regs.start_slope_cntl_r = REG(MPCC_OGAM_RAMA_START_SLOPE_CNTL_R[mpcc_id]);
-       gam_regs.start_end_cntl1_b = REG(MPCC_OGAM_RAMA_END_CNTL1_B[mpcc_id]);
-       gam_regs.start_end_cntl2_b = REG(MPCC_OGAM_RAMA_END_CNTL2_B[mpcc_id]);
-       gam_regs.start_end_cntl1_g = REG(MPCC_OGAM_RAMA_END_CNTL1_G[mpcc_id]);
-       gam_regs.start_end_cntl2_g = REG(MPCC_OGAM_RAMA_END_CNTL2_G[mpcc_id]);
-       gam_regs.start_end_cntl1_r = REG(MPCC_OGAM_RAMA_END_CNTL1_R[mpcc_id]);
-       gam_regs.start_end_cntl2_r = REG(MPCC_OGAM_RAMA_END_CNTL2_R[mpcc_id]);
-       gam_regs.region_start = REG(MPCC_OGAM_RAMA_REGION_0_1[mpcc_id]);
-       gam_regs.region_end = REG(MPCC_OGAM_RAMA_REGION_32_33[mpcc_id]);
-       //New registers in DCN3AG/DCN OGAM block
-       gam_regs.offset_b =  REG(MPCC_OGAM_RAMA_OFFSET_B[mpcc_id]);
-       gam_regs.offset_g =  REG(MPCC_OGAM_RAMA_OFFSET_G[mpcc_id]);
-       gam_regs.offset_r =  REG(MPCC_OGAM_RAMA_OFFSET_R[mpcc_id]);
-       gam_regs.start_base_cntl_b = REG(MPCC_OGAM_RAMA_START_BASE_CNTL_B[mpcc_id]);
-       gam_regs.start_base_cntl_g = REG(MPCC_OGAM_RAMA_START_BASE_CNTL_G[mpcc_id]);
-       gam_regs.start_base_cntl_r = REG(MPCC_OGAM_RAMA_START_BASE_CNTL_R[mpcc_id]);
-
-       cm_helper_program_gamcor_xfer_func(mpc30->base.ctx, params, &gam_regs);
-}
-
-static void mpc3_program_lutb(struct mpc *mpc, int mpcc_id,
-               const struct pwl_params *params)
-{
-       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
-       struct dcn3_xfer_func_reg gam_regs;
-
-       mpc3_ogam_get_reg_field(mpc, &gam_regs);
-
-       gam_regs.start_cntl_b = REG(MPCC_OGAM_RAMB_START_CNTL_B[mpcc_id]);
-       gam_regs.start_cntl_g = REG(MPCC_OGAM_RAMB_START_CNTL_G[mpcc_id]);
-       gam_regs.start_cntl_r = REG(MPCC_OGAM_RAMB_START_CNTL_R[mpcc_id]);
-       gam_regs.start_slope_cntl_b = REG(MPCC_OGAM_RAMB_START_SLOPE_CNTL_B[mpcc_id]);
-       gam_regs.start_slope_cntl_g = REG(MPCC_OGAM_RAMB_START_SLOPE_CNTL_G[mpcc_id]);
-       gam_regs.start_slope_cntl_r = REG(MPCC_OGAM_RAMB_START_SLOPE_CNTL_R[mpcc_id]);
-       gam_regs.start_end_cntl1_b = REG(MPCC_OGAM_RAMB_END_CNTL1_B[mpcc_id]);
-       gam_regs.start_end_cntl2_b = REG(MPCC_OGAM_RAMB_END_CNTL2_B[mpcc_id]);
-       gam_regs.start_end_cntl1_g = REG(MPCC_OGAM_RAMB_END_CNTL1_G[mpcc_id]);
-       gam_regs.start_end_cntl2_g = REG(MPCC_OGAM_RAMB_END_CNTL2_G[mpcc_id]);
-       gam_regs.start_end_cntl1_r = REG(MPCC_OGAM_RAMB_END_CNTL1_R[mpcc_id]);
-       gam_regs.start_end_cntl2_r = REG(MPCC_OGAM_RAMB_END_CNTL2_R[mpcc_id]);
-       gam_regs.region_start = REG(MPCC_OGAM_RAMB_REGION_0_1[mpcc_id]);
-       gam_regs.region_end = REG(MPCC_OGAM_RAMB_REGION_32_33[mpcc_id]);
-       //New registers in DCN3AG/DCN OGAM block
-       gam_regs.offset_b =  REG(MPCC_OGAM_RAMB_OFFSET_B[mpcc_id]);
-       gam_regs.offset_g =  REG(MPCC_OGAM_RAMB_OFFSET_G[mpcc_id]);
-       gam_regs.offset_r =  REG(MPCC_OGAM_RAMB_OFFSET_R[mpcc_id]);
-       gam_regs.start_base_cntl_b = REG(MPCC_OGAM_RAMB_START_BASE_CNTL_B[mpcc_id]);
-       gam_regs.start_base_cntl_g = REG(MPCC_OGAM_RAMB_START_BASE_CNTL_G[mpcc_id]);
-       gam_regs.start_base_cntl_r = REG(MPCC_OGAM_RAMB_START_BASE_CNTL_R[mpcc_id]);
-
-       cm_helper_program_gamcor_xfer_func(mpc30->base.ctx, params, &gam_regs);
-}
-
-
-static void mpc3_program_ogam_pwl(
-               struct mpc *mpc, int mpcc_id,
-               const struct pwl_result_data *rgb,
-               uint32_t num)
-{
-       uint32_t i;
-       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
-
-       if (is_rgb_equal(rgb,  num)) {
-               for (i = 0 ; i < num; i++)
-                       REG_SET(MPCC_OGAM_LUT_DATA[mpcc_id], 0, MPCC_OGAM_LUT_DATA, rgb[i].red_reg);
-       } else {
-
-               REG_UPDATE(MPCC_OGAM_LUT_CONTROL[mpcc_id],
-                               MPCC_OGAM_LUT_WRITE_COLOR_MASK, 4);
-
-               for (i = 0 ; i < num; i++)
-                       REG_SET(MPCC_OGAM_LUT_DATA[mpcc_id], 0, MPCC_OGAM_LUT_DATA, rgb[i].red_reg);
-
-               REG_SET(MPCC_OGAM_LUT_INDEX[mpcc_id], 0, MPCC_OGAM_LUT_INDEX, 0);
-
-               REG_UPDATE(MPCC_OGAM_LUT_CONTROL[mpcc_id],
-                               MPCC_OGAM_LUT_WRITE_COLOR_MASK, 2);
-
-               for (i = 0 ; i < num; i++)
-                       REG_SET(MPCC_OGAM_LUT_DATA[mpcc_id], 0, MPCC_OGAM_LUT_DATA, rgb[i].green_reg);
-
-               REG_SET(MPCC_OGAM_LUT_INDEX[mpcc_id], 0, MPCC_OGAM_LUT_INDEX, 0);
-
-               REG_UPDATE(MPCC_OGAM_LUT_CONTROL[mpcc_id],
-                               MPCC_OGAM_LUT_WRITE_COLOR_MASK, 1);
-
-               for (i = 0 ; i < num; i++)
-                       REG_SET(MPCC_OGAM_LUT_DATA[mpcc_id], 0, MPCC_OGAM_LUT_DATA, rgb[i].blue_reg);
-
-       }
-
-}
-
-void mpc3_set_output_gamma(
-               struct mpc *mpc,
-               int mpcc_id,
-               const struct pwl_params *params)
-{
-       enum dc_lut_mode current_mode;
-       enum dc_lut_mode next_mode;
-       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
-
-       if (mpc->ctx->dc->debug.cm_in_bypass) {
-               REG_SET(MPCC_OGAM_MODE[mpcc_id], 0, MPCC_OGAM_MODE, 0);
-               return;
-       }
-
-       if (params == NULL) { //disable OGAM
-               REG_SET(MPCC_OGAM_CONTROL[mpcc_id], 0, MPCC_OGAM_MODE, 0);
-               return;
-       }
-       //enable OGAM
-       REG_SET(MPCC_OGAM_CONTROL[mpcc_id], 0, MPCC_OGAM_MODE, 2);
-
-       current_mode = mpc3_get_ogam_current(mpc, mpcc_id);
-       if (current_mode == LUT_BYPASS)
-               next_mode = LUT_RAM_A;
-       else if (current_mode == LUT_RAM_A)
-               next_mode = LUT_RAM_B;
-       else
-               next_mode = LUT_RAM_A;
-
-       mpc3_power_on_ogam_lut(mpc, mpcc_id, true);
-       mpc3_configure_ogam_lut(mpc, mpcc_id, next_mode == LUT_RAM_A);
-
-       if (next_mode == LUT_RAM_A)
-               mpc3_program_luta(mpc, mpcc_id, params);
-       else
-               mpc3_program_lutb(mpc, mpcc_id, params);
-
-       mpc3_program_ogam_pwl(
-                       mpc, mpcc_id, params->rgb_resulted, params->hw_points_num);
-
-       /*we need to program 2 fields here as apposed to 1*/
-       REG_UPDATE(MPCC_OGAM_CONTROL[mpcc_id],
-                       MPCC_OGAM_SELECT, next_mode == LUT_RAM_A ? 0:1);
-
-       if (mpc->ctx->dc->debug.enable_mem_low_power.bits.mpc)
-               mpc3_power_on_ogam_lut(mpc, mpcc_id, false);
-}
-
-void mpc3_set_denorm(
-               struct mpc *mpc,
-               int opp_id,
-               enum dc_color_depth output_depth)
-{
-       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
-       /* De-normalize Fixed U1.13 color data to different target bit depths. 0 is bypass*/
-       int denorm_mode = 0;
-
-       switch (output_depth) {
-       case COLOR_DEPTH_666:
-               denorm_mode = 1;
-               break;
-       case COLOR_DEPTH_888:
-               denorm_mode = 2;
-               break;
-       case COLOR_DEPTH_999:
-               denorm_mode = 3;
-               break;
-       case COLOR_DEPTH_101010:
-               denorm_mode = 4;
-               break;
-       case COLOR_DEPTH_111111:
-               denorm_mode = 5;
-               break;
-       case COLOR_DEPTH_121212:
-               denorm_mode = 6;
-               break;
-       case COLOR_DEPTH_141414:
-       case COLOR_DEPTH_161616:
-       default:
-               /* not valid used case! */
-               break;
-       }
-
-       REG_UPDATE(DENORM_CONTROL[opp_id],
-                       MPC_OUT_DENORM_MODE, denorm_mode);
-}
-
-void mpc3_set_denorm_clamp(
-               struct mpc *mpc,
-               int opp_id,
-               struct mpc_denorm_clamp denorm_clamp)
-{
-       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
-
-       /*program min and max clamp values for the pixel components*/
-       REG_UPDATE_2(DENORM_CONTROL[opp_id],
-                       MPC_OUT_DENORM_CLAMP_MAX_R_CR, denorm_clamp.clamp_max_r_cr,
-                       MPC_OUT_DENORM_CLAMP_MIN_R_CR, denorm_clamp.clamp_min_r_cr);
-       REG_UPDATE_2(DENORM_CLAMP_G_Y[opp_id],
-                       MPC_OUT_DENORM_CLAMP_MAX_G_Y, denorm_clamp.clamp_max_g_y,
-                       MPC_OUT_DENORM_CLAMP_MIN_G_Y, denorm_clamp.clamp_min_g_y);
-       REG_UPDATE_2(DENORM_CLAMP_B_CB[opp_id],
-                       MPC_OUT_DENORM_CLAMP_MAX_B_CB, denorm_clamp.clamp_max_b_cb,
-                       MPC_OUT_DENORM_CLAMP_MIN_B_CB, denorm_clamp.clamp_min_b_cb);
-}
-
-static enum dc_lut_mode mpc3_get_shaper_current(struct mpc *mpc, uint32_t rmu_idx)
-{
-       enum dc_lut_mode mode;
-       uint32_t state_mode;
-       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
-
-       REG_GET(SHAPER_CONTROL[rmu_idx], MPC_RMU_SHAPER_LUT_MODE_CURRENT, &state_mode);
-
-       switch (state_mode) {
-       case 0:
-               mode = LUT_BYPASS;
-               break;
-       case 1:
-               mode = LUT_RAM_A;
-               break;
-       case 2:
-               mode = LUT_RAM_B;
-               break;
-       default:
-               mode = LUT_BYPASS;
-               break;
-       }
-
-       return mode;
-}
-
-static void mpc3_configure_shaper_lut(
-               struct mpc *mpc,
-               bool is_ram_a,
-               uint32_t rmu_idx)
-{
-       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
-
-       REG_UPDATE(SHAPER_LUT_WRITE_EN_MASK[rmu_idx],
-                       MPC_RMU_SHAPER_LUT_WRITE_EN_MASK, 7);
-       REG_UPDATE(SHAPER_LUT_WRITE_EN_MASK[rmu_idx],
-                       MPC_RMU_SHAPER_LUT_WRITE_SEL, is_ram_a == true ? 0:1);
-       REG_SET(SHAPER_LUT_INDEX[rmu_idx], 0, MPC_RMU_SHAPER_LUT_INDEX, 0);
-}
-
-static void mpc3_program_shaper_luta_settings(
-               struct mpc *mpc,
-               const struct pwl_params *params,
-               uint32_t rmu_idx)
-{
-       const struct gamma_curve *curve;
-       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
-
-       REG_SET_2(SHAPER_RAMA_START_CNTL_B[rmu_idx], 0,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION_START_B, params->corner_points[0].blue.custom_float_x,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION_START_SEGMENT_B, 0);
-       REG_SET_2(SHAPER_RAMA_START_CNTL_G[rmu_idx], 0,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION_START_B, params->corner_points[0].green.custom_float_x,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION_START_SEGMENT_B, 0);
-       REG_SET_2(SHAPER_RAMA_START_CNTL_R[rmu_idx], 0,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION_START_B, params->corner_points[0].red.custom_float_x,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION_START_SEGMENT_B, 0);
-
-       REG_SET_2(SHAPER_RAMA_END_CNTL_B[rmu_idx], 0,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION_END_B, params->corner_points[1].blue.custom_float_x,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION_END_BASE_B, params->corner_points[1].blue.custom_float_y);
-       REG_SET_2(SHAPER_RAMA_END_CNTL_G[rmu_idx], 0,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION_END_B, params->corner_points[1].green.custom_float_x,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION_END_BASE_B, params->corner_points[1].green.custom_float_y);
-       REG_SET_2(SHAPER_RAMA_END_CNTL_R[rmu_idx], 0,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION_END_B, params->corner_points[1].red.custom_float_x,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION_END_BASE_B, params->corner_points[1].red.custom_float_y);
-
-       curve = params->arr_curve_points;
-       REG_SET_4(SHAPER_RAMA_REGION_0_1[rmu_idx], 0,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
-
-       curve += 2;
-       REG_SET_4(SHAPER_RAMA_REGION_2_3[rmu_idx], 0,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
-
-       curve += 2;
-       REG_SET_4(SHAPER_RAMA_REGION_4_5[rmu_idx], 0,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
-
-       curve += 2;
-       REG_SET_4(SHAPER_RAMA_REGION_6_7[rmu_idx], 0,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
-
-       curve += 2;
-       REG_SET_4(SHAPER_RAMA_REGION_8_9[rmu_idx], 0,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
-
-       curve += 2;
-       REG_SET_4(SHAPER_RAMA_REGION_10_11[rmu_idx], 0,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
-
-       curve += 2;
-       REG_SET_4(SHAPER_RAMA_REGION_12_13[rmu_idx], 0,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
-
-       curve += 2;
-       REG_SET_4(SHAPER_RAMA_REGION_14_15[rmu_idx], 0,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
-
-
-       curve += 2;
-       REG_SET_4(SHAPER_RAMA_REGION_16_17[rmu_idx], 0,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
-
-       curve += 2;
-       REG_SET_4(SHAPER_RAMA_REGION_18_19[rmu_idx], 0,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
-
-       curve += 2;
-       REG_SET_4(SHAPER_RAMA_REGION_20_21[rmu_idx], 0,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
-
-       curve += 2;
-       REG_SET_4(SHAPER_RAMA_REGION_22_23[rmu_idx], 0,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
-
-       curve += 2;
-       REG_SET_4(SHAPER_RAMA_REGION_24_25[rmu_idx], 0,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
-
-       curve += 2;
-       REG_SET_4(SHAPER_RAMA_REGION_26_27[rmu_idx], 0,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
-
-       curve += 2;
-       REG_SET_4(SHAPER_RAMA_REGION_28_29[rmu_idx], 0,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
-
-       curve += 2;
-       REG_SET_4(SHAPER_RAMA_REGION_30_31[rmu_idx], 0,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
-
-       curve += 2;
-       REG_SET_4(SHAPER_RAMA_REGION_32_33[rmu_idx], 0,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
-}
-
-static void mpc3_program_shaper_lutb_settings(
-               struct mpc *mpc,
-               const struct pwl_params *params,
-               uint32_t rmu_idx)
-{
-       const struct gamma_curve *curve;
-       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
-
-       REG_SET_2(SHAPER_RAMB_START_CNTL_B[rmu_idx], 0,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION_START_B, params->corner_points[0].blue.custom_float_x,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION_START_SEGMENT_B, 0);
-       REG_SET_2(SHAPER_RAMB_START_CNTL_G[rmu_idx], 0,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION_START_B, params->corner_points[0].green.custom_float_x,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION_START_SEGMENT_B, 0);
-       REG_SET_2(SHAPER_RAMB_START_CNTL_R[rmu_idx], 0,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION_START_B, params->corner_points[0].red.custom_float_x,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION_START_SEGMENT_B, 0);
-
-       REG_SET_2(SHAPER_RAMB_END_CNTL_B[rmu_idx], 0,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION_END_B, params->corner_points[1].blue.custom_float_x,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION_END_BASE_B, params->corner_points[1].blue.custom_float_y);
-       REG_SET_2(SHAPER_RAMB_END_CNTL_G[rmu_idx], 0,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION_END_B, params->corner_points[1].green.custom_float_x,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION_END_BASE_B, params->corner_points[1].green.custom_float_y);
-       REG_SET_2(SHAPER_RAMB_END_CNTL_R[rmu_idx], 0,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION_END_B, params->corner_points[1].red.custom_float_x,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION_END_BASE_B, params->corner_points[1].red.custom_float_y);
-
-       curve = params->arr_curve_points;
-       REG_SET_4(SHAPER_RAMB_REGION_0_1[rmu_idx], 0,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
-
-       curve += 2;
-       REG_SET_4(SHAPER_RAMB_REGION_2_3[rmu_idx], 0,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
-
-
-       curve += 2;
-       REG_SET_4(SHAPER_RAMB_REGION_4_5[rmu_idx], 0,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
-
-       curve += 2;
-       REG_SET_4(SHAPER_RAMB_REGION_6_7[rmu_idx], 0,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
-
-       curve += 2;
-       REG_SET_4(SHAPER_RAMB_REGION_8_9[rmu_idx], 0,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
-               MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
-
-       curve += 2;
-       REG_SET_4(SHAPER_RAMB_REGION_10_11[rmu_idx], 0,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
-
-       curve += 2;
-       REG_SET_4(SHAPER_RAMB_REGION_12_13[rmu_idx], 0,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
-
-       curve += 2;
-       REG_SET_4(SHAPER_RAMB_REGION_14_15[rmu_idx], 0,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
-
-
-       curve += 2;
-       REG_SET_4(SHAPER_RAMB_REGION_16_17[rmu_idx], 0,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
-
-       curve += 2;
-       REG_SET_4(SHAPER_RAMB_REGION_18_19[rmu_idx], 0,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
-
-       curve += 2;
-       REG_SET_4(SHAPER_RAMB_REGION_20_21[rmu_idx], 0,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
-
-       curve += 2;
-       REG_SET_4(SHAPER_RAMB_REGION_22_23[rmu_idx], 0,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
-
-       curve += 2;
-       REG_SET_4(SHAPER_RAMB_REGION_24_25[rmu_idx], 0,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
-
-       curve += 2;
-       REG_SET_4(SHAPER_RAMB_REGION_26_27[rmu_idx], 0,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
-
-       curve += 2;
-       REG_SET_4(SHAPER_RAMB_REGION_28_29[rmu_idx], 0,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
-
-       curve += 2;
-       REG_SET_4(SHAPER_RAMB_REGION_30_31[rmu_idx], 0,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
-
-       curve += 2;
-       REG_SET_4(SHAPER_RAMB_REGION_32_33[rmu_idx], 0,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
-                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
-}
-
-
-static void mpc3_program_shaper_lut(
-               struct mpc *mpc,
-               const struct pwl_result_data *rgb,
-               uint32_t num,
-               uint32_t rmu_idx)
-{
-       uint32_t i, red, green, blue;
-       uint32_t  red_delta, green_delta, blue_delta;
-       uint32_t  red_value, green_value, blue_value;
-
-       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
-
-       for (i = 0 ; i < num; i++) {
-
-               red   = rgb[i].red_reg;
-               green = rgb[i].green_reg;
-               blue  = rgb[i].blue_reg;
-
-               red_delta   = rgb[i].delta_red_reg;
-               green_delta = rgb[i].delta_green_reg;
-               blue_delta  = rgb[i].delta_blue_reg;
-
-               red_value   = ((red_delta   & 0x3ff) << 14) | (red   & 0x3fff);
-               green_value = ((green_delta & 0x3ff) << 14) | (green & 0x3fff);
-               blue_value  = ((blue_delta  & 0x3ff) << 14) | (blue  & 0x3fff);
-
-               REG_SET(SHAPER_LUT_DATA[rmu_idx], 0, MPC_RMU_SHAPER_LUT_DATA, red_value);
-               REG_SET(SHAPER_LUT_DATA[rmu_idx], 0, MPC_RMU_SHAPER_LUT_DATA, green_value);
-               REG_SET(SHAPER_LUT_DATA[rmu_idx], 0, MPC_RMU_SHAPER_LUT_DATA, blue_value);
-       }
-
-}
-
-static void mpc3_power_on_shaper_3dlut(
-               struct mpc *mpc,
-               uint32_t rmu_idx,
-       bool power_on)
-{
-       uint32_t power_status_shaper = 2;
-       uint32_t power_status_3dlut  = 2;
-       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
-       int max_retries = 10;
-
-       if (rmu_idx == 0) {
-               REG_SET(MPC_RMU_MEM_PWR_CTRL, 0,
-                       MPC_RMU0_MEM_PWR_DIS, power_on == true ? 1:0);
-               /* wait for memory to fully power up */
-               if (power_on && mpc->ctx->dc->debug.enable_mem_low_power.bits.mpc) {
-                       REG_WAIT(MPC_RMU_MEM_PWR_CTRL, MPC_RMU0_SHAPER_MEM_PWR_STATE, 0, 1, max_retries);
-                       REG_WAIT(MPC_RMU_MEM_PWR_CTRL, MPC_RMU0_3DLUT_MEM_PWR_STATE, 0, 1, max_retries);
-               }
-
-               /*read status is not mandatory, it is just for debugging*/
-               REG_GET(MPC_RMU_MEM_PWR_CTRL, MPC_RMU0_SHAPER_MEM_PWR_STATE, &power_status_shaper);
-               REG_GET(MPC_RMU_MEM_PWR_CTRL, MPC_RMU0_3DLUT_MEM_PWR_STATE, &power_status_3dlut);
-       } else if (rmu_idx == 1) {
-               REG_SET(MPC_RMU_MEM_PWR_CTRL, 0,
-                       MPC_RMU1_MEM_PWR_DIS, power_on == true ? 1:0);
-               if (power_on && mpc->ctx->dc->debug.enable_mem_low_power.bits.mpc) {
-                       REG_WAIT(MPC_RMU_MEM_PWR_CTRL, MPC_RMU1_SHAPER_MEM_PWR_STATE, 0, 1, max_retries);
-                       REG_WAIT(MPC_RMU_MEM_PWR_CTRL, MPC_RMU1_3DLUT_MEM_PWR_STATE, 0, 1, max_retries);
-               }
-
-               REG_GET(MPC_RMU_MEM_PWR_CTRL, MPC_RMU1_SHAPER_MEM_PWR_STATE, &power_status_shaper);
-               REG_GET(MPC_RMU_MEM_PWR_CTRL, MPC_RMU1_3DLUT_MEM_PWR_STATE, &power_status_3dlut);
-       }
-       /*TODO Add rmu_idx == 2 for SIENNA_CICHLID */
-       if (power_status_shaper != 0 && power_on == true)
-               BREAK_TO_DEBUGGER();
-
-       if (power_status_3dlut != 0 && power_on == true)
-               BREAK_TO_DEBUGGER();
-}
-
-
-
-bool mpc3_program_shaper(
-               struct mpc *mpc,
-               const struct pwl_params *params,
-               uint32_t rmu_idx)
-{
-       enum dc_lut_mode current_mode;
-       enum dc_lut_mode next_mode;
-
-       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
-
-       if (params == NULL) {
-               REG_SET(SHAPER_CONTROL[rmu_idx], 0, MPC_RMU_SHAPER_LUT_MODE, 0);
-               return false;
-       }
-
-       if (mpc->ctx->dc->debug.enable_mem_low_power.bits.mpc)
-               mpc3_power_on_shaper_3dlut(mpc, rmu_idx, true);
-
-       current_mode = mpc3_get_shaper_current(mpc, rmu_idx);
-
-       if (current_mode == LUT_BYPASS || current_mode == LUT_RAM_A)
-               next_mode = LUT_RAM_B;
-       else
-               next_mode = LUT_RAM_A;
-
-       mpc3_configure_shaper_lut(mpc, next_mode == LUT_RAM_A, rmu_idx);
-
-       if (next_mode == LUT_RAM_A)
-               mpc3_program_shaper_luta_settings(mpc, params, rmu_idx);
-       else
-               mpc3_program_shaper_lutb_settings(mpc, params, rmu_idx);
-
-       mpc3_program_shaper_lut(
-                       mpc, params->rgb_resulted, params->hw_points_num, rmu_idx);
-
-       REG_SET(SHAPER_CONTROL[rmu_idx], 0, MPC_RMU_SHAPER_LUT_MODE, next_mode == LUT_RAM_A ? 1:2);
-       mpc3_power_on_shaper_3dlut(mpc, rmu_idx, false);
-
-       return true;
-}
-
-static void mpc3_set_3dlut_mode(
-               struct mpc *mpc,
-               enum dc_lut_mode mode,
-               bool is_color_channel_12bits,
-               bool is_lut_size17x17x17,
-               uint32_t rmu_idx)
-{
-       uint32_t lut_mode;
-       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
-
-       if (mode == LUT_BYPASS)
-               lut_mode = 0;
-       else if (mode == LUT_RAM_A)
-               lut_mode = 1;
-       else
-               lut_mode = 2;
-
-       REG_UPDATE_2(RMU_3DLUT_MODE[rmu_idx],
-                       MPC_RMU_3DLUT_MODE, lut_mode,
-                       MPC_RMU_3DLUT_SIZE, is_lut_size17x17x17 == true ? 0 : 1);
-}
-
-static enum dc_lut_mode get3dlut_config(
-                       struct mpc *mpc,
-                       bool *is_17x17x17,
-                       bool *is_12bits_color_channel,
-                       int rmu_idx)
-{
-       uint32_t i_mode, i_enable_10bits, lut_size;
-       enum dc_lut_mode mode;
-       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
-
-       REG_GET(RMU_3DLUT_MODE[rmu_idx],
-                       MPC_RMU_3DLUT_MODE_CURRENT,  &i_mode);
-
-       REG_GET(RMU_3DLUT_READ_WRITE_CONTROL[rmu_idx],
-                       MPC_RMU_3DLUT_30BIT_EN, &i_enable_10bits);
-
-       switch (i_mode) {
-       case 0:
-               mode = LUT_BYPASS;
-               break;
-       case 1:
-               mode = LUT_RAM_A;
-               break;
-       case 2:
-               mode = LUT_RAM_B;
-               break;
-       default:
-               mode = LUT_BYPASS;
-               break;
-       }
-       if (i_enable_10bits > 0)
-               *is_12bits_color_channel = false;
-       else
-               *is_12bits_color_channel = true;
-
-       REG_GET(RMU_3DLUT_MODE[rmu_idx], MPC_RMU_3DLUT_SIZE, &lut_size);
-
-       if (lut_size == 0)
-               *is_17x17x17 = true;
-       else
-               *is_17x17x17 = false;
-
-       return mode;
-}
-
-static void mpc3_select_3dlut_ram(
-               struct mpc *mpc,
-               enum dc_lut_mode mode,
-               bool is_color_channel_12bits,
-               uint32_t rmu_idx)
-{
-       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
-
-       REG_UPDATE_2(RMU_3DLUT_READ_WRITE_CONTROL[rmu_idx],
-               MPC_RMU_3DLUT_RAM_SEL, mode == LUT_RAM_A ? 0 : 1,
-               MPC_RMU_3DLUT_30BIT_EN, is_color_channel_12bits == true ? 0:1);
-}
-
-static void mpc3_select_3dlut_ram_mask(
-               struct mpc *mpc,
-               uint32_t ram_selection_mask,
-               uint32_t rmu_idx)
-{
-       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
-
-       REG_UPDATE(RMU_3DLUT_READ_WRITE_CONTROL[rmu_idx], MPC_RMU_3DLUT_WRITE_EN_MASK,
-                       ram_selection_mask);
-       REG_SET(RMU_3DLUT_INDEX[rmu_idx], 0, MPC_RMU_3DLUT_INDEX, 0);
-}
-
-static void mpc3_set3dlut_ram12(
-               struct mpc *mpc,
-               const struct dc_rgb *lut,
-               uint32_t entries,
-               uint32_t rmu_idx)
-{
-       uint32_t i, red, green, blue, red1, green1, blue1;
-       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
-
-       for (i = 0 ; i < entries; i += 2) {
-               red   = lut[i].red<<4;
-               green = lut[i].green<<4;
-               blue  = lut[i].blue<<4;
-               red1   = lut[i+1].red<<4;
-               green1 = lut[i+1].green<<4;
-               blue1  = lut[i+1].blue<<4;
-
-               REG_SET_2(RMU_3DLUT_DATA[rmu_idx], 0,
-                               MPC_RMU_3DLUT_DATA0, red,
-                               MPC_RMU_3DLUT_DATA1, red1);
-
-               REG_SET_2(RMU_3DLUT_DATA[rmu_idx], 0,
-                               MPC_RMU_3DLUT_DATA0, green,
-                               MPC_RMU_3DLUT_DATA1, green1);
-
-               REG_SET_2(RMU_3DLUT_DATA[rmu_idx], 0,
-                               MPC_RMU_3DLUT_DATA0, blue,
-                               MPC_RMU_3DLUT_DATA1, blue1);
-       }
-}
-
-static void mpc3_set3dlut_ram10(
-               struct mpc *mpc,
-               const struct dc_rgb *lut,
-               uint32_t entries,
-               uint32_t rmu_idx)
-{
-       uint32_t i, red, green, blue, value;
-       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
-
-       for (i = 0; i < entries; i++) {
-               red   = lut[i].red;
-               green = lut[i].green;
-               blue  = lut[i].blue;
-               //should we shift red 22bit and green 12? ask Nvenko
-               value = (red<<20) | (green<<10) | blue;
-
-               REG_SET(RMU_3DLUT_DATA_30BIT[rmu_idx], 0, MPC_RMU_3DLUT_DATA_30BIT, value);
-       }
-
-}
-
-
-void mpc3_init_mpcc(struct mpcc *mpcc, int mpcc_inst)
-{
-       mpcc->mpcc_id = mpcc_inst;
-       mpcc->dpp_id = 0xf;
-       mpcc->mpcc_bot = NULL;
-       mpcc->blnd_cfg.overlap_only = false;
-       mpcc->blnd_cfg.global_alpha = 0xff;
-       mpcc->blnd_cfg.global_gain = 0xff;
-       mpcc->blnd_cfg.background_color_bpc = 4;
-       mpcc->blnd_cfg.bottom_gain_mode = 0;
-       mpcc->blnd_cfg.top_gain = 0x1f000;
-       mpcc->blnd_cfg.bottom_inside_gain = 0x1f000;
-       mpcc->blnd_cfg.bottom_outside_gain = 0x1f000;
-       mpcc->sm_cfg.enable = false;
-       mpcc->shared_bottom = false;
-}
-
-static void program_gamut_remap(
-               struct dcn30_mpc *mpc30,
-               int mpcc_id,
-               const uint16_t *regval,
-               int select)
-{
-       uint16_t selection = 0;
-       struct color_matrices_reg gam_regs;
-
-       if (regval == NULL || select == GAMUT_REMAP_BYPASS) {
-               REG_SET(MPCC_GAMUT_REMAP_MODE[mpcc_id], 0,
-                               MPCC_GAMUT_REMAP_MODE, GAMUT_REMAP_BYPASS);
-               return;
-       }
-       switch (select) {
-       case GAMUT_REMAP_COEFF:
-               selection = 1;
-               break;
-               /*this corresponds to GAMUT_REMAP coefficients set B
-                * we don't have common coefficient sets in dcn3ag/dcn3
-                */
-       case GAMUT_REMAP_COMA_COEFF:
-               selection = 2;
-               break;
-       default:
-               break;
-       }
-
-       gam_regs.shifts.csc_c11 = mpc30->mpc_shift->MPCC_GAMUT_REMAP_C11_A;
-       gam_regs.masks.csc_c11  = mpc30->mpc_mask->MPCC_GAMUT_REMAP_C11_A;
-       gam_regs.shifts.csc_c12 = mpc30->mpc_shift->MPCC_GAMUT_REMAP_C12_A;
-       gam_regs.masks.csc_c12 = mpc30->mpc_mask->MPCC_GAMUT_REMAP_C12_A;
-
-
-       if (select == GAMUT_REMAP_COEFF) {
-               gam_regs.csc_c11_c12 = REG(MPC_GAMUT_REMAP_C11_C12_A[mpcc_id]);
-               gam_regs.csc_c33_c34 = REG(MPC_GAMUT_REMAP_C33_C34_A[mpcc_id]);
-
-               cm_helper_program_color_matrices(
-                               mpc30->base.ctx,
-                               regval,
-                               &gam_regs);
-
-       } else  if (select == GAMUT_REMAP_COMA_COEFF) {
-
-               gam_regs.csc_c11_c12 = REG(MPC_GAMUT_REMAP_C11_C12_B[mpcc_id]);
-               gam_regs.csc_c33_c34 = REG(MPC_GAMUT_REMAP_C33_C34_B[mpcc_id]);
-
-               cm_helper_program_color_matrices(
-                               mpc30->base.ctx,
-                               regval,
-                               &gam_regs);
-
-       }
-       //select coefficient set to use
-       REG_SET(MPCC_GAMUT_REMAP_MODE[mpcc_id], 0,
-                                       MPCC_GAMUT_REMAP_MODE, selection);
-}
-
-void mpc3_set_gamut_remap(
-               struct mpc *mpc,
-               int mpcc_id,
-               const struct mpc_grph_gamut_adjustment *adjust)
-{
-       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
-       int i = 0;
-       int gamut_mode;
-
-       if (adjust->gamut_adjust_type != GRAPHICS_GAMUT_ADJUST_TYPE_SW)
-               program_gamut_remap(mpc30, mpcc_id, NULL, GAMUT_REMAP_BYPASS);
-       else {
-               struct fixed31_32 arr_matrix[12];
-               uint16_t arr_reg_val[12];
-
-               for (i = 0; i < 12; i++)
-                       arr_matrix[i] = adjust->temperature_matrix[i];
-
-               convert_float_matrix(
-                       arr_reg_val, arr_matrix, 12);
-
-               //current coefficient set in use
-               REG_GET(MPCC_GAMUT_REMAP_MODE[mpcc_id], MPCC_GAMUT_REMAP_MODE_CURRENT, &gamut_mode);
-
-               if (gamut_mode == 0)
-                       gamut_mode = 1; //use coefficient set A
-               else if (gamut_mode == 1)
-                       gamut_mode = 2;
-               else
-                       gamut_mode = 1;
-
-               program_gamut_remap(mpc30, mpcc_id, arr_reg_val, gamut_mode);
-       }
-}
-
-static void read_gamut_remap(struct dcn30_mpc *mpc30,
-                            int mpcc_id,
-                            uint16_t *regval,
-                            uint32_t *select)
-{
-       struct color_matrices_reg gam_regs;
-
-       //current coefficient set in use
-       REG_GET(MPCC_GAMUT_REMAP_MODE[mpcc_id], MPCC_GAMUT_REMAP_MODE_CURRENT, select);
-
-       gam_regs.shifts.csc_c11 = mpc30->mpc_shift->MPCC_GAMUT_REMAP_C11_A;
-       gam_regs.masks.csc_c11  = mpc30->mpc_mask->MPCC_GAMUT_REMAP_C11_A;
-       gam_regs.shifts.csc_c12 = mpc30->mpc_shift->MPCC_GAMUT_REMAP_C12_A;
-       gam_regs.masks.csc_c12 = mpc30->mpc_mask->MPCC_GAMUT_REMAP_C12_A;
-
-       if (*select == GAMUT_REMAP_COEFF) {
-               gam_regs.csc_c11_c12 = REG(MPC_GAMUT_REMAP_C11_C12_A[mpcc_id]);
-               gam_regs.csc_c33_c34 = REG(MPC_GAMUT_REMAP_C33_C34_A[mpcc_id]);
-
-               cm_helper_read_color_matrices(
-                               mpc30->base.ctx,
-                               regval,
-                               &gam_regs);
-
-       } else  if (*select == GAMUT_REMAP_COMA_COEFF) {
-
-               gam_regs.csc_c11_c12 = REG(MPC_GAMUT_REMAP_C11_C12_B[mpcc_id]);
-               gam_regs.csc_c33_c34 = REG(MPC_GAMUT_REMAP_C33_C34_B[mpcc_id]);
-
-               cm_helper_read_color_matrices(
-                               mpc30->base.ctx,
-                               regval,
-                               &gam_regs);
-
-       }
-
-}
-
-void mpc3_get_gamut_remap(struct mpc *mpc,
-                         int mpcc_id,
-                         struct mpc_grph_gamut_adjustment *adjust)
-{
-       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
-       uint16_t arr_reg_val[12] = {0};
-       int select;
-
-       read_gamut_remap(mpc30, mpcc_id, arr_reg_val, &select);
-
-       if (select == GAMUT_REMAP_BYPASS) {
-               adjust->gamut_adjust_type = GRAPHICS_GAMUT_ADJUST_TYPE_BYPASS;
-               return;
-       }
-
-       adjust->gamut_adjust_type = GRAPHICS_GAMUT_ADJUST_TYPE_SW;
-       convert_hw_matrix(adjust->temperature_matrix,
-                         arr_reg_val, ARRAY_SIZE(arr_reg_val));
-}
-
-bool mpc3_program_3dlut(
-               struct mpc *mpc,
-               const struct tetrahedral_params *params,
-               int rmu_idx)
-{
-       enum dc_lut_mode mode;
-       bool is_17x17x17;
-       bool is_12bits_color_channel;
-       const struct dc_rgb *lut0;
-       const struct dc_rgb *lut1;
-       const struct dc_rgb *lut2;
-       const struct dc_rgb *lut3;
-       int lut_size0;
-       int lut_size;
-
-       if (params == NULL) {
-               mpc3_set_3dlut_mode(mpc, LUT_BYPASS, false, false, rmu_idx);
-               return false;
-       }
-       mpc3_power_on_shaper_3dlut(mpc, rmu_idx, true);
-
-       mode = get3dlut_config(mpc, &is_17x17x17, &is_12bits_color_channel, rmu_idx);
-
-       if (mode == LUT_BYPASS || mode == LUT_RAM_B)
-               mode = LUT_RAM_A;
-       else
-               mode = LUT_RAM_B;
-
-       is_17x17x17 = !params->use_tetrahedral_9;
-       is_12bits_color_channel = params->use_12bits;
-       if (is_17x17x17) {
-               lut0 = params->tetrahedral_17.lut0;
-               lut1 = params->tetrahedral_17.lut1;
-               lut2 = params->tetrahedral_17.lut2;
-               lut3 = params->tetrahedral_17.lut3;
-               lut_size0 = sizeof(params->tetrahedral_17.lut0)/
-                                       sizeof(params->tetrahedral_17.lut0[0]);
-               lut_size  = sizeof(params->tetrahedral_17.lut1)/
-                                       sizeof(params->tetrahedral_17.lut1[0]);
-       } else {
-               lut0 = params->tetrahedral_9.lut0;
-               lut1 = params->tetrahedral_9.lut1;
-               lut2 = params->tetrahedral_9.lut2;
-               lut3 = params->tetrahedral_9.lut3;
-               lut_size0 = sizeof(params->tetrahedral_9.lut0)/
-                               sizeof(params->tetrahedral_9.lut0[0]);
-               lut_size  = sizeof(params->tetrahedral_9.lut1)/
-                               sizeof(params->tetrahedral_9.lut1[0]);
-               }
-
-       mpc3_select_3dlut_ram(mpc, mode,
-                               is_12bits_color_channel, rmu_idx);
-       mpc3_select_3dlut_ram_mask(mpc, 0x1, rmu_idx);
-       if (is_12bits_color_channel)
-               mpc3_set3dlut_ram12(mpc, lut0, lut_size0, rmu_idx);
-       else
-               mpc3_set3dlut_ram10(mpc, lut0, lut_size0, rmu_idx);
-
-       mpc3_select_3dlut_ram_mask(mpc, 0x2, rmu_idx);
-       if (is_12bits_color_channel)
-               mpc3_set3dlut_ram12(mpc, lut1, lut_size, rmu_idx);
-       else
-               mpc3_set3dlut_ram10(mpc, lut1, lut_size, rmu_idx);
-
-       mpc3_select_3dlut_ram_mask(mpc, 0x4, rmu_idx);
-       if (is_12bits_color_channel)
-               mpc3_set3dlut_ram12(mpc, lut2, lut_size, rmu_idx);
-       else
-               mpc3_set3dlut_ram10(mpc, lut2, lut_size, rmu_idx);
-
-       mpc3_select_3dlut_ram_mask(mpc, 0x8, rmu_idx);
-       if (is_12bits_color_channel)
-               mpc3_set3dlut_ram12(mpc, lut3, lut_size, rmu_idx);
-       else
-               mpc3_set3dlut_ram10(mpc, lut3, lut_size, rmu_idx);
-
-       mpc3_set_3dlut_mode(mpc, mode, is_12bits_color_channel,
-                                       is_17x17x17, rmu_idx);
-
-       if (mpc->ctx->dc->debug.enable_mem_low_power.bits.mpc)
-               mpc3_power_on_shaper_3dlut(mpc, rmu_idx, false);
-
-       return true;
-}
-
-void mpc3_set_output_csc(
-               struct mpc *mpc,
-               int opp_id,
-               const uint16_t *regval,
-               enum mpc_output_csc_mode ocsc_mode)
-{
-       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
-       struct color_matrices_reg ocsc_regs;
-
-       REG_WRITE(MPC_OUT_CSC_COEF_FORMAT, 0);
-
-       REG_SET(CSC_MODE[opp_id], 0, MPC_OCSC_MODE, ocsc_mode);
-
-       if (ocsc_mode == MPC_OUTPUT_CSC_DISABLE)
-               return;
-
-       if (regval == NULL) {
-               BREAK_TO_DEBUGGER();
-               return;
-       }
-
-       ocsc_regs.shifts.csc_c11 = mpc30->mpc_shift->MPC_OCSC_C11_A;
-       ocsc_regs.masks.csc_c11  = mpc30->mpc_mask->MPC_OCSC_C11_A;
-       ocsc_regs.shifts.csc_c12 = mpc30->mpc_shift->MPC_OCSC_C12_A;
-       ocsc_regs.masks.csc_c12 = mpc30->mpc_mask->MPC_OCSC_C12_A;
-
-       if (ocsc_mode == MPC_OUTPUT_CSC_COEF_A) {
-               ocsc_regs.csc_c11_c12 = REG(CSC_C11_C12_A[opp_id]);
-               ocsc_regs.csc_c33_c34 = REG(CSC_C33_C34_A[opp_id]);
-       } else {
-               ocsc_regs.csc_c11_c12 = REG(CSC_C11_C12_B[opp_id]);
-               ocsc_regs.csc_c33_c34 = REG(CSC_C33_C34_B[opp_id]);
-       }
-       cm_helper_program_color_matrices(
-                       mpc30->base.ctx,
-                       regval,
-                       &ocsc_regs);
-}
-
-void mpc3_set_ocsc_default(
-               struct mpc *mpc,
-               int opp_id,
-               enum dc_color_space color_space,
-               enum mpc_output_csc_mode ocsc_mode)
-{
-       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
-       uint32_t arr_size;
-       struct color_matrices_reg ocsc_regs;
-       const uint16_t *regval = NULL;
-
-       REG_WRITE(MPC_OUT_CSC_COEF_FORMAT, 0);
-
-       REG_SET(CSC_MODE[opp_id], 0, MPC_OCSC_MODE, ocsc_mode);
-       if (ocsc_mode == MPC_OUTPUT_CSC_DISABLE)
-               return;
-
-       regval = find_color_matrix(color_space, &arr_size);
-
-       if (regval == NULL) {
-               BREAK_TO_DEBUGGER();
-               return;
-       }
-
-       ocsc_regs.shifts.csc_c11 = mpc30->mpc_shift->MPC_OCSC_C11_A;
-       ocsc_regs.masks.csc_c11  = mpc30->mpc_mask->MPC_OCSC_C11_A;
-       ocsc_regs.shifts.csc_c12 = mpc30->mpc_shift->MPC_OCSC_C12_A;
-       ocsc_regs.masks.csc_c12 = mpc30->mpc_mask->MPC_OCSC_C12_A;
-
-
-       if (ocsc_mode == MPC_OUTPUT_CSC_COEF_A) {
-               ocsc_regs.csc_c11_c12 = REG(CSC_C11_C12_A[opp_id]);
-               ocsc_regs.csc_c33_c34 = REG(CSC_C33_C34_A[opp_id]);
-       } else {
-               ocsc_regs.csc_c11_c12 = REG(CSC_C11_C12_B[opp_id]);
-               ocsc_regs.csc_c33_c34 = REG(CSC_C33_C34_B[opp_id]);
-       }
-
-       cm_helper_program_color_matrices(
-                       mpc30->base.ctx,
-                       regval,
-                       &ocsc_regs);
-}
-
-void mpc3_set_rmu_mux(
-       struct mpc *mpc,
-       int rmu_idx,
-       int value)
-{
-       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
-
-       if (rmu_idx == 0)
-               REG_UPDATE(MPC_RMU_CONTROL, MPC_RMU0_MUX, value);
-       else if (rmu_idx == 1)
-               REG_UPDATE(MPC_RMU_CONTROL, MPC_RMU1_MUX, value);
-
-}
-
-uint32_t mpc3_get_rmu_mux_status(
-       struct mpc *mpc,
-       int rmu_idx)
-{
-       uint32_t status = 0xf;
-       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
-
-       if (rmu_idx == 0)
-               REG_GET(MPC_RMU_CONTROL, MPC_RMU0_MUX_STATUS, &status);
-       else if (rmu_idx == 1)
-               REG_GET(MPC_RMU_CONTROL, MPC_RMU1_MUX_STATUS, &status);
-
-       return status;
-}
-
-uint32_t mpcc3_acquire_rmu(struct mpc *mpc, int mpcc_id, int rmu_idx)
-{
-       uint32_t rmu_status;
-
-       //determine if this mpcc is already multiplexed to an RMU unit
-       rmu_status = mpc3_get_rmu_mux_status(mpc, rmu_idx);
-       if (rmu_status == mpcc_id)
-               //return rmu_idx of pre_acquired rmu unit
-               return rmu_idx;
-
-       if (rmu_status == 0xf) {//rmu unit is disabled
-               mpc3_set_rmu_mux(mpc, rmu_idx, mpcc_id);
-               return rmu_idx;
-       }
-
-       //no vacant RMU units or invalid parameters acquire_post_bldn_3dlut
-       return -1;
-}
-
-static int mpcc3_release_rmu(struct mpc *mpc, int mpcc_id)
-{
-       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
-       int rmu_idx;
-       uint32_t rmu_status;
-       int released_rmu = -1;
-
-       for (rmu_idx = 0; rmu_idx < mpc30->num_rmu; rmu_idx++) {
-               rmu_status = mpc3_get_rmu_mux_status(mpc, rmu_idx);
-               if (rmu_status == mpcc_id) {
-                       mpc3_set_rmu_mux(mpc, rmu_idx, 0xf);
-                       released_rmu = rmu_idx;
-                       break;
-               }
-       }
-       return released_rmu;
-
-}
-
-static void mpc3_set_mpc_mem_lp_mode(struct mpc *mpc)
-{
-       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
-       int mpcc_id;
-
-       if (mpc->ctx->dc->debug.enable_mem_low_power.bits.mpc) {
-               if (mpc30->mpc_mask->MPC_RMU0_MEM_LOW_PWR_MODE && mpc30->mpc_mask->MPC_RMU1_MEM_LOW_PWR_MODE) {
-                       REG_UPDATE(MPC_RMU_MEM_PWR_CTRL, MPC_RMU0_MEM_LOW_PWR_MODE, 3);
-                       REG_UPDATE(MPC_RMU_MEM_PWR_CTRL, MPC_RMU1_MEM_LOW_PWR_MODE, 3);
-               }
-
-               if (mpc30->mpc_mask->MPCC_OGAM_MEM_LOW_PWR_MODE) {
-                       for (mpcc_id = 0; mpcc_id < mpc30->num_mpcc; mpcc_id++)
-                               REG_UPDATE(MPCC_MEM_PWR_CTRL[mpcc_id], MPCC_OGAM_MEM_LOW_PWR_MODE, 3);
-               }
-       }
-}
-
-static void mpc3_read_mpcc_state(
-               struct mpc *mpc,
-               int mpcc_inst,
-               struct mpcc_state *s)
-{
-       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
-       uint32_t rmu_status = 0xf;
-
-       REG_GET(MPCC_OPP_ID[mpcc_inst], MPCC_OPP_ID, &s->opp_id);
-       REG_GET(MPCC_TOP_SEL[mpcc_inst], MPCC_TOP_SEL, &s->dpp_id);
-       REG_GET(MPCC_BOT_SEL[mpcc_inst], MPCC_BOT_SEL, &s->bot_mpcc_id);
-       REG_GET_4(MPCC_CONTROL[mpcc_inst], MPCC_MODE, &s->mode,
-                       MPCC_ALPHA_BLND_MODE, &s->alpha_mode,
-                       MPCC_ALPHA_MULTIPLIED_MODE, &s->pre_multiplied_alpha,
-                       MPCC_BLND_ACTIVE_OVERLAP_ONLY, &s->overlap_only);
-       REG_GET_2(MPCC_STATUS[mpcc_inst], MPCC_IDLE, &s->idle,
-                       MPCC_BUSY, &s->busy);
-
-       /* Color blocks state */
-       REG_GET(MPC_RMU_CONTROL, MPC_RMU0_MUX_STATUS, &rmu_status);
-
-       if (rmu_status == mpcc_inst) {
-               REG_GET(SHAPER_CONTROL[0],
-                       MPC_RMU_SHAPER_LUT_MODE_CURRENT, &s->shaper_lut_mode);
-               REG_GET(RMU_3DLUT_MODE[0],
-                       MPC_RMU_3DLUT_MODE_CURRENT,  &s->lut3d_mode);
-               REG_GET(RMU_3DLUT_READ_WRITE_CONTROL[0],
-                       MPC_RMU_3DLUT_30BIT_EN, &s->lut3d_bit_depth);
-               REG_GET(RMU_3DLUT_MODE[0],
-                       MPC_RMU_3DLUT_SIZE, &s->lut3d_size);
-       } else {
-               REG_GET(SHAPER_CONTROL[1],
-                       MPC_RMU_SHAPER_LUT_MODE_CURRENT, &s->shaper_lut_mode);
-               REG_GET(RMU_3DLUT_MODE[1],
-                       MPC_RMU_3DLUT_MODE_CURRENT,  &s->lut3d_mode);
-               REG_GET(RMU_3DLUT_READ_WRITE_CONTROL[1],
-                       MPC_RMU_3DLUT_30BIT_EN, &s->lut3d_bit_depth);
-               REG_GET(RMU_3DLUT_MODE[1],
-                       MPC_RMU_3DLUT_SIZE, &s->lut3d_size);
-       }
-
-       REG_GET_2(MPCC_OGAM_CONTROL[mpcc_inst],
-                 MPCC_OGAM_MODE_CURRENT, &s->rgam_mode,
-                 MPCC_OGAM_SELECT_CURRENT, &s->rgam_lut);
-}
-
-static const struct mpc_funcs dcn30_mpc_funcs = {
-       .read_mpcc_state = mpc3_read_mpcc_state,
-       .insert_plane = mpc1_insert_plane,
-       .remove_mpcc = mpc1_remove_mpcc,
-       .mpc_init = mpc3_mpc_init,
-       .mpc_init_single_inst = mpc3_mpc_init_single_inst,
-       .update_blending = mpc2_update_blending,
-       .cursor_lock = mpc1_cursor_lock,
-       .get_mpcc_for_dpp = mpc1_get_mpcc_for_dpp,
-       .wait_for_idle = mpc2_assert_idle_mpcc,
-       .assert_mpcc_idle_before_connect = mpc2_assert_mpcc_idle_before_connect,
-       .init_mpcc_list_from_hw = mpc1_init_mpcc_list_from_hw,
-       .set_denorm =  mpc3_set_denorm,
-       .set_denorm_clamp = mpc3_set_denorm_clamp,
-       .set_output_csc = mpc3_set_output_csc,
-       .set_ocsc_default = mpc3_set_ocsc_default,
-       .set_output_gamma = mpc3_set_output_gamma,
-       .insert_plane_to_secondary = NULL,
-       .remove_mpcc_from_secondary =  NULL,
-       .set_dwb_mux = mpc3_set_dwb_mux,
-       .disable_dwb_mux = mpc3_disable_dwb_mux,
-       .is_dwb_idle = mpc3_is_dwb_idle,
-       .set_gamut_remap = mpc3_set_gamut_remap,
-       .program_shaper = mpc3_program_shaper,
-       .acquire_rmu = mpcc3_acquire_rmu,
-       .program_3dlut = mpc3_program_3dlut,
-       .release_rmu = mpcc3_release_rmu,
-       .power_on_mpc_mem_pwr = mpc3_power_on_ogam_lut,
-       .get_mpc_out_mux = mpc1_get_mpc_out_mux,
-       .set_bg_color = mpc1_set_bg_color,
-       .set_mpc_mem_lp_mode = mpc3_set_mpc_mem_lp_mode,
-};
-
-void dcn30_mpc_construct(struct dcn30_mpc *mpc30,
-       struct dc_context *ctx,
-       const struct dcn30_mpc_registers *mpc_regs,
-       const struct dcn30_mpc_shift *mpc_shift,
-       const struct dcn30_mpc_mask *mpc_mask,
-       int num_mpcc,
-       int num_rmu)
-{
-       int i;
-
-       mpc30->base.ctx = ctx;
-
-       mpc30->base.funcs = &dcn30_mpc_funcs;
-
-       mpc30->mpc_regs = mpc_regs;
-       mpc30->mpc_shift = mpc_shift;
-       mpc30->mpc_mask = mpc_mask;
-
-       mpc30->mpcc_in_use_mask = 0;
-       mpc30->num_mpcc = num_mpcc;
-       mpc30->num_rmu = num_rmu;
-
-       for (i = 0; i < MAX_MPCC; i++)
-               mpc3_init_mpcc(&mpc30->base.mpcc_array[i], i);
-}
-
diff --git a/drivers/gpu/drm/amd/display/dc/dcn30/dcn30_mpc.h b/drivers/gpu/drm/amd/display/dc/dcn30/dcn30_mpc.h
deleted file mode 100644 (file)
index ce93003..0000000
+++ /dev/null
@@ -1,1098 +0,0 @@
-/* Copyright 2020 Advanced Micro Devices, Inc.
- *
- * Permission is hereby granted, free of charge, to any person obtaining a
- * copy of this software and associated documentation files (the "Software"),
- * to deal in the Software without restriction, including without limitation
- * the rights to use, copy, modify, merge, publish, distribute, sublicense,
- * and/or sell copies of the Software, and to permit persons to whom the
- * Software is furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice shall be included in
- * all copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
- * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
- * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
- * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
- * OTHER DEALINGS IN THE SOFTWARE.
- *
- * Authors: AMD
- *
- */
-
-#ifndef __DC_MPCC_DCN30_H__
-#define __DC_MPCC_DCN30_H__
-
-#include "dcn20/dcn20_mpc.h"
-
-#define MAX_RMU 3
-
-#define TO_DCN30_MPC(mpc_base) \
-       container_of(mpc_base, struct dcn30_mpc, base)
-
-#ifdef SRII_MPC_RMU
-#undef SRII_MPC_RMU
-
-#define SRII_MPC_RMU(reg_name, block, id)\
-       .RMU##_##reg_name[id] = BASE(mm ## block ## id ## _ ## reg_name ## _BASE_IDX) + \
-                                       mm ## block ## id ## _ ## reg_name
-
-#endif
-
-
-#define MPC_REG_LIST_DCN3_0(inst)\
-       MPC_COMMON_REG_LIST_DCN1_0(inst),\
-       SRII(MPCC_TOP_GAIN, MPCC, inst),\
-       SRII(MPCC_BOT_GAIN_INSIDE, MPCC, inst),\
-       SRII(MPCC_BOT_GAIN_OUTSIDE, MPCC, inst),\
-       SRII(MPCC_MEM_PWR_CTRL, MPCC, inst),\
-       SRII(MPCC_OGAM_LUT_INDEX, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_LUT_DATA, MPCC_OGAM, inst), \
-       SRII(MPCC_GAMUT_REMAP_COEF_FORMAT, MPCC_OGAM, inst),\
-       SRII(MPCC_GAMUT_REMAP_MODE, MPCC_OGAM, inst),\
-       SRII(MPC_GAMUT_REMAP_C11_C12_A, MPCC_OGAM, inst),\
-       SRII(MPC_GAMUT_REMAP_C33_C34_A, MPCC_OGAM, inst),\
-       SRII(MPC_GAMUT_REMAP_C11_C12_B, MPCC_OGAM, inst),\
-       SRII(MPC_GAMUT_REMAP_C33_C34_B, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMA_START_CNTL_B, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMA_START_CNTL_G, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMA_START_CNTL_R, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMA_START_SLOPE_CNTL_B, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMA_START_SLOPE_CNTL_G, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMA_START_SLOPE_CNTL_R, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMA_END_CNTL1_B, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMA_END_CNTL2_B, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMA_END_CNTL1_G, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMA_END_CNTL2_G, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMA_END_CNTL1_R, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMA_END_CNTL2_R, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMA_REGION_0_1, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMA_REGION_32_33, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMA_OFFSET_B, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMA_OFFSET_G, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMA_OFFSET_R, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMA_START_BASE_CNTL_B, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMA_START_BASE_CNTL_G, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMA_START_BASE_CNTL_R, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMB_START_CNTL_B, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMB_START_CNTL_G, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMB_START_CNTL_R, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMB_START_SLOPE_CNTL_B, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMB_START_SLOPE_CNTL_G, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMB_START_SLOPE_CNTL_R, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMB_END_CNTL1_B, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMB_END_CNTL2_B, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMB_END_CNTL1_G, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMB_END_CNTL2_G, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMB_END_CNTL1_R, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMB_END_CNTL2_R, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMB_REGION_0_1, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMB_REGION_32_33, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMB_OFFSET_B, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMB_OFFSET_G, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMB_OFFSET_R, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMB_START_BASE_CNTL_B, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMB_START_BASE_CNTL_G, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_RAMB_START_BASE_CNTL_R, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_CONTROL, MPCC_OGAM, inst),\
-       SRII(MPCC_OGAM_LUT_CONTROL, MPCC_OGAM, inst)
-
-#define MPC_OUT_MUX_REG_LIST_DCN3_0(inst) \
-       MPC_OUT_MUX_COMMON_REG_LIST_DCN1_0(inst),\
-       SRII(CSC_MODE, MPC_OUT, inst),\
-       SRII(CSC_C11_C12_A, MPC_OUT, inst),\
-       SRII(CSC_C33_C34_A, MPC_OUT, inst),\
-       SRII(CSC_C11_C12_B, MPC_OUT, inst),\
-       SRII(CSC_C33_C34_B, MPC_OUT, inst),\
-       SRII(DENORM_CONTROL, MPC_OUT, inst),\
-       SRII(DENORM_CLAMP_G_Y, MPC_OUT, inst),\
-       SRII(DENORM_CLAMP_B_CB, MPC_OUT, inst), \
-       SR(MPC_OUT_CSC_COEF_FORMAT)
-
-#define MPC_RMU_GLOBAL_REG_LIST_DCN3AG \
-       SR(MPC_RMU_CONTROL),\
-       SR(MPC_RMU_MEM_PWR_CTRL)
-
-#define MPC_RMU_REG_LIST_DCN3AG(inst) \
-       SRII(SHAPER_CONTROL, MPC_RMU, inst),\
-       SRII(SHAPER_OFFSET_R, MPC_RMU, inst),\
-       SRII(SHAPER_OFFSET_G, MPC_RMU, inst),\
-       SRII(SHAPER_OFFSET_B, MPC_RMU, inst),\
-       SRII(SHAPER_SCALE_R, MPC_RMU, inst),\
-       SRII(SHAPER_SCALE_G_B, MPC_RMU, inst),\
-       SRII(SHAPER_LUT_INDEX, MPC_RMU, inst),\
-       SRII(SHAPER_LUT_DATA, MPC_RMU, inst),\
-       SRII(SHAPER_LUT_WRITE_EN_MASK, MPC_RMU, inst),\
-       SRII(SHAPER_RAMA_START_CNTL_B, MPC_RMU, inst),\
-       SRII(SHAPER_RAMA_START_CNTL_G, MPC_RMU, inst),\
-       SRII(SHAPER_RAMA_START_CNTL_R, MPC_RMU, inst),\
-       SRII(SHAPER_RAMA_END_CNTL_B, MPC_RMU, inst),\
-       SRII(SHAPER_RAMA_END_CNTL_G, MPC_RMU, inst),\
-       SRII(SHAPER_RAMA_END_CNTL_R, MPC_RMU, inst),\
-       SRII(SHAPER_RAMA_REGION_0_1, MPC_RMU, inst),\
-       SRII(SHAPER_RAMA_REGION_2_3, MPC_RMU, inst),\
-       SRII(SHAPER_RAMA_REGION_4_5, MPC_RMU, inst),\
-       SRII(SHAPER_RAMA_REGION_6_7, MPC_RMU, inst),\
-       SRII(SHAPER_RAMA_REGION_8_9, MPC_RMU, inst),\
-       SRII(SHAPER_RAMA_REGION_10_11, MPC_RMU, inst),\
-       SRII(SHAPER_RAMA_REGION_12_13, MPC_RMU, inst),\
-       SRII(SHAPER_RAMA_REGION_14_15, MPC_RMU, inst),\
-       SRII(SHAPER_RAMA_REGION_16_17, MPC_RMU, inst),\
-       SRII(SHAPER_RAMA_REGION_18_19, MPC_RMU, inst),\
-       SRII(SHAPER_RAMA_REGION_20_21, MPC_RMU, inst),\
-       SRII(SHAPER_RAMA_REGION_22_23, MPC_RMU, inst),\
-       SRII(SHAPER_RAMA_REGION_24_25, MPC_RMU, inst),\
-       SRII(SHAPER_RAMA_REGION_26_27, MPC_RMU, inst),\
-       SRII(SHAPER_RAMA_REGION_28_29, MPC_RMU, inst),\
-       SRII(SHAPER_RAMA_REGION_30_31, MPC_RMU, inst),\
-       SRII(SHAPER_RAMA_REGION_32_33, MPC_RMU, inst),\
-       SRII(SHAPER_RAMB_START_CNTL_B, MPC_RMU, inst),\
-       SRII(SHAPER_RAMB_START_CNTL_G, MPC_RMU, inst),\
-       SRII(SHAPER_RAMB_START_CNTL_R, MPC_RMU, inst),\
-       SRII(SHAPER_RAMB_END_CNTL_B, MPC_RMU, inst),\
-       SRII(SHAPER_RAMB_END_CNTL_G, MPC_RMU, inst),\
-       SRII(SHAPER_RAMB_END_CNTL_R, MPC_RMU, inst),\
-       SRII(SHAPER_RAMB_REGION_0_1, MPC_RMU, inst),\
-       SRII(SHAPER_RAMB_REGION_2_3, MPC_RMU, inst),\
-       SRII(SHAPER_RAMB_REGION_4_5, MPC_RMU, inst),\
-       SRII(SHAPER_RAMB_REGION_6_7, MPC_RMU, inst),\
-       SRII(SHAPER_RAMB_REGION_8_9, MPC_RMU, inst),\
-       SRII(SHAPER_RAMB_REGION_10_11, MPC_RMU, inst),\
-       SRII(SHAPER_RAMB_REGION_12_13, MPC_RMU, inst),\
-       SRII(SHAPER_RAMB_REGION_14_15, MPC_RMU, inst),\
-       SRII(SHAPER_RAMB_REGION_16_17, MPC_RMU, inst),\
-       SRII(SHAPER_RAMB_REGION_18_19, MPC_RMU, inst),\
-       SRII(SHAPER_RAMB_REGION_20_21, MPC_RMU, inst),\
-       SRII(SHAPER_RAMB_REGION_22_23, MPC_RMU, inst),\
-       SRII(SHAPER_RAMB_REGION_24_25, MPC_RMU, inst),\
-       SRII(SHAPER_RAMB_REGION_26_27, MPC_RMU, inst),\
-       SRII(SHAPER_RAMB_REGION_28_29, MPC_RMU, inst),\
-       SRII(SHAPER_RAMB_REGION_30_31, MPC_RMU, inst),\
-       SRII(SHAPER_RAMB_REGION_32_33, MPC_RMU, inst),\
-       SRII_MPC_RMU(3DLUT_MODE, MPC_RMU, inst),\
-       SRII_MPC_RMU(3DLUT_INDEX, MPC_RMU, inst),\
-       SRII_MPC_RMU(3DLUT_DATA, MPC_RMU, inst),\
-       SRII_MPC_RMU(3DLUT_DATA_30BIT, MPC_RMU, inst),\
-       SRII_MPC_RMU(3DLUT_READ_WRITE_CONTROL, MPC_RMU, inst),\
-       SRII_MPC_RMU(3DLUT_OUT_NORM_FACTOR, MPC_RMU, inst),\
-       SRII_MPC_RMU(3DLUT_OUT_OFFSET_R, MPC_RMU, inst),\
-       SRII_MPC_RMU(3DLUT_OUT_OFFSET_G, MPC_RMU, inst),\
-       SRII_MPC_RMU(3DLUT_OUT_OFFSET_B, MPC_RMU, inst)
-
-
-#define MPC_DWB_MUX_REG_LIST_DCN3_0(inst) \
-       SRII_DWB(DWB_MUX, MUX, MPC_DWB, inst)
-
-#define MPC_REG_VARIABLE_LIST_DCN3_0 \
-       MPC_REG_VARIABLE_LIST_DCN2_0 \
-       uint32_t DWB_MUX[MAX_DWB]; \
-       uint32_t MPCC_GAMUT_REMAP_COEF_FORMAT[MAX_MPCC]; \
-       uint32_t MPCC_GAMUT_REMAP_MODE[MAX_MPCC]; \
-       uint32_t MPC_GAMUT_REMAP_C11_C12_A[MAX_MPCC]; \
-       uint32_t MPC_GAMUT_REMAP_C33_C34_A[MAX_MPCC]; \
-       uint32_t MPC_GAMUT_REMAP_C11_C12_B[MAX_MPCC]; \
-       uint32_t MPC_GAMUT_REMAP_C33_C34_B[MAX_MPCC]; \
-       uint32_t MPC_RMU_CONTROL; \
-       uint32_t MPC_RMU_MEM_PWR_CTRL; \
-       uint32_t SHAPER_CONTROL[MAX_RMU]; \
-       uint32_t SHAPER_OFFSET_R[MAX_RMU]; \
-       uint32_t SHAPER_OFFSET_G[MAX_RMU]; \
-       uint32_t SHAPER_OFFSET_B[MAX_RMU]; \
-       uint32_t SHAPER_SCALE_R[MAX_RMU]; \
-       uint32_t SHAPER_SCALE_G_B[MAX_RMU]; \
-       uint32_t SHAPER_LUT_INDEX[MAX_RMU]; \
-       uint32_t SHAPER_LUT_DATA[MAX_RMU]; \
-       uint32_t SHAPER_LUT_WRITE_EN_MASK[MAX_RMU]; \
-       uint32_t SHAPER_RAMA_START_CNTL_B[MAX_RMU]; \
-       uint32_t SHAPER_RAMA_START_CNTL_G[MAX_RMU]; \
-       uint32_t SHAPER_RAMA_START_CNTL_R[MAX_RMU]; \
-       uint32_t SHAPER_RAMA_END_CNTL_B[MAX_RMU]; \
-       uint32_t SHAPER_RAMA_END_CNTL_G[MAX_RMU]; \
-       uint32_t SHAPER_RAMA_END_CNTL_R[MAX_RMU]; \
-       uint32_t SHAPER_RAMA_REGION_0_1[MAX_RMU]; \
-       uint32_t SHAPER_RAMA_REGION_2_3[MAX_RMU]; \
-       uint32_t SHAPER_RAMA_REGION_4_5[MAX_RMU]; \
-       uint32_t SHAPER_RAMA_REGION_6_7[MAX_RMU]; \
-       uint32_t SHAPER_RAMA_REGION_8_9[MAX_RMU]; \
-       uint32_t SHAPER_RAMA_REGION_10_11[MAX_RMU]; \
-       uint32_t SHAPER_RAMA_REGION_12_13[MAX_RMU]; \
-       uint32_t SHAPER_RAMA_REGION_14_15[MAX_RMU]; \
-       uint32_t SHAPER_RAMA_REGION_16_17[MAX_RMU]; \
-       uint32_t SHAPER_RAMA_REGION_18_19[MAX_RMU]; \
-       uint32_t SHAPER_RAMA_REGION_20_21[MAX_RMU]; \
-       uint32_t SHAPER_RAMA_REGION_22_23[MAX_RMU]; \
-       uint32_t SHAPER_RAMA_REGION_24_25[MAX_RMU]; \
-       uint32_t SHAPER_RAMA_REGION_26_27[MAX_RMU]; \
-       uint32_t SHAPER_RAMA_REGION_28_29[MAX_RMU]; \
-       uint32_t SHAPER_RAMA_REGION_30_31[MAX_RMU]; \
-       uint32_t SHAPER_RAMA_REGION_32_33[MAX_RMU]; \
-       uint32_t MPCC_OGAM_RAMA_START_SLOPE_CNTL_B[MAX_MPCC]; \
-       uint32_t MPCC_OGAM_RAMA_START_SLOPE_CNTL_G[MAX_MPCC]; \
-       uint32_t MPCC_OGAM_RAMA_START_SLOPE_CNTL_R[MAX_MPCC]; \
-       uint32_t MPCC_OGAM_RAMA_OFFSET_B[MAX_MPCC]; \
-       uint32_t MPCC_OGAM_RAMA_OFFSET_G[MAX_MPCC]; \
-       uint32_t MPCC_OGAM_RAMA_OFFSET_R[MAX_MPCC]; \
-       uint32_t MPCC_OGAM_RAMA_START_BASE_CNTL_B[MAX_MPCC]; \
-       uint32_t MPCC_OGAM_RAMA_START_BASE_CNTL_G[MAX_MPCC]; \
-       uint32_t MPCC_OGAM_RAMA_START_BASE_CNTL_R[MAX_MPCC];\
-       uint32_t SHAPER_RAMB_START_CNTL_B[MAX_RMU]; \
-       uint32_t SHAPER_RAMB_START_CNTL_G[MAX_RMU]; \
-       uint32_t SHAPER_RAMB_START_CNTL_R[MAX_RMU]; \
-       uint32_t SHAPER_RAMB_END_CNTL_B[MAX_RMU]; \
-       uint32_t SHAPER_RAMB_END_CNTL_G[MAX_RMU]; \
-       uint32_t SHAPER_RAMB_END_CNTL_R[MAX_RMU]; \
-       uint32_t SHAPER_RAMB_REGION_0_1[MAX_RMU]; \
-       uint32_t SHAPER_RAMB_REGION_2_3[MAX_RMU]; \
-       uint32_t SHAPER_RAMB_REGION_4_5[MAX_RMU]; \
-       uint32_t SHAPER_RAMB_REGION_6_7[MAX_RMU]; \
-       uint32_t SHAPER_RAMB_REGION_8_9[MAX_RMU]; \
-       uint32_t SHAPER_RAMB_REGION_10_11[MAX_RMU]; \
-       uint32_t SHAPER_RAMB_REGION_12_13[MAX_RMU]; \
-       uint32_t SHAPER_RAMB_REGION_14_15[MAX_RMU]; \
-       uint32_t SHAPER_RAMB_REGION_16_17[MAX_RMU]; \
-       uint32_t SHAPER_RAMB_REGION_18_19[MAX_RMU]; \
-       uint32_t SHAPER_RAMB_REGION_20_21[MAX_RMU]; \
-       uint32_t SHAPER_RAMB_REGION_22_23[MAX_RMU]; \
-       uint32_t SHAPER_RAMB_REGION_24_25[MAX_RMU]; \
-       uint32_t SHAPER_RAMB_REGION_26_27[MAX_RMU]; \
-       uint32_t SHAPER_RAMB_REGION_28_29[MAX_RMU]; \
-       uint32_t SHAPER_RAMB_REGION_30_31[MAX_RMU]; \
-       uint32_t SHAPER_RAMB_REGION_32_33[MAX_RMU]; \
-       uint32_t RMU_3DLUT_MODE[MAX_RMU]; \
-       uint32_t RMU_3DLUT_INDEX[MAX_RMU]; \
-       uint32_t RMU_3DLUT_DATA[MAX_RMU]; \
-       uint32_t RMU_3DLUT_DATA_30BIT[MAX_RMU]; \
-       uint32_t RMU_3DLUT_READ_WRITE_CONTROL[MAX_RMU]; \
-       uint32_t RMU_3DLUT_OUT_NORM_FACTOR[MAX_RMU]; \
-       uint32_t RMU_3DLUT_OUT_OFFSET_R[MAX_RMU]; \
-       uint32_t RMU_3DLUT_OUT_OFFSET_G[MAX_RMU]; \
-       uint32_t RMU_3DLUT_OUT_OFFSET_B[MAX_RMU]; \
-       uint32_t MPCC_OGAM_RAMB_START_SLOPE_CNTL_B[MAX_MPCC]; \
-       uint32_t MPCC_OGAM_RAMB_START_SLOPE_CNTL_G[MAX_MPCC]; \
-       uint32_t MPCC_OGAM_RAMB_START_SLOPE_CNTL_R[MAX_MPCC]; \
-       uint32_t MPCC_OGAM_CONTROL[MAX_MPCC]; \
-       uint32_t MPCC_OGAM_LUT_CONTROL[MAX_MPCC]; \
-       uint32_t MPCC_OGAM_RAMB_OFFSET_B[MAX_MPCC]; \
-       uint32_t MPCC_OGAM_RAMB_OFFSET_G[MAX_MPCC]; \
-       uint32_t MPCC_OGAM_RAMB_OFFSET_R[MAX_MPCC]; \
-       uint32_t MPCC_OGAM_RAMB_START_BASE_CNTL_B[MAX_MPCC]; \
-       uint32_t MPCC_OGAM_RAMB_START_BASE_CNTL_G[MAX_MPCC]; \
-       uint32_t MPCC_OGAM_RAMB_START_BASE_CNTL_R[MAX_MPCC]; \
-       uint32_t MPC_OUT_CSC_COEF_FORMAT
-
-#define MPC_REG_VARIABLE_LIST_DCN32 \
-       uint32_t MPCC_MOVABLE_CM_LOCATION_CONTROL[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_CONTROL[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_OFFSET_R[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_OFFSET_G[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_OFFSET_B[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_SCALE_R[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_SCALE_G_B[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_LUT_INDEX[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_LUT_DATA[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_LUT_WRITE_EN_MASK[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_RAMA_START_CNTL_B[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_RAMA_START_CNTL_G[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_RAMA_START_CNTL_R[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_RAMA_END_CNTL_B[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_RAMA_END_CNTL_G[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_RAMA_END_CNTL_R[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_RAMA_REGION_0_1[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_RAMA_REGION_2_3[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_RAMA_REGION_4_5[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_RAMA_REGION_6_7[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_RAMA_REGION_8_9[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_RAMA_REGION_10_11[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_RAMA_REGION_12_13[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_RAMA_REGION_14_15[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_RAMA_REGION_16_17[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_RAMA_REGION_18_19[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_RAMA_REGION_20_21[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_RAMA_REGION_22_23[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_RAMA_REGION_24_25[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_RAMA_REGION_26_27[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_RAMA_REGION_28_29[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_RAMA_REGION_30_31[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_RAMA_REGION_32_33[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_RAMB_START_CNTL_B[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_RAMB_START_CNTL_G[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_RAMB_START_CNTL_R[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_RAMB_END_CNTL_B[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_RAMB_END_CNTL_G[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_RAMB_END_CNTL_R[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_RAMB_REGION_0_1[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_RAMB_REGION_2_3[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_RAMB_REGION_4_5[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_RAMB_REGION_6_7[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_RAMB_REGION_8_9[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_RAMB_REGION_10_11[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_RAMB_REGION_12_13[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_RAMB_REGION_14_15[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_RAMB_REGION_16_17[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_RAMB_REGION_18_19[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_RAMB_REGION_20_21[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_RAMB_REGION_22_23[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_RAMB_REGION_24_25[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_RAMB_REGION_26_27[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_RAMB_REGION_28_29[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_RAMB_REGION_30_31[MAX_MPCC]; \
-       uint32_t MPCC_MCM_SHAPER_RAMB_REGION_32_33[MAX_MPCC]; \
-       uint32_t MPCC_MCM_3DLUT_MODE[MAX_MPCC]; \
-       uint32_t MPCC_MCM_3DLUT_INDEX[MAX_MPCC]; \
-       uint32_t MPCC_MCM_3DLUT_DATA[MAX_MPCC]; \
-       uint32_t MPCC_MCM_3DLUT_DATA_30BIT[MAX_MPCC]; \
-       uint32_t MPCC_MCM_3DLUT_READ_WRITE_CONTROL[MAX_MPCC]; \
-       uint32_t MPCC_MCM_3DLUT_OUT_NORM_FACTOR[MAX_MPCC]; \
-       uint32_t MPCC_MCM_3DLUT_OUT_OFFSET_R[MAX_MPCC]; \
-       uint32_t MPCC_MCM_3DLUT_OUT_OFFSET_G[MAX_MPCC]; \
-       uint32_t MPCC_MCM_3DLUT_OUT_OFFSET_B[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_CONTROL[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_LUT_INDEX[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_LUT_DATA[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_LUT_CONTROL[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMA_START_CNTL_B[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMA_START_CNTL_G[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMA_START_CNTL_R[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMA_START_SLOPE_CNTL_B[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMA_START_SLOPE_CNTL_G[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMA_START_SLOPE_CNTL_R[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMA_START_BASE_CNTL_B[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMA_START_BASE_CNTL_G[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMA_START_BASE_CNTL_R[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMA_END_CNTL1_B[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMA_END_CNTL2_B[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMA_END_CNTL1_G[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMA_END_CNTL2_G[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMA_END_CNTL1_R[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMA_END_CNTL2_R[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMA_OFFSET_B[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMA_OFFSET_G[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMA_OFFSET_R[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMA_REGION_0_1[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMA_REGION_2_3[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMA_REGION_4_5[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMA_REGION_6_7[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMA_REGION_8_9[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMA_REGION_10_11[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMA_REGION_12_13[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMA_REGION_14_15[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMA_REGION_16_17[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMA_REGION_18_19[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMA_REGION_20_21[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMA_REGION_22_23[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMA_REGION_24_25[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMA_REGION_26_27[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMA_REGION_28_29[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMA_REGION_30_31[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMA_REGION_32_33[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMB_START_CNTL_B[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMB_START_CNTL_G[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMB_START_CNTL_R[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMB_START_SLOPE_CNTL_B[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMB_START_SLOPE_CNTL_G[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMB_START_SLOPE_CNTL_R[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMB_START_BASE_CNTL_B[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMB_START_BASE_CNTL_G[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMB_START_BASE_CNTL_R[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMB_END_CNTL1_B[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMB_END_CNTL2_B[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMB_END_CNTL1_G[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMB_END_CNTL2_G[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMB_END_CNTL1_R[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMB_END_CNTL2_R[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMB_OFFSET_B[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMB_OFFSET_G[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMB_OFFSET_R[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMB_REGION_0_1[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMB_REGION_2_3[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMB_REGION_4_5[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMB_REGION_6_7[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMB_REGION_8_9[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMB_REGION_10_11[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMB_REGION_12_13[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMB_REGION_14_15[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMB_REGION_16_17[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMB_REGION_18_19[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMB_REGION_20_21[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMB_REGION_22_23[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMB_REGION_24_25[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMB_REGION_26_27[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMB_REGION_28_29[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMB_REGION_30_31[MAX_MPCC]; \
-       uint32_t MPCC_MCM_1DLUT_RAMB_REGION_32_33[MAX_MPCC]; \
-       uint32_t MPCC_MCM_MEM_PWR_CTRL[MAX_MPCC]
-
-#define MPC_COMMON_MASK_SH_LIST_DCN3_0(mask_sh) \
-       MPC_COMMON_MASK_SH_LIST_DCN1_0(mask_sh),\
-       SF(MPCC0_MPCC_CONTROL, MPCC_BG_BPC, mask_sh),\
-       SF(MPCC0_MPCC_CONTROL, MPCC_BOT_GAIN_MODE, mask_sh),\
-       SF(MPCC0_MPCC_TOP_GAIN, MPCC_TOP_GAIN, mask_sh),\
-       SF(MPCC0_MPCC_BOT_GAIN_INSIDE, MPCC_BOT_GAIN_INSIDE, mask_sh),\
-       SF(MPCC0_MPCC_BOT_GAIN_OUTSIDE, MPCC_BOT_GAIN_OUTSIDE, mask_sh),\
-       SF(MPC_OUT0_CSC_MODE, MPC_OCSC_MODE, mask_sh),\
-       SF(MPC_OUT0_CSC_C11_C12_A, MPC_OCSC_C11_A, mask_sh),\
-       SF(MPC_OUT0_CSC_C11_C12_A, MPC_OCSC_C12_A, mask_sh),\
-       SF(MPCC0_MPCC_STATUS, MPCC_DISABLED, mask_sh),\
-       SF(MPCC0_MPCC_MEM_PWR_CTRL, MPCC_OGAM_MEM_PWR_FORCE, mask_sh),\
-       SF(MPCC0_MPCC_MEM_PWR_CTRL, MPCC_OGAM_MEM_PWR_DIS, mask_sh),\
-       SF(MPCC0_MPCC_MEM_PWR_CTRL, MPCC_OGAM_MEM_PWR_STATE, mask_sh),\
-       SF(MPC_OUT0_DENORM_CONTROL, MPC_OUT_DENORM_MODE, mask_sh),\
-       SF(MPC_OUT0_DENORM_CONTROL, MPC_OUT_DENORM_CLAMP_MAX_R_CR, mask_sh),\
-       SF(MPC_OUT0_DENORM_CONTROL, MPC_OUT_DENORM_CLAMP_MIN_R_CR, mask_sh),\
-       SF(MPC_OUT0_DENORM_CLAMP_G_Y, MPC_OUT_DENORM_CLAMP_MAX_G_Y, mask_sh),\
-       SF(MPC_OUT0_DENORM_CLAMP_G_Y, MPC_OUT_DENORM_CLAMP_MIN_G_Y, mask_sh),\
-       SF(MPC_OUT0_DENORM_CLAMP_B_CB, MPC_OUT_DENORM_CLAMP_MAX_B_CB, mask_sh),\
-       SF(MPC_OUT0_DENORM_CLAMP_B_CB, MPC_OUT_DENORM_CLAMP_MIN_B_CB, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_GAMUT_REMAP_MODE, MPCC_GAMUT_REMAP_MODE, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_GAMUT_REMAP_MODE, MPCC_GAMUT_REMAP_MODE_CURRENT, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_GAMUT_REMAP_COEF_FORMAT, MPCC_GAMUT_REMAP_COEF_FORMAT, mask_sh),\
-       SF(MPCC_OGAM0_MPC_GAMUT_REMAP_C11_C12_A, MPCC_GAMUT_REMAP_C11_A, mask_sh),\
-       SF(MPCC_OGAM0_MPC_GAMUT_REMAP_C11_C12_A, MPCC_GAMUT_REMAP_C12_A, mask_sh),\
-       SF(MPC_DWB0_MUX, MPC_DWB0_MUX, mask_sh),\
-       SF(MPC_DWB0_MUX, MPC_DWB0_MUX_STATUS, mask_sh),\
-       SF(MPC_OUT0_MUX, MPC_OUT_RATE_CONTROL, mask_sh),\
-       SF(MPC_OUT0_MUX, MPC_OUT_RATE_CONTROL_DISABLE, mask_sh),\
-       SF(MPC_OUT0_MUX, MPC_OUT_FLOW_CONTROL_MODE, mask_sh),\
-       SF(MPC_OUT0_MUX, MPC_OUT_FLOW_CONTROL_COUNT, mask_sh), \
-       SF(MPC_RMU_CONTROL, MPC_RMU0_MUX, mask_sh), \
-       SF(MPC_RMU_CONTROL, MPC_RMU1_MUX, mask_sh), \
-       SF(MPC_RMU_CONTROL, MPC_RMU0_MUX_STATUS, mask_sh), \
-       SF(MPC_RMU_CONTROL, MPC_RMU1_MUX_STATUS, mask_sh), \
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_REGION_0_1, MPCC_OGAM_RAMA_EXP_REGION0_LUT_OFFSET, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_REGION_0_1, MPCC_OGAM_RAMA_EXP_REGION0_NUM_SEGMENTS, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_REGION_0_1, MPCC_OGAM_RAMA_EXP_REGION1_LUT_OFFSET, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_REGION_0_1, MPCC_OGAM_RAMA_EXP_REGION1_NUM_SEGMENTS, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_END_CNTL2_B, MPCC_OGAM_RAMA_EXP_REGION_END_SLOPE_B, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_END_CNTL2_B, MPCC_OGAM_RAMA_EXP_REGION_END_B, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_END_CNTL1_B, MPCC_OGAM_RAMA_EXP_REGION_END_BASE_B, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_START_SLOPE_CNTL_B, MPCC_OGAM_RAMA_EXP_REGION_START_SLOPE_B, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_START_BASE_CNTL_B, MPCC_OGAM_RAMA_EXP_REGION_START_BASE_B, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_START_CNTL_B, MPCC_OGAM_RAMA_EXP_REGION_START_B, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_START_CNTL_B, MPCC_OGAM_RAMA_EXP_REGION_START_SEGMENT_B, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_OFFSET_B, MPCC_OGAM_RAMA_OFFSET_B, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_OFFSET_G, MPCC_OGAM_RAMA_OFFSET_G, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_OFFSET_R, MPCC_OGAM_RAMA_OFFSET_R, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_LUT_INDEX, MPCC_OGAM_LUT_INDEX, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_CONTROL, MPCC_OGAM_MODE, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_CONTROL, MPCC_OGAM_SELECT, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_CONTROL, MPCC_OGAM_PWL_DISABLE, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_CONTROL, MPCC_OGAM_MODE_CURRENT, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_CONTROL, MPCC_OGAM_SELECT_CURRENT, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_LUT_CONTROL, MPCC_OGAM_LUT_WRITE_COLOR_MASK, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_LUT_CONTROL, MPCC_OGAM_LUT_READ_COLOR_SEL, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_LUT_CONTROL, MPCC_OGAM_LUT_READ_DBG, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_LUT_CONTROL, MPCC_OGAM_LUT_HOST_SEL, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_LUT_CONTROL, MPCC_OGAM_LUT_CONFIG_MODE, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_LUT_CONTROL, MPCC_OGAM_LUT_STATUS, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_LUT_DATA, MPCC_OGAM_LUT_DATA, mask_sh),\
-       SF(MPC_RMU0_3DLUT_MODE, MPC_RMU_3DLUT_MODE, mask_sh),\
-       SF(MPC_RMU0_3DLUT_MODE, MPC_RMU_3DLUT_SIZE, mask_sh),\
-       SF(MPC_RMU0_3DLUT_MODE, MPC_RMU_3DLUT_MODE_CURRENT, mask_sh),\
-       SF(MPC_RMU0_3DLUT_READ_WRITE_CONTROL, MPC_RMU_3DLUT_WRITE_EN_MASK, mask_sh),\
-       SF(MPC_RMU0_3DLUT_READ_WRITE_CONTROL, MPC_RMU_3DLUT_RAM_SEL, mask_sh),\
-       SF(MPC_RMU0_3DLUT_READ_WRITE_CONTROL, MPC_RMU_3DLUT_30BIT_EN, mask_sh),\
-       SF(MPC_RMU0_3DLUT_READ_WRITE_CONTROL, MPC_RMU_3DLUT_CONFIG_STATUS, mask_sh),\
-       SF(MPC_RMU0_3DLUT_READ_WRITE_CONTROL, MPC_RMU_3DLUT_READ_SEL, mask_sh),\
-       SF(MPC_RMU0_3DLUT_INDEX, MPC_RMU_3DLUT_INDEX, mask_sh),\
-       SF(MPC_RMU0_3DLUT_DATA, MPC_RMU_3DLUT_DATA0, mask_sh),\
-       SF(MPC_RMU0_3DLUT_DATA, MPC_RMU_3DLUT_DATA1, mask_sh),\
-       SF(MPC_RMU0_3DLUT_DATA_30BIT, MPC_RMU_3DLUT_DATA_30BIT, mask_sh),\
-       SF(MPC_RMU0_SHAPER_CONTROL, MPC_RMU_SHAPER_LUT_MODE, mask_sh),\
-       SF(MPC_RMU0_SHAPER_CONTROL, MPC_RMU_SHAPER_LUT_MODE_CURRENT, mask_sh),\
-       SF(MPC_RMU0_SHAPER_OFFSET_R, MPC_RMU_SHAPER_OFFSET_R, mask_sh),\
-       SF(MPC_RMU0_SHAPER_OFFSET_G, MPC_RMU_SHAPER_OFFSET_G, mask_sh),\
-       SF(MPC_RMU0_SHAPER_OFFSET_B, MPC_RMU_SHAPER_OFFSET_B, mask_sh),\
-       SF(MPC_RMU0_SHAPER_SCALE_R, MPC_RMU_SHAPER_SCALE_R, mask_sh),\
-       SF(MPC_RMU0_SHAPER_SCALE_G_B, MPC_RMU_SHAPER_SCALE_G, mask_sh),\
-       SF(MPC_RMU0_SHAPER_SCALE_G_B, MPC_RMU_SHAPER_SCALE_B, mask_sh),\
-       SF(MPC_RMU0_SHAPER_LUT_INDEX, MPC_RMU_SHAPER_LUT_INDEX, mask_sh),\
-       SF(MPC_RMU0_SHAPER_LUT_DATA, MPC_RMU_SHAPER_LUT_DATA, mask_sh),\
-       SF(MPC_RMU0_SHAPER_LUT_WRITE_EN_MASK, MPC_RMU_SHAPER_LUT_WRITE_EN_MASK, mask_sh),\
-       SF(MPC_RMU0_SHAPER_LUT_WRITE_EN_MASK, MPC_RMU_SHAPER_LUT_WRITE_SEL, mask_sh),\
-       SF(MPC_RMU0_SHAPER_LUT_WRITE_EN_MASK, MPC_RMU_SHAPER_CONFIG_STATUS, mask_sh),\
-       SF(MPC_RMU0_SHAPER_RAMA_START_CNTL_B, MPC_RMU_SHAPER_RAMA_EXP_REGION_START_B, mask_sh),\
-       SF(MPC_RMU0_SHAPER_RAMA_START_CNTL_B, MPC_RMU_SHAPER_RAMA_EXP_REGION_START_SEGMENT_B, mask_sh),\
-       SF(MPC_RMU0_SHAPER_RAMA_END_CNTL_B, MPC_RMU_SHAPER_RAMA_EXP_REGION_END_B, mask_sh),\
-       SF(MPC_RMU0_SHAPER_RAMA_END_CNTL_B, MPC_RMU_SHAPER_RAMA_EXP_REGION_END_BASE_B, mask_sh),\
-       SF(MPC_RMU0_SHAPER_RAMA_REGION_0_1, MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, mask_sh),\
-       SF(MPC_RMU0_SHAPER_RAMA_REGION_0_1, MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, mask_sh),\
-       SF(MPC_RMU0_SHAPER_RAMA_REGION_0_1, MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, mask_sh),\
-       SF(MPC_RMU0_SHAPER_RAMA_REGION_0_1, MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, mask_sh),\
-       SF(MPC_RMU_MEM_PWR_CTRL, MPC_RMU0_MEM_PWR_FORCE, mask_sh),\
-       SF(MPC_RMU_MEM_PWR_CTRL, MPC_RMU0_MEM_PWR_DIS, mask_sh),\
-       SF(MPC_RMU_MEM_PWR_CTRL, MPC_RMU0_SHAPER_MEM_PWR_STATE, mask_sh),\
-       SF(MPC_RMU_MEM_PWR_CTRL, MPC_RMU0_3DLUT_MEM_PWR_STATE, mask_sh),\
-       SF(MPC_RMU_MEM_PWR_CTRL, MPC_RMU1_MEM_PWR_FORCE, mask_sh),\
-       SF(MPC_RMU_MEM_PWR_CTRL, MPC_RMU1_MEM_PWR_DIS, mask_sh),\
-       SF(MPC_RMU_MEM_PWR_CTRL, MPC_RMU1_SHAPER_MEM_PWR_STATE, mask_sh),\
-       SF(MPC_RMU_MEM_PWR_CTRL, MPC_RMU1_3DLUT_MEM_PWR_STATE, mask_sh),\
-       SF(CUR_VUPDATE_LOCK_SET0, CUR_VUPDATE_LOCK_SET, mask_sh)
-
-
-#define MPC_COMMON_MASK_SH_LIST_DCN30(mask_sh) \
-       MPC_COMMON_MASK_SH_LIST_DCN1_0(mask_sh),\
-       SF(MPCC0_MPCC_CONTROL, MPCC_BG_BPC, mask_sh),\
-       SF(MPCC0_MPCC_CONTROL, MPCC_BOT_GAIN_MODE, mask_sh),\
-       SF(MPCC0_MPCC_TOP_GAIN, MPCC_TOP_GAIN, mask_sh),\
-       SF(MPCC0_MPCC_BOT_GAIN_INSIDE, MPCC_BOT_GAIN_INSIDE, mask_sh),\
-       SF(MPCC0_MPCC_BOT_GAIN_OUTSIDE, MPCC_BOT_GAIN_OUTSIDE, mask_sh),\
-       SF(MPC_OUT0_CSC_MODE, MPC_OCSC_MODE, mask_sh),\
-       SF(MPC_OUT0_CSC_C11_C12_A, MPC_OCSC_C11_A, mask_sh),\
-       SF(MPC_OUT0_CSC_C11_C12_A, MPC_OCSC_C12_A, mask_sh),\
-       SF(MPCC0_MPCC_STATUS, MPCC_DISABLED, mask_sh),\
-       SF(MPCC0_MPCC_MEM_PWR_CTRL, MPCC_OGAM_MEM_PWR_FORCE, mask_sh),\
-       SF(MPCC0_MPCC_MEM_PWR_CTRL, MPCC_OGAM_MEM_PWR_DIS, mask_sh),\
-       SF(MPCC0_MPCC_MEM_PWR_CTRL, MPCC_OGAM_MEM_LOW_PWR_MODE, mask_sh),\
-       SF(MPCC0_MPCC_MEM_PWR_CTRL, MPCC_OGAM_MEM_PWR_STATE, mask_sh),\
-       SF(MPC_OUT0_DENORM_CONTROL, MPC_OUT_DENORM_MODE, mask_sh),\
-       SF(MPC_OUT0_DENORM_CONTROL, MPC_OUT_DENORM_CLAMP_MAX_R_CR, mask_sh),\
-       SF(MPC_OUT0_DENORM_CONTROL, MPC_OUT_DENORM_CLAMP_MIN_R_CR, mask_sh),\
-       SF(MPC_OUT0_DENORM_CLAMP_G_Y, MPC_OUT_DENORM_CLAMP_MAX_G_Y, mask_sh),\
-       SF(MPC_OUT0_DENORM_CLAMP_G_Y, MPC_OUT_DENORM_CLAMP_MIN_G_Y, mask_sh),\
-       SF(MPC_OUT0_DENORM_CLAMP_B_CB, MPC_OUT_DENORM_CLAMP_MAX_B_CB, mask_sh),\
-       SF(MPC_OUT0_DENORM_CLAMP_B_CB, MPC_OUT_DENORM_CLAMP_MIN_B_CB, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_GAMUT_REMAP_MODE, MPCC_GAMUT_REMAP_MODE, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_GAMUT_REMAP_MODE, MPCC_GAMUT_REMAP_MODE_CURRENT, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_GAMUT_REMAP_COEF_FORMAT, MPCC_GAMUT_REMAP_COEF_FORMAT, mask_sh),\
-       SF(MPCC_OGAM0_MPC_GAMUT_REMAP_C11_C12_A, MPCC_GAMUT_REMAP_C11_A, mask_sh),\
-       SF(MPCC_OGAM0_MPC_GAMUT_REMAP_C11_C12_A, MPCC_GAMUT_REMAP_C12_A, mask_sh),\
-       SF(MPC_DWB0_MUX, MPC_DWB0_MUX, mask_sh),\
-       SF(MPC_DWB0_MUX, MPC_DWB0_MUX_STATUS, mask_sh),\
-       SF(MPC_OUT0_MUX, MPC_OUT_RATE_CONTROL, mask_sh),\
-       SF(MPC_OUT0_MUX, MPC_OUT_RATE_CONTROL_DISABLE, mask_sh),\
-       SF(MPC_OUT0_MUX, MPC_OUT_FLOW_CONTROL_MODE, mask_sh),\
-       SF(MPC_OUT0_MUX, MPC_OUT_FLOW_CONTROL_COUNT, mask_sh), \
-       SF(MPC_RMU_CONTROL, MPC_RMU0_MUX, mask_sh), \
-       SF(MPC_RMU_CONTROL, MPC_RMU1_MUX, mask_sh), \
-       SF(MPC_RMU_CONTROL, MPC_RMU0_MUX_STATUS, mask_sh), \
-       SF(MPC_RMU_CONTROL, MPC_RMU1_MUX_STATUS, mask_sh), \
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_REGION_0_1, MPCC_OGAM_RAMA_EXP_REGION0_LUT_OFFSET, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_REGION_0_1, MPCC_OGAM_RAMA_EXP_REGION0_NUM_SEGMENTS, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_REGION_0_1, MPCC_OGAM_RAMA_EXP_REGION1_LUT_OFFSET, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_REGION_0_1, MPCC_OGAM_RAMA_EXP_REGION1_NUM_SEGMENTS, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_END_CNTL2_B, MPCC_OGAM_RAMA_EXP_REGION_END_SLOPE_B, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_END_CNTL2_B, MPCC_OGAM_RAMA_EXP_REGION_END_B, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_END_CNTL1_B, MPCC_OGAM_RAMA_EXP_REGION_END_BASE_B, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_START_SLOPE_CNTL_B, MPCC_OGAM_RAMA_EXP_REGION_START_SLOPE_B, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_START_BASE_CNTL_B, MPCC_OGAM_RAMA_EXP_REGION_START_BASE_B, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_START_CNTL_B, MPCC_OGAM_RAMA_EXP_REGION_START_B, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_START_CNTL_B, MPCC_OGAM_RAMA_EXP_REGION_START_SEGMENT_B, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_OFFSET_B, MPCC_OGAM_RAMA_OFFSET_B, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_OFFSET_G, MPCC_OGAM_RAMA_OFFSET_G, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_OFFSET_R, MPCC_OGAM_RAMA_OFFSET_R, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_LUT_INDEX, MPCC_OGAM_LUT_INDEX, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_CONTROL, MPCC_OGAM_MODE, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_CONTROL, MPCC_OGAM_SELECT, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_CONTROL, MPCC_OGAM_PWL_DISABLE, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_CONTROL, MPCC_OGAM_MODE_CURRENT, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_CONTROL, MPCC_OGAM_SELECT_CURRENT, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_LUT_CONTROL, MPCC_OGAM_LUT_WRITE_COLOR_MASK, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_LUT_CONTROL, MPCC_OGAM_LUT_READ_COLOR_SEL, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_LUT_CONTROL, MPCC_OGAM_LUT_READ_DBG, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_LUT_CONTROL, MPCC_OGAM_LUT_HOST_SEL, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_LUT_CONTROL, MPCC_OGAM_LUT_CONFIG_MODE, mask_sh),\
-       /*SF(MPCC_OGAM0_MPCC_OGAM_LUT_CONTROL, MPCC_OGAM_LUT_STATUS, mask_sh),*/\
-       SF(MPCC_OGAM0_MPCC_OGAM_LUT_DATA, MPCC_OGAM_LUT_DATA, mask_sh),\
-       SF(MPC_RMU0_3DLUT_MODE, MPC_RMU_3DLUT_MODE, mask_sh),\
-       SF(MPC_RMU0_3DLUT_MODE, MPC_RMU_3DLUT_SIZE, mask_sh),\
-       /*SF(MPC_RMU0_3DLUT_MODE, MPC_RMU_3DLUT_MODE_CURRENT, mask_sh),*/\
-       SF(MPC_RMU0_3DLUT_READ_WRITE_CONTROL, MPC_RMU_3DLUT_WRITE_EN_MASK, mask_sh),\
-       SF(MPC_RMU0_3DLUT_READ_WRITE_CONTROL, MPC_RMU_3DLUT_RAM_SEL, mask_sh),\
-       SF(MPC_RMU0_3DLUT_READ_WRITE_CONTROL, MPC_RMU_3DLUT_30BIT_EN, mask_sh),\
-       /*SF(MPC_RMU0_3DLUT_READ_WRITE_CONTROL, MPC_RMU_3DLUT_CONFIG_STATUS, mask_sh),*/\
-       SF(MPC_RMU0_3DLUT_READ_WRITE_CONTROL, MPC_RMU_3DLUT_READ_SEL, mask_sh),\
-       SF(MPC_RMU0_3DLUT_INDEX, MPC_RMU_3DLUT_INDEX, mask_sh),\
-       SF(MPC_RMU0_3DLUT_DATA, MPC_RMU_3DLUT_DATA0, mask_sh),\
-       SF(MPC_RMU0_3DLUT_DATA, MPC_RMU_3DLUT_DATA1, mask_sh),\
-       SF(MPC_RMU0_3DLUT_DATA_30BIT, MPC_RMU_3DLUT_DATA_30BIT, mask_sh),\
-       SF(MPC_RMU0_SHAPER_CONTROL, MPC_RMU_SHAPER_LUT_MODE, mask_sh),\
-       /*SF(MPC_RMU0_SHAPER_CONTROL, MPC_RMU_SHAPER_LUT_MODE_CURRENT, mask_sh),*/\
-       SF(MPC_RMU0_SHAPER_OFFSET_R, MPC_RMU_SHAPER_OFFSET_R, mask_sh),\
-       SF(MPC_RMU0_SHAPER_OFFSET_G, MPC_RMU_SHAPER_OFFSET_G, mask_sh),\
-       SF(MPC_RMU0_SHAPER_OFFSET_B, MPC_RMU_SHAPER_OFFSET_B, mask_sh),\
-       SF(MPC_RMU0_SHAPER_SCALE_R, MPC_RMU_SHAPER_SCALE_R, mask_sh),\
-       SF(MPC_RMU0_SHAPER_SCALE_G_B, MPC_RMU_SHAPER_SCALE_G, mask_sh),\
-       SF(MPC_RMU0_SHAPER_SCALE_G_B, MPC_RMU_SHAPER_SCALE_B, mask_sh),\
-       SF(MPC_RMU0_SHAPER_LUT_INDEX, MPC_RMU_SHAPER_LUT_INDEX, mask_sh),\
-       SF(MPC_RMU0_SHAPER_LUT_DATA, MPC_RMU_SHAPER_LUT_DATA, mask_sh),\
-       SF(MPC_RMU0_SHAPER_LUT_WRITE_EN_MASK, MPC_RMU_SHAPER_LUT_WRITE_EN_MASK, mask_sh),\
-       SF(MPC_RMU0_SHAPER_LUT_WRITE_EN_MASK, MPC_RMU_SHAPER_LUT_WRITE_SEL, mask_sh),\
-       /*SF(MPC_RMU0_SHAPER_LUT_WRITE_EN_MASK, MPC_RMU_SHAPER_CONFIG_STATUS, mask_sh),*/\
-       SF(MPC_RMU0_SHAPER_RAMA_START_CNTL_B, MPC_RMU_SHAPER_RAMA_EXP_REGION_START_B, mask_sh),\
-       SF(MPC_RMU0_SHAPER_RAMA_START_CNTL_B, MPC_RMU_SHAPER_RAMA_EXP_REGION_START_SEGMENT_B, mask_sh),\
-       SF(MPC_RMU0_SHAPER_RAMA_END_CNTL_B, MPC_RMU_SHAPER_RAMA_EXP_REGION_END_B, mask_sh),\
-       SF(MPC_RMU0_SHAPER_RAMA_END_CNTL_B, MPC_RMU_SHAPER_RAMA_EXP_REGION_END_BASE_B, mask_sh),\
-       SF(MPC_RMU0_SHAPER_RAMA_REGION_0_1, MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, mask_sh),\
-       SF(MPC_RMU0_SHAPER_RAMA_REGION_0_1, MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, mask_sh),\
-       SF(MPC_RMU0_SHAPER_RAMA_REGION_0_1, MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, mask_sh),\
-       SF(MPC_RMU0_SHAPER_RAMA_REGION_0_1, MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, mask_sh),\
-       SF(MPC_RMU_MEM_PWR_CTRL, MPC_RMU0_MEM_PWR_FORCE, mask_sh),\
-       SF(MPC_RMU_MEM_PWR_CTRL, MPC_RMU0_MEM_PWR_DIS, mask_sh),\
-       SF(MPC_RMU_MEM_PWR_CTRL, MPC_RMU0_SHAPER_MEM_PWR_STATE, mask_sh),\
-       SF(MPC_RMU_MEM_PWR_CTRL, MPC_RMU0_3DLUT_MEM_PWR_STATE, mask_sh),\
-       SF(MPC_RMU_MEM_PWR_CTRL, MPC_RMU0_MEM_LOW_PWR_MODE, mask_sh),\
-       SF(MPC_RMU_MEM_PWR_CTRL, MPC_RMU1_MEM_PWR_FORCE, mask_sh),\
-       SF(MPC_RMU_MEM_PWR_CTRL, MPC_RMU1_MEM_PWR_DIS, mask_sh),\
-       SF(MPC_RMU_MEM_PWR_CTRL, MPC_RMU1_SHAPER_MEM_PWR_STATE, mask_sh),\
-       SF(MPC_RMU_MEM_PWR_CTRL, MPC_RMU1_3DLUT_MEM_PWR_STATE, mask_sh),\
-       SF(MPC_RMU_MEM_PWR_CTRL, MPC_RMU1_MEM_LOW_PWR_MODE, mask_sh),\
-       SF(MPC_RMU0_SHAPER_CONTROL, MPC_RMU_SHAPER_MODE_CURRENT, mask_sh),\
-       SF(CUR_VUPDATE_LOCK_SET0, CUR_VUPDATE_LOCK_SET, mask_sh)
-
-
-#define MPC_REG_FIELD_LIST_DCN3_0(type) \
-       MPC_REG_FIELD_LIST_DCN2_0(type) \
-       type MPC_DWB0_MUX;\
-       type MPC_DWB0_MUX_STATUS;\
-       type MPC_OUT_RATE_CONTROL;\
-       type MPC_OUT_RATE_CONTROL_DISABLE;\
-       type MPC_OUT_FLOW_CONTROL_MODE;\
-       type MPC_OUT_FLOW_CONTROL_COUNT; \
-       type MPCC_GAMUT_REMAP_MODE; \
-       type MPCC_GAMUT_REMAP_MODE_CURRENT;\
-       type MPCC_GAMUT_REMAP_COEF_FORMAT; \
-       type MPCC_GAMUT_REMAP_C11_A; \
-       type MPCC_GAMUT_REMAP_C12_A; \
-       type MPC_RMU0_MUX; \
-       type MPC_RMU1_MUX; \
-       type MPC_RMU0_MUX_STATUS; \
-       type MPC_RMU1_MUX_STATUS; \
-       type MPC_RMU0_MEM_PWR_FORCE;\
-       type MPC_RMU0_MEM_PWR_DIS;\
-       type MPC_RMU0_MEM_LOW_PWR_MODE;\
-       type MPC_RMU0_SHAPER_MEM_PWR_STATE;\
-       type MPC_RMU0_3DLUT_MEM_PWR_STATE;\
-       type MPC_RMU1_MEM_PWR_FORCE;\
-       type MPC_RMU1_MEM_PWR_DIS;\
-       type MPC_RMU1_MEM_LOW_PWR_MODE;\
-       type MPC_RMU1_SHAPER_MEM_PWR_STATE;\
-       type MPC_RMU1_3DLUT_MEM_PWR_STATE;\
-       type MPCC_OGAM_RAMA_EXP_REGION_START_SLOPE_B; \
-       type MPCC_OGAM_RAMA_EXP_REGION_START_BASE_B;\
-       type MPCC_OGAM_RAMA_OFFSET_B;\
-       type MPCC_OGAM_RAMA_OFFSET_G;\
-       type MPCC_OGAM_RAMA_OFFSET_R;\
-       type MPCC_OGAM_SELECT; \
-       type MPCC_OGAM_PWL_DISABLE; \
-       type MPCC_OGAM_MODE_CURRENT; \
-       type MPCC_OGAM_SELECT_CURRENT; \
-       type MPCC_OGAM_LUT_WRITE_COLOR_MASK; \
-       type MPCC_OGAM_LUT_READ_COLOR_SEL; \
-       type MPCC_OGAM_LUT_READ_DBG; \
-       type MPCC_OGAM_LUT_HOST_SEL; \
-       type MPCC_OGAM_LUT_CONFIG_MODE; \
-       type MPCC_OGAM_LUT_STATUS; \
-       type MPCC_OGAM_RAMA_START_BASE_CNTL_B;\
-       type MPCC_OGAM_MEM_LOW_PWR_MODE;\
-       type MPCC_OGAM_MEM_PWR_STATE;\
-       type MPC_RMU_3DLUT_MODE; \
-       type MPC_RMU_3DLUT_SIZE; \
-       type MPC_RMU_3DLUT_MODE_CURRENT; \
-       type MPC_RMU_3DLUT_WRITE_EN_MASK;\
-       type MPC_RMU_3DLUT_RAM_SEL;\
-       type MPC_RMU_3DLUT_30BIT_EN;\
-       type MPC_RMU_3DLUT_CONFIG_STATUS;\
-       type MPC_RMU_3DLUT_READ_SEL;\
-       type MPC_RMU_3DLUT_INDEX;\
-       type MPC_RMU_3DLUT_DATA0;\
-       type MPC_RMU_3DLUT_DATA1;\
-       type MPC_RMU_3DLUT_DATA_30BIT;\
-       type MPC_RMU_SHAPER_LUT_MODE;\
-       type MPC_RMU_SHAPER_LUT_MODE_CURRENT;\
-       type MPC_RMU_SHAPER_OFFSET_R;\
-       type MPC_RMU_SHAPER_OFFSET_G;\
-       type MPC_RMU_SHAPER_OFFSET_B;\
-       type MPC_RMU_SHAPER_SCALE_R;\
-       type MPC_RMU_SHAPER_SCALE_G;\
-       type MPC_RMU_SHAPER_SCALE_B;\
-       type MPC_RMU_SHAPER_LUT_INDEX;\
-       type MPC_RMU_SHAPER_LUT_DATA;\
-       type MPC_RMU_SHAPER_LUT_WRITE_EN_MASK;\
-       type MPC_RMU_SHAPER_LUT_WRITE_SEL;\
-       type MPC_RMU_SHAPER_CONFIG_STATUS;\
-       type MPC_RMU_SHAPER_RAMA_EXP_REGION_START_B;\
-       type MPC_RMU_SHAPER_RAMA_EXP_REGION_START_SEGMENT_B;\
-       type MPC_RMU_SHAPER_RAMA_EXP_REGION_END_B;\
-       type MPC_RMU_SHAPER_RAMA_EXP_REGION_END_BASE_B;\
-       type MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET;\
-       type MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS;\
-       type MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET;\
-       type MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS;\
-       type MPC_RMU_SHAPER_MODE_CURRENT
-
-#define MPC_REG_FIELD_LIST_DCN32(type) \
-       type MPCC_MOVABLE_CM_LOCATION_CNTL;\
-       type MPCC_MOVABLE_CM_LOCATION_CNTL_CURRENT;\
-       type MPCC_MCM_SHAPER_MEM_PWR_FORCE;\
-       type MPCC_MCM_SHAPER_MEM_PWR_DIS;\
-       type MPCC_MCM_SHAPER_MEM_LOW_PWR_MODE;\
-       type MPCC_MCM_3DLUT_MEM_PWR_FORCE;\
-       type MPCC_MCM_3DLUT_MEM_PWR_DIS;\
-       type MPCC_MCM_3DLUT_MEM_LOW_PWR_MODE;\
-       type MPCC_MCM_1DLUT_MEM_PWR_FORCE;\
-       type MPCC_MCM_1DLUT_MEM_PWR_DIS;\
-       type MPCC_MCM_1DLUT_MEM_LOW_PWR_MODE;\
-       type MPCC_MCM_SHAPER_MEM_PWR_STATE;\
-       type MPCC_MCM_3DLUT_MEM_PWR_STATE;\
-       type MPCC_MCM_1DLUT_MEM_PWR_STATE;\
-       type MPCC_MCM_3DLUT_MODE; \
-       type MPCC_MCM_3DLUT_SIZE; \
-       type MPCC_MCM_3DLUT_MODE_CURRENT; \
-       type MPCC_MCM_3DLUT_WRITE_EN_MASK;\
-       type MPCC_MCM_3DLUT_RAM_SEL;\
-       type MPCC_MCM_3DLUT_30BIT_EN;\
-       type MPCC_MCM_3DLUT_CONFIG_STATUS;\
-       type MPCC_MCM_3DLUT_READ_SEL;\
-       type MPCC_MCM_3DLUT_INDEX;\
-       type MPCC_MCM_3DLUT_DATA0;\
-       type MPCC_MCM_3DLUT_DATA1;\
-       type MPCC_MCM_3DLUT_DATA_30BIT;\
-       type MPCC_MCM_SHAPER_LUT_MODE;\
-       type MPCC_MCM_SHAPER_MODE_CURRENT;\
-       type MPCC_MCM_SHAPER_OFFSET_R;\
-       type MPCC_MCM_SHAPER_OFFSET_G;\
-       type MPCC_MCM_SHAPER_OFFSET_B;\
-       type MPCC_MCM_SHAPER_SCALE_R;\
-       type MPCC_MCM_SHAPER_SCALE_G;\
-       type MPCC_MCM_SHAPER_SCALE_B;\
-       type MPCC_MCM_SHAPER_LUT_INDEX;\
-       type MPCC_MCM_SHAPER_LUT_DATA;\
-       type MPCC_MCM_SHAPER_LUT_WRITE_EN_MASK;\
-       type MPCC_MCM_SHAPER_LUT_WRITE_SEL;\
-       type MPCC_MCM_SHAPER_CONFIG_STATUS;\
-       type MPCC_MCM_SHAPER_RAMA_EXP_REGION_START_B;\
-       type MPCC_MCM_SHAPER_RAMA_EXP_REGION_START_SEGMENT_B;\
-       type MPCC_MCM_SHAPER_RAMA_EXP_REGION_END_B;\
-       type MPCC_MCM_SHAPER_RAMA_EXP_REGION_END_BASE_B;\
-       type MPCC_MCM_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET;\
-       type MPCC_MCM_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS;\
-       type MPCC_MCM_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET;\
-       type MPCC_MCM_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS; \
-       type MPCC_MCM_1DLUT_MODE;\
-       type MPCC_MCM_1DLUT_SELECT;\
-       type MPCC_MCM_1DLUT_PWL_DISABLE;\
-       type MPCC_MCM_1DLUT_MODE_CURRENT;\
-       type MPCC_MCM_1DLUT_SELECT_CURRENT;\
-       type MPCC_MCM_1DLUT_LUT_INDEX;\
-       type MPCC_MCM_1DLUT_LUT_DATA;\
-       type MPCC_MCM_1DLUT_LUT_WRITE_COLOR_MASK;\
-       type MPCC_MCM_1DLUT_LUT_READ_COLOR_SEL;\
-       type MPCC_MCM_1DLUT_LUT_HOST_SEL;\
-       type MPCC_MCM_1DLUT_LUT_CONFIG_MODE;\
-       type MPCC_MCM_1DLUT_RAMA_EXP_REGION_START_B;\
-       type MPCC_MCM_1DLUT_RAMA_EXP_REGION_START_SEGMENT_B;\
-       type MPCC_MCM_1DLUT_RAMA_EXP_REGION_START_SLOPE_B;\
-       type MPCC_MCM_1DLUT_RAMA_EXP_REGION_START_BASE_B;\
-       type MPCC_MCM_1DLUT_RAMA_EXP_REGION_END_BASE_B;\
-       type MPCC_MCM_1DLUT_RAMA_EXP_REGION_END_B;\
-       type MPCC_MCM_1DLUT_RAMA_EXP_REGION_END_SLOPE_B;\
-       type MPCC_MCM_1DLUT_RAMA_OFFSET_B;\
-       type MPCC_MCM_1DLUT_RAMA_OFFSET_G;\
-       type MPCC_MCM_1DLUT_RAMA_OFFSET_R;\
-       type MPCC_MCM_1DLUT_RAMA_EXP_REGION0_LUT_OFFSET;\
-       type MPCC_MCM_1DLUT_RAMA_EXP_REGION0_NUM_SEGMENTS;\
-       type MPCC_MCM_1DLUT_RAMA_EXP_REGION1_LUT_OFFSET;\
-       type MPCC_MCM_1DLUT_RAMA_EXP_REGION1_NUM_SEGMENTS
-
-
-#define MPC_COMMON_MASK_SH_LIST_DCN303(mask_sh) \
-       MPC_COMMON_MASK_SH_LIST_DCN1_0(mask_sh),\
-       SF(MPCC0_MPCC_CONTROL, MPCC_BG_BPC, mask_sh),\
-       SF(MPCC0_MPCC_CONTROL, MPCC_BOT_GAIN_MODE, mask_sh),\
-       SF(MPCC0_MPCC_TOP_GAIN, MPCC_TOP_GAIN, mask_sh),\
-       SF(MPCC0_MPCC_BOT_GAIN_INSIDE, MPCC_BOT_GAIN_INSIDE, mask_sh),\
-       SF(MPCC0_MPCC_BOT_GAIN_OUTSIDE, MPCC_BOT_GAIN_OUTSIDE, mask_sh),\
-       SF(MPC_OUT0_CSC_MODE, MPC_OCSC_MODE, mask_sh),\
-       SF(MPC_OUT0_CSC_C11_C12_A, MPC_OCSC_C11_A, mask_sh),\
-       SF(MPC_OUT0_CSC_C11_C12_A, MPC_OCSC_C12_A, mask_sh),\
-       SF(MPCC0_MPCC_STATUS, MPCC_DISABLED, mask_sh),\
-       SF(MPCC0_MPCC_MEM_PWR_CTRL, MPCC_OGAM_MEM_PWR_FORCE, mask_sh),\
-       SF(MPCC0_MPCC_MEM_PWR_CTRL, MPCC_OGAM_MEM_PWR_DIS, mask_sh),\
-       SF(MPCC0_MPCC_MEM_PWR_CTRL, MPCC_OGAM_MEM_LOW_PWR_MODE, mask_sh),\
-       SF(MPCC0_MPCC_MEM_PWR_CTRL, MPCC_OGAM_MEM_PWR_STATE, mask_sh),\
-       SF(MPC_OUT0_DENORM_CONTROL, MPC_OUT_DENORM_MODE, mask_sh),\
-       SF(MPC_OUT0_DENORM_CONTROL, MPC_OUT_DENORM_CLAMP_MAX_R_CR, mask_sh),\
-       SF(MPC_OUT0_DENORM_CONTROL, MPC_OUT_DENORM_CLAMP_MIN_R_CR, mask_sh),\
-       SF(MPC_OUT0_DENORM_CLAMP_G_Y, MPC_OUT_DENORM_CLAMP_MAX_G_Y, mask_sh),\
-       SF(MPC_OUT0_DENORM_CLAMP_G_Y, MPC_OUT_DENORM_CLAMP_MIN_G_Y, mask_sh),\
-       SF(MPC_OUT0_DENORM_CLAMP_B_CB, MPC_OUT_DENORM_CLAMP_MAX_B_CB, mask_sh),\
-       SF(MPC_OUT0_DENORM_CLAMP_B_CB, MPC_OUT_DENORM_CLAMP_MIN_B_CB, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_GAMUT_REMAP_MODE, MPCC_GAMUT_REMAP_MODE, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_GAMUT_REMAP_MODE, MPCC_GAMUT_REMAP_MODE_CURRENT, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_GAMUT_REMAP_COEF_FORMAT, MPCC_GAMUT_REMAP_COEF_FORMAT, mask_sh),\
-       SF(MPCC_OGAM0_MPC_GAMUT_REMAP_C11_C12_A, MPCC_GAMUT_REMAP_C11_A, mask_sh),\
-       SF(MPCC_OGAM0_MPC_GAMUT_REMAP_C11_C12_A, MPCC_GAMUT_REMAP_C12_A, mask_sh),\
-       SF(MPC_DWB0_MUX, MPC_DWB0_MUX, mask_sh),\
-       SF(MPC_DWB0_MUX, MPC_DWB0_MUX_STATUS, mask_sh),\
-       SF(MPC_OUT0_MUX, MPC_OUT_RATE_CONTROL, mask_sh),\
-       SF(MPC_OUT0_MUX, MPC_OUT_RATE_CONTROL_DISABLE, mask_sh),\
-       SF(MPC_OUT0_MUX, MPC_OUT_FLOW_CONTROL_MODE, mask_sh),\
-       SF(MPC_OUT0_MUX, MPC_OUT_FLOW_CONTROL_COUNT, mask_sh), \
-       SF(MPC_RMU_CONTROL, MPC_RMU0_MUX, mask_sh), \
-       SF(MPC_RMU_CONTROL, MPC_RMU0_MUX_STATUS, mask_sh), \
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_REGION_0_1, MPCC_OGAM_RAMA_EXP_REGION0_LUT_OFFSET, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_REGION_0_1, MPCC_OGAM_RAMA_EXP_REGION0_NUM_SEGMENTS, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_REGION_0_1, MPCC_OGAM_RAMA_EXP_REGION1_LUT_OFFSET, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_REGION_0_1, MPCC_OGAM_RAMA_EXP_REGION1_NUM_SEGMENTS, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_END_CNTL2_B, MPCC_OGAM_RAMA_EXP_REGION_END_SLOPE_B, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_END_CNTL2_B, MPCC_OGAM_RAMA_EXP_REGION_END_B, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_END_CNTL1_B, MPCC_OGAM_RAMA_EXP_REGION_END_BASE_B, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_START_SLOPE_CNTL_B, MPCC_OGAM_RAMA_EXP_REGION_START_SLOPE_B, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_START_BASE_CNTL_B, MPCC_OGAM_RAMA_EXP_REGION_START_BASE_B, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_START_CNTL_B, MPCC_OGAM_RAMA_EXP_REGION_START_B, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_START_CNTL_B, MPCC_OGAM_RAMA_EXP_REGION_START_SEGMENT_B, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_OFFSET_B, MPCC_OGAM_RAMA_OFFSET_B, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_OFFSET_G, MPCC_OGAM_RAMA_OFFSET_G, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_OFFSET_R, MPCC_OGAM_RAMA_OFFSET_R, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_LUT_INDEX, MPCC_OGAM_LUT_INDEX, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_CONTROL, MPCC_OGAM_MODE, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_CONTROL, MPCC_OGAM_SELECT, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_CONTROL, MPCC_OGAM_PWL_DISABLE, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_CONTROL, MPCC_OGAM_MODE_CURRENT, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_CONTROL, MPCC_OGAM_SELECT_CURRENT, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_LUT_CONTROL, MPCC_OGAM_LUT_WRITE_COLOR_MASK, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_LUT_CONTROL, MPCC_OGAM_LUT_READ_COLOR_SEL, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_LUT_CONTROL, MPCC_OGAM_LUT_READ_DBG, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_LUT_CONTROL, MPCC_OGAM_LUT_HOST_SEL, mask_sh),\
-       SF(MPCC_OGAM0_MPCC_OGAM_LUT_CONTROL, MPCC_OGAM_LUT_CONFIG_MODE, mask_sh),\
-       /*SF(MPCC_OGAM0_MPCC_OGAM_LUT_CONTROL, MPCC_OGAM_LUT_STATUS, mask_sh),*/\
-       SF(MPCC_OGAM0_MPCC_OGAM_LUT_DATA, MPCC_OGAM_LUT_DATA, mask_sh),\
-       SF(MPC_RMU0_3DLUT_MODE, MPC_RMU_3DLUT_MODE, mask_sh),\
-       SF(MPC_RMU0_3DLUT_MODE, MPC_RMU_3DLUT_SIZE, mask_sh),\
-       /*SF(MPC_RMU0_3DLUT_MODE, MPC_RMU_3DLUT_MODE_CURRENT, mask_sh),*/\
-       SF(MPC_RMU0_3DLUT_READ_WRITE_CONTROL, MPC_RMU_3DLUT_WRITE_EN_MASK, mask_sh),\
-       SF(MPC_RMU0_3DLUT_READ_WRITE_CONTROL, MPC_RMU_3DLUT_RAM_SEL, mask_sh),\
-       SF(MPC_RMU0_3DLUT_READ_WRITE_CONTROL, MPC_RMU_3DLUT_30BIT_EN, mask_sh),\
-       /*SF(MPC_RMU0_3DLUT_READ_WRITE_CONTROL, MPC_RMU_3DLUT_CONFIG_STATUS, mask_sh),*/\
-       SF(MPC_RMU0_3DLUT_READ_WRITE_CONTROL, MPC_RMU_3DLUT_READ_SEL, mask_sh),\
-       SF(MPC_RMU0_3DLUT_INDEX, MPC_RMU_3DLUT_INDEX, mask_sh),\
-       SF(MPC_RMU0_3DLUT_DATA, MPC_RMU_3DLUT_DATA0, mask_sh),\
-       SF(MPC_RMU0_3DLUT_DATA, MPC_RMU_3DLUT_DATA1, mask_sh),\
-       SF(MPC_RMU0_3DLUT_DATA_30BIT, MPC_RMU_3DLUT_DATA_30BIT, mask_sh),\
-       SF(MPC_RMU0_SHAPER_CONTROL, MPC_RMU_SHAPER_LUT_MODE, mask_sh),\
-       /*SF(MPC_RMU0_SHAPER_CONTROL, MPC_RMU_SHAPER_LUT_MODE_CURRENT, mask_sh),*/\
-       SF(MPC_RMU0_SHAPER_OFFSET_R, MPC_RMU_SHAPER_OFFSET_R, mask_sh),\
-       SF(MPC_RMU0_SHAPER_OFFSET_G, MPC_RMU_SHAPER_OFFSET_G, mask_sh),\
-       SF(MPC_RMU0_SHAPER_OFFSET_B, MPC_RMU_SHAPER_OFFSET_B, mask_sh),\
-       SF(MPC_RMU0_SHAPER_SCALE_R, MPC_RMU_SHAPER_SCALE_R, mask_sh),\
-       SF(MPC_RMU0_SHAPER_SCALE_G_B, MPC_RMU_SHAPER_SCALE_G, mask_sh),\
-       SF(MPC_RMU0_SHAPER_SCALE_G_B, MPC_RMU_SHAPER_SCALE_B, mask_sh),\
-       SF(MPC_RMU0_SHAPER_LUT_INDEX, MPC_RMU_SHAPER_LUT_INDEX, mask_sh),\
-       SF(MPC_RMU0_SHAPER_LUT_DATA, MPC_RMU_SHAPER_LUT_DATA, mask_sh),\
-       SF(MPC_RMU0_SHAPER_LUT_WRITE_EN_MASK, MPC_RMU_SHAPER_LUT_WRITE_EN_MASK, mask_sh),\
-       SF(MPC_RMU0_SHAPER_LUT_WRITE_EN_MASK, MPC_RMU_SHAPER_LUT_WRITE_SEL, mask_sh),\
-       /*SF(MPC_RMU0_SHAPER_LUT_WRITE_EN_MASK, MPC_RMU_SHAPER_CONFIG_STATUS, mask_sh),*/\
-       SF(MPC_RMU0_SHAPER_RAMA_START_CNTL_B, MPC_RMU_SHAPER_RAMA_EXP_REGION_START_B, mask_sh),\
-       SF(MPC_RMU0_SHAPER_RAMA_START_CNTL_B, MPC_RMU_SHAPER_RAMA_EXP_REGION_START_SEGMENT_B, mask_sh),\
-       SF(MPC_RMU0_SHAPER_RAMA_END_CNTL_B, MPC_RMU_SHAPER_RAMA_EXP_REGION_END_B, mask_sh),\
-       SF(MPC_RMU0_SHAPER_RAMA_END_CNTL_B, MPC_RMU_SHAPER_RAMA_EXP_REGION_END_BASE_B, mask_sh),\
-       SF(MPC_RMU0_SHAPER_RAMA_REGION_0_1, MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, mask_sh),\
-       SF(MPC_RMU0_SHAPER_RAMA_REGION_0_1, MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, mask_sh),\
-       SF(MPC_RMU0_SHAPER_RAMA_REGION_0_1, MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, mask_sh),\
-       SF(MPC_RMU0_SHAPER_RAMA_REGION_0_1, MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, mask_sh),\
-       SF(MPC_RMU_MEM_PWR_CTRL, MPC_RMU0_MEM_PWR_FORCE, mask_sh),\
-       SF(MPC_RMU_MEM_PWR_CTRL, MPC_RMU0_MEM_PWR_DIS, mask_sh),\
-       SF(MPC_RMU_MEM_PWR_CTRL, MPC_RMU0_SHAPER_MEM_PWR_STATE, mask_sh),\
-       SF(MPC_RMU_MEM_PWR_CTRL, MPC_RMU0_3DLUT_MEM_PWR_STATE, mask_sh),\
-       SF(MPC_RMU_MEM_PWR_CTRL, MPC_RMU0_MEM_LOW_PWR_MODE, mask_sh),\
-       SF(MPC_RMU0_SHAPER_CONTROL, MPC_RMU_SHAPER_MODE_CURRENT, mask_sh),\
-       SF(CUR_VUPDATE_LOCK_SET0, CUR_VUPDATE_LOCK_SET, mask_sh)
-
-#define MPC_REG_FIELD_LIST_DCN3_03(type) \
-       MPC_REG_FIELD_LIST_DCN2_0(type) \
-       type MPC_DWB0_MUX;\
-       type MPC_DWB0_MUX_STATUS;\
-       type MPC_OUT_RATE_CONTROL;\
-       type MPC_OUT_RATE_CONTROL_DISABLE;\
-       type MPC_OUT_FLOW_CONTROL_MODE;\
-       type MPC_OUT_FLOW_CONTROL_COUNT; \
-       type MPCC_GAMUT_REMAP_MODE; \
-       type MPCC_GAMUT_REMAP_MODE_CURRENT;\
-       type MPCC_GAMUT_REMAP_COEF_FORMAT; \
-       type MPCC_GAMUT_REMAP_C11_A; \
-       type MPCC_GAMUT_REMAP_C12_A; \
-       type MPC_RMU0_MUX; \
-       type MPC_RMU0_MUX_STATUS; \
-       type MPC_RMU0_MEM_PWR_FORCE;\
-       type MPC_RMU0_MEM_PWR_DIS;\
-       type MPC_RMU0_MEM_LOW_PWR_MODE;\
-       type MPC_RMU0_SHAPER_MEM_PWR_STATE;\
-       type MPC_RMU0_3DLUT_MEM_PWR_STATE;\
-       type MPCC_OGAM_RAMA_EXP_REGION_START_SLOPE_B; \
-       type MPCC_OGAM_RAMA_EXP_REGION_START_BASE_B;\
-       type MPCC_OGAM_RAMA_OFFSET_B;\
-       type MPCC_OGAM_RAMA_OFFSET_G;\
-       type MPCC_OGAM_RAMA_OFFSET_R;\
-       type MPCC_OGAM_SELECT; \
-       type MPCC_OGAM_PWL_DISABLE; \
-       type MPCC_OGAM_MODE_CURRENT; \
-       type MPCC_OGAM_SELECT_CURRENT; \
-       type MPCC_OGAM_LUT_WRITE_COLOR_MASK; \
-       type MPCC_OGAM_LUT_READ_COLOR_SEL; \
-       type MPCC_OGAM_LUT_READ_DBG; \
-       type MPCC_OGAM_LUT_HOST_SEL; \
-       type MPCC_OGAM_LUT_CONFIG_MODE; \
-       type MPCC_OGAM_LUT_STATUS; \
-       type MPCC_OGAM_RAMA_START_BASE_CNTL_B;\
-       type MPCC_OGAM_MEM_LOW_PWR_MODE;\
-       type MPCC_OGAM_MEM_PWR_STATE;\
-       type MPC_RMU_3DLUT_MODE; \
-       type MPC_RMU_3DLUT_SIZE; \
-       type MPC_RMU_3DLUT_MODE_CURRENT; \
-       type MPC_RMU_3DLUT_WRITE_EN_MASK;\
-       type MPC_RMU_3DLUT_RAM_SEL;\
-       type MPC_RMU_3DLUT_30BIT_EN;\
-       type MPC_RMU_3DLUT_CONFIG_STATUS;\
-       type MPC_RMU_3DLUT_READ_SEL;\
-       type MPC_RMU_3DLUT_INDEX;\
-       type MPC_RMU_3DLUT_DATA0;\
-       type MPC_RMU_3DLUT_DATA1;\
-       type MPC_RMU_3DLUT_DATA_30BIT;\
-       type MPC_RMU_SHAPER_LUT_MODE;\
-       type MPC_RMU_SHAPER_LUT_MODE_CURRENT;\
-       type MPC_RMU_SHAPER_OFFSET_R;\
-       type MPC_RMU_SHAPER_OFFSET_G;\
-       type MPC_RMU_SHAPER_OFFSET_B;\
-       type MPC_RMU_SHAPER_SCALE_R;\
-       type MPC_RMU_SHAPER_SCALE_G;\
-       type MPC_RMU_SHAPER_SCALE_B;\
-       type MPC_RMU_SHAPER_LUT_INDEX;\
-       type MPC_RMU_SHAPER_LUT_DATA;\
-       type MPC_RMU_SHAPER_LUT_WRITE_EN_MASK;\
-       type MPC_RMU_SHAPER_LUT_WRITE_SEL;\
-       type MPC_RMU_SHAPER_CONFIG_STATUS;\
-       type MPC_RMU_SHAPER_RAMA_EXP_REGION_START_B;\
-       type MPC_RMU_SHAPER_RAMA_EXP_REGION_START_SEGMENT_B;\
-       type MPC_RMU_SHAPER_RAMA_EXP_REGION_END_B;\
-       type MPC_RMU_SHAPER_RAMA_EXP_REGION_END_BASE_B;\
-       type MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET;\
-       type MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS;\
-       type MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET;\
-       type MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS;\
-       type MPC_RMU_SHAPER_MODE_CURRENT
-
-struct dcn30_mpc_registers {
-       MPC_REG_VARIABLE_LIST_DCN3_0;
-       MPC_REG_VARIABLE_LIST_DCN32;
-};
-
-struct dcn30_mpc_shift {
-       MPC_REG_FIELD_LIST_DCN3_0(uint8_t);
-       MPC_REG_FIELD_LIST_DCN32(uint8_t);
-};
-
-struct dcn30_mpc_mask {
-       MPC_REG_FIELD_LIST_DCN3_0(uint32_t);
-       MPC_REG_FIELD_LIST_DCN32(uint32_t);
-};
-
-struct dcn30_mpc {
-       struct mpc base;
-
-       int mpcc_in_use_mask;
-       int num_mpcc;
-       const struct dcn30_mpc_registers *mpc_regs;
-       const struct dcn30_mpc_shift *mpc_shift;
-       const struct dcn30_mpc_mask *mpc_mask;
-       int num_rmu;
-};
-
-void dcn30_mpc_construct(struct dcn30_mpc *mpc30,
-       struct dc_context *ctx,
-       const struct dcn30_mpc_registers *mpc_regs,
-       const struct dcn30_mpc_shift *mpc_shift,
-       const struct dcn30_mpc_mask *mpc_mask,
-       int num_mpcc,
-       int num_rmu);
-
-void mpc3_mpc_init(
-       struct mpc *mpc);
-
-void mpc3_mpc_init_single_inst(
-       struct mpc *mpc,
-       unsigned int mpcc_id);
-
-bool mpc3_program_shaper(
-               struct mpc *mpc,
-               const struct pwl_params *params,
-               uint32_t rmu_idx);
-
-bool mpc3_program_3dlut(
-               struct mpc *mpc,
-               const struct tetrahedral_params *params,
-               int rmu_idx);
-
-uint32_t mpcc3_acquire_rmu(struct mpc *mpc,
-               int mpcc_id, int rmu_idx);
-
-void mpc3_set_denorm(
-       struct mpc *mpc,
-       int opp_id,
-       enum dc_color_depth output_depth);
-
-void mpc3_set_denorm_clamp(
-       struct mpc *mpc,
-       int opp_id,
-       struct mpc_denorm_clamp denorm_clamp);
-
-void mpc3_set_output_csc(
-       struct mpc *mpc,
-       int opp_id,
-       const uint16_t *regval,
-       enum mpc_output_csc_mode ocsc_mode);
-
-void mpc3_set_ocsc_default(
-       struct mpc *mpc,
-       int opp_id,
-       enum dc_color_space color_space,
-       enum mpc_output_csc_mode ocsc_mode);
-
-void mpc3_set_output_gamma(
-       struct mpc *mpc,
-       int mpcc_id,
-       const struct pwl_params *params);
-
-uint32_t mpc3_get_rmu_mux_status(
-       struct mpc *mpc,
-       int rmu_idx);
-
-void mpc3_set_gamut_remap(
-       struct mpc *mpc,
-       int mpcc_id,
-       const struct mpc_grph_gamut_adjustment *adjust);
-
-void mpc3_get_gamut_remap(struct mpc *mpc,
-                         int mpcc_id,
-                         struct mpc_grph_gamut_adjustment *adjust);
-
-void mpc3_set_rmu_mux(
-       struct mpc *mpc,
-       int rmu_idx,
-       int value);
-
-void mpc3_set_dwb_mux(
-       struct mpc *mpc,
-       int dwb_id,
-       int mpcc_id);
-
-void mpc3_disable_dwb_mux(
-       struct mpc *mpc,
-       int dwb_id);
-
-bool mpc3_is_dwb_idle(
-       struct mpc *mpc,
-       int dwb_id);
-
-void mpc3_power_on_ogam_lut(
-       struct mpc *mpc, int mpcc_id,
-       bool power_on);
-
-void mpc3_init_mpcc(struct mpcc *mpcc, int mpcc_inst);
-
-enum dc_lut_mode mpc3_get_ogam_current(
-       struct mpc *mpc,
-       int mpcc_id);
-
-#endif
index 7f7458c..5402c35 100644 (file)
 #
 
 ifdef CONFIG_DRM_AMD_DC_FP
+###############################################################################
+# DCN10
+###############################################################################
+MPC_DCN10 = dcn10_mpc.o
+
+AMD_DAL_MPC_DCN10 = $(addprefix $(AMDDALPATH)/dc/mpc/dcn10/,$(MPC_DCN10))
+
+AMD_DISPLAY_FILES += $(AMD_DAL_MPC_DCN10)
+
+###############################################################################
+# DCN20
+###############################################################################
+MPC_DCN20 = dcn20_mpc.o
+
+AMD_DAL_MPC_DCN20 = $(addprefix $(AMDDALPATH)/dc/mpc/dcn20/,$(MPC_DCN20))
+
+AMD_DISPLAY_FILES += $(AMD_DAL_MPC_DCN20)
+
+###############################################################################
+# DCN30
+###############################################################################
+MPC_DCN30 = dcn30_mpc.o
+
+AMD_DAL_MPC_DCN30 = $(addprefix $(AMDDALPATH)/dc/mpc/dcn30/,$(MPC_DCN30))
+
+AMD_DISPLAY_FILES += $(AMD_DAL_MPC_DCN30)
+
 ###############################################################################
 # DCN32
 ###############################################################################
diff --git a/drivers/gpu/drm/amd/display/dc/mpc/dcn10/dcn10_mpc.c b/drivers/gpu/drm/amd/display/dc/mpc/dcn10/dcn10_mpc.c
new file mode 100644 (file)
index 0000000..f2f5556
--- /dev/null
@@ -0,0 +1,537 @@
+/*
+ * Copyright 2012-15 Advanced Micro Devices, Inc.
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining a
+ * copy of this software and associated documentation files (the "Software"),
+ * to deal in the Software without restriction, including without limitation
+ * the rights to use, copy, modify, merge, publish, distribute, sublicense,
+ * and/or sell copies of the Software, and to permit persons to whom the
+ * Software is furnished to do so, subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be included in
+ * all copies or substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
+ * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
+ * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
+ * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
+ * OTHER DEALINGS IN THE SOFTWARE.
+ *
+ * Authors: AMD
+ *
+ */
+
+#include "reg_helper.h"
+#include "dcn10_mpc.h"
+
+#define REG(reg)\
+       mpc10->mpc_regs->reg
+
+#define CTX \
+       mpc10->base.ctx
+
+#undef FN
+#define FN(reg_name, field_name) \
+       mpc10->mpc_shift->field_name, mpc10->mpc_mask->field_name
+
+
+void mpc1_set_bg_color(struct mpc *mpc,
+               struct tg_color *bg_color,
+               int mpcc_id)
+{
+       struct dcn10_mpc *mpc10 = TO_DCN10_MPC(mpc);
+       struct mpcc *bottommost_mpcc = mpc1_get_mpcc(mpc, mpcc_id);
+       uint32_t bg_r_cr, bg_g_y, bg_b_cb;
+
+       bottommost_mpcc->blnd_cfg.black_color = *bg_color;
+
+       /* find bottommost mpcc. */
+       while (bottommost_mpcc->mpcc_bot) {
+               /* avoid circular linked link */
+               ASSERT(bottommost_mpcc != bottommost_mpcc->mpcc_bot);
+               if (bottommost_mpcc == bottommost_mpcc->mpcc_bot)
+                       break;
+
+               bottommost_mpcc = bottommost_mpcc->mpcc_bot;
+       }
+
+       /* mpc color is 12 bit.  tg_color is 10 bit */
+       /* todo: might want to use 16 bit to represent color and have each
+        * hw block translate to correct color depth.
+        */
+       bg_r_cr = bg_color->color_r_cr << 2;
+       bg_g_y = bg_color->color_g_y << 2;
+       bg_b_cb = bg_color->color_b_cb << 2;
+
+       REG_SET(MPCC_BG_R_CR[bottommost_mpcc->mpcc_id], 0,
+                       MPCC_BG_R_CR, bg_r_cr);
+       REG_SET(MPCC_BG_G_Y[bottommost_mpcc->mpcc_id], 0,
+                       MPCC_BG_G_Y, bg_g_y);
+       REG_SET(MPCC_BG_B_CB[bottommost_mpcc->mpcc_id], 0,
+                       MPCC_BG_B_CB, bg_b_cb);
+}
+
+static void mpc1_update_blending(
+       struct mpc *mpc,
+       struct mpcc_blnd_cfg *blnd_cfg,
+       int mpcc_id)
+{
+       struct dcn10_mpc *mpc10 = TO_DCN10_MPC(mpc);
+       struct mpcc *mpcc = mpc1_get_mpcc(mpc, mpcc_id);
+
+       REG_UPDATE_5(MPCC_CONTROL[mpcc_id],
+                       MPCC_ALPHA_BLND_MODE,           blnd_cfg->alpha_mode,
+                       MPCC_ALPHA_MULTIPLIED_MODE,     blnd_cfg->pre_multiplied_alpha,
+                       MPCC_BLND_ACTIVE_OVERLAP_ONLY,  blnd_cfg->overlap_only,
+                       MPCC_GLOBAL_ALPHA,              blnd_cfg->global_alpha,
+                       MPCC_GLOBAL_GAIN,               blnd_cfg->global_gain);
+
+       mpcc->blnd_cfg = *blnd_cfg;
+}
+
+void mpc1_update_stereo_mix(
+       struct mpc *mpc,
+       struct mpcc_sm_cfg *sm_cfg,
+       int mpcc_id)
+{
+       struct dcn10_mpc *mpc10 = TO_DCN10_MPC(mpc);
+
+       REG_UPDATE_6(MPCC_SM_CONTROL[mpcc_id],
+                       MPCC_SM_EN,                     sm_cfg->enable,
+                       MPCC_SM_MODE,                   sm_cfg->sm_mode,
+                       MPCC_SM_FRAME_ALT,              sm_cfg->frame_alt,
+                       MPCC_SM_FIELD_ALT,              sm_cfg->field_alt,
+                       MPCC_SM_FORCE_NEXT_FRAME_POL,   sm_cfg->force_next_frame_porlarity,
+                       MPCC_SM_FORCE_NEXT_TOP_POL,     sm_cfg->force_next_field_polarity);
+}
+void mpc1_assert_idle_mpcc(struct mpc *mpc, int id)
+{
+       struct dcn10_mpc *mpc10 = TO_DCN10_MPC(mpc);
+
+       ASSERT(!(mpc10->mpcc_in_use_mask & 1 << id));
+       REG_WAIT(MPCC_STATUS[id],
+                       MPCC_IDLE, 1,
+                       1, 100000);
+}
+
+struct mpcc *mpc1_get_mpcc(struct mpc *mpc, int mpcc_id)
+{
+       struct dcn10_mpc *mpc10 = TO_DCN10_MPC(mpc);
+
+       ASSERT(mpcc_id < mpc10->num_mpcc);
+       return &(mpc->mpcc_array[mpcc_id]);
+}
+
+struct mpcc *mpc1_get_mpcc_for_dpp(struct mpc_tree *tree, int dpp_id)
+{
+       struct mpcc *tmp_mpcc = tree->opp_list;
+
+       while (tmp_mpcc != NULL) {
+               if (tmp_mpcc->dpp_id == dpp_id)
+                       return tmp_mpcc;
+
+               /* avoid circular linked list */
+               ASSERT(tmp_mpcc != tmp_mpcc->mpcc_bot);
+               if (tmp_mpcc == tmp_mpcc->mpcc_bot)
+                       break;
+
+               tmp_mpcc = tmp_mpcc->mpcc_bot;
+       }
+       return NULL;
+}
+
+bool mpc1_is_mpcc_idle(struct mpc *mpc, int mpcc_id)
+{
+       struct dcn10_mpc *mpc10 = TO_DCN10_MPC(mpc);
+       unsigned int top_sel;
+       unsigned int opp_id;
+       unsigned int idle;
+
+       REG_GET(MPCC_TOP_SEL[mpcc_id], MPCC_TOP_SEL, &top_sel);
+       REG_GET(MPCC_OPP_ID[mpcc_id],  MPCC_OPP_ID, &opp_id);
+       REG_GET(MPCC_STATUS[mpcc_id],  MPCC_IDLE,   &idle);
+       if (top_sel == 0xf && opp_id == 0xf && idle)
+               return true;
+       else
+               return false;
+}
+
+void mpc1_assert_mpcc_idle_before_connect(struct mpc *mpc, int mpcc_id)
+{
+       struct dcn10_mpc *mpc10 = TO_DCN10_MPC(mpc);
+       unsigned int top_sel, mpc_busy, mpc_idle;
+
+       REG_GET(MPCC_TOP_SEL[mpcc_id],
+                       MPCC_TOP_SEL, &top_sel);
+
+       if (top_sel == 0xf) {
+               REG_GET_2(MPCC_STATUS[mpcc_id],
+                               MPCC_BUSY, &mpc_busy,
+                               MPCC_IDLE, &mpc_idle);
+
+               ASSERT(mpc_busy == 0);
+               ASSERT(mpc_idle == 1);
+       }
+}
+
+/*
+ * Insert DPP into MPC tree based on specified blending position.
+ * Only used for planes that are part of blending chain for OPP output
+ *
+ * Parameters:
+ * [in/out] mpc                - MPC context.
+ * [in/out] tree       - MPC tree structure that plane will be added to.
+ * [in]        blnd_cfg        - MPCC blending configuration for the new blending layer.
+ * [in]        sm_cfg          - MPCC stereo mix configuration for the new blending layer.
+ *                       stereo mix must disable for the very bottom layer of the tree config.
+ * [in]        insert_above_mpcc - Insert new plane above this MPCC.  If NULL, insert as bottom plane.
+ * [in]        dpp_id          - DPP instance for the plane to be added.
+ * [in]        mpcc_id         - The MPCC physical instance to use for blending.
+ *
+ * Return:  struct mpcc* - MPCC that was added.
+ */
+struct mpcc *mpc1_insert_plane(
+       struct mpc *mpc,
+       struct mpc_tree *tree,
+       struct mpcc_blnd_cfg *blnd_cfg,
+       struct mpcc_sm_cfg *sm_cfg,
+       struct mpcc *insert_above_mpcc,
+       int dpp_id,
+       int mpcc_id)
+{
+       struct dcn10_mpc *mpc10 = TO_DCN10_MPC(mpc);
+       struct mpcc *new_mpcc = NULL;
+
+       /* sanity check parameters */
+       ASSERT(mpcc_id < mpc10->num_mpcc);
+       ASSERT(!(mpc10->mpcc_in_use_mask & 1 << mpcc_id));
+
+       if (insert_above_mpcc) {
+               /* check insert_above_mpcc exist in tree->opp_list */
+               struct mpcc *temp_mpcc = tree->opp_list;
+
+               if (temp_mpcc != insert_above_mpcc)
+                       while (temp_mpcc && temp_mpcc->mpcc_bot != insert_above_mpcc)
+                               temp_mpcc = temp_mpcc->mpcc_bot;
+               if (temp_mpcc == NULL)
+                       return NULL;
+       }
+
+       /* Get and update MPCC struct parameters */
+       new_mpcc = mpc1_get_mpcc(mpc, mpcc_id);
+       new_mpcc->dpp_id = dpp_id;
+
+       /* program mux and MPCC_MODE */
+       if (insert_above_mpcc) {
+               new_mpcc->mpcc_bot = insert_above_mpcc;
+               REG_SET(MPCC_BOT_SEL[mpcc_id], 0, MPCC_BOT_SEL, insert_above_mpcc->mpcc_id);
+               REG_UPDATE(MPCC_CONTROL[mpcc_id], MPCC_MODE, MPCC_BLEND_MODE_TOP_BOT_BLENDING);
+       } else {
+               new_mpcc->mpcc_bot = NULL;
+               REG_SET(MPCC_BOT_SEL[mpcc_id], 0, MPCC_BOT_SEL, 0xf);
+               REG_UPDATE(MPCC_CONTROL[mpcc_id], MPCC_MODE, MPCC_BLEND_MODE_TOP_LAYER_ONLY);
+       }
+       REG_SET(MPCC_TOP_SEL[mpcc_id], 0, MPCC_TOP_SEL, dpp_id);
+       REG_SET(MPCC_OPP_ID[mpcc_id], 0, MPCC_OPP_ID, tree->opp_id);
+
+       /* Configure VUPDATE lock set for this MPCC to map to the OPP */
+       REG_SET(MPCC_UPDATE_LOCK_SEL[mpcc_id], 0, MPCC_UPDATE_LOCK_SEL, tree->opp_id);
+
+       /* update mpc tree mux setting */
+       if (tree->opp_list == insert_above_mpcc) {
+               /* insert the toppest mpcc */
+               tree->opp_list = new_mpcc;
+               REG_UPDATE(MUX[tree->opp_id], MPC_OUT_MUX, mpcc_id);
+       } else {
+               /* find insert position */
+               struct mpcc *temp_mpcc = tree->opp_list;
+
+               while (temp_mpcc && temp_mpcc->mpcc_bot != insert_above_mpcc)
+                       temp_mpcc = temp_mpcc->mpcc_bot;
+               if (temp_mpcc && temp_mpcc->mpcc_bot == insert_above_mpcc) {
+                       REG_SET(MPCC_BOT_SEL[temp_mpcc->mpcc_id], 0, MPCC_BOT_SEL, mpcc_id);
+                       temp_mpcc->mpcc_bot = new_mpcc;
+                       if (!insert_above_mpcc)
+                               REG_UPDATE(MPCC_CONTROL[temp_mpcc->mpcc_id],
+                                               MPCC_MODE, MPCC_BLEND_MODE_TOP_BOT_BLENDING);
+               }
+       }
+
+       /* update the blending configuration */
+       mpc->funcs->update_blending(mpc, blnd_cfg, mpcc_id);
+
+       /* update the stereo mix settings, if provided */
+       if (sm_cfg != NULL) {
+               new_mpcc->sm_cfg = *sm_cfg;
+               mpc1_update_stereo_mix(mpc, sm_cfg, mpcc_id);
+       }
+
+       /* mark this mpcc as in use */
+       mpc10->mpcc_in_use_mask |= 1 << mpcc_id;
+
+       return new_mpcc;
+}
+
+/*
+ * Remove a specified MPCC from the MPC tree.
+ *
+ * Parameters:
+ * [in/out] mpc                - MPC context.
+ * [in/out] tree       - MPC tree structure that plane will be removed from.
+ * [in/out] mpcc       - MPCC to be removed from tree.
+ *
+ * Return:  void
+ */
+void mpc1_remove_mpcc(
+       struct mpc *mpc,
+       struct mpc_tree *tree,
+       struct mpcc *mpcc_to_remove)
+{
+       struct dcn10_mpc *mpc10 = TO_DCN10_MPC(mpc);
+       bool found = false;
+       int mpcc_id = mpcc_to_remove->mpcc_id;
+
+       if (tree->opp_list == mpcc_to_remove) {
+               found = true;
+               /* remove MPCC from top of tree */
+               if (mpcc_to_remove->mpcc_bot) {
+                       /* set the next MPCC in list to be the top MPCC */
+                       tree->opp_list = mpcc_to_remove->mpcc_bot;
+                       REG_UPDATE(MUX[tree->opp_id], MPC_OUT_MUX, tree->opp_list->mpcc_id);
+               } else {
+                       /* there are no other MPCC is list */
+                       tree->opp_list = NULL;
+                       REG_UPDATE(MUX[tree->opp_id], MPC_OUT_MUX, 0xf);
+               }
+       } else {
+               /* find mpcc to remove MPCC list */
+               struct mpcc *temp_mpcc = tree->opp_list;
+
+               while (temp_mpcc && temp_mpcc->mpcc_bot != mpcc_to_remove)
+                       temp_mpcc = temp_mpcc->mpcc_bot;
+
+               if (temp_mpcc && temp_mpcc->mpcc_bot == mpcc_to_remove) {
+                       found = true;
+                       temp_mpcc->mpcc_bot = mpcc_to_remove->mpcc_bot;
+                       if (mpcc_to_remove->mpcc_bot) {
+                               /* remove MPCC in middle of list */
+                               REG_SET(MPCC_BOT_SEL[temp_mpcc->mpcc_id], 0,
+                                               MPCC_BOT_SEL, mpcc_to_remove->mpcc_bot->mpcc_id);
+                       } else {
+                               /* remove MPCC from bottom of list */
+                               REG_SET(MPCC_BOT_SEL[temp_mpcc->mpcc_id], 0,
+                                               MPCC_BOT_SEL, 0xf);
+                               REG_UPDATE(MPCC_CONTROL[temp_mpcc->mpcc_id],
+                                               MPCC_MODE, MPCC_BLEND_MODE_TOP_LAYER_PASSTHROUGH);
+                       }
+               }
+       }
+
+       if (found) {
+               /* turn off MPCC mux registers */
+               REG_SET(MPCC_TOP_SEL[mpcc_id], 0, MPCC_TOP_SEL, 0xf);
+               REG_SET(MPCC_BOT_SEL[mpcc_id], 0, MPCC_BOT_SEL, 0xf);
+               REG_SET(MPCC_OPP_ID[mpcc_id],  0, MPCC_OPP_ID,  0xf);
+               REG_SET(MPCC_UPDATE_LOCK_SEL[mpcc_id], 0, MPCC_UPDATE_LOCK_SEL, 0xf);
+
+               /* mark this mpcc as not in use */
+               mpc10->mpcc_in_use_mask &= ~(1 << mpcc_id);
+               mpcc_to_remove->dpp_id = 0xf;
+               mpcc_to_remove->mpcc_bot = NULL;
+       } else {
+               /* In case of resume from S3/S4, remove mpcc from bios left over */
+               REG_SET(MPCC_TOP_SEL[mpcc_id], 0, MPCC_TOP_SEL, 0xf);
+               REG_SET(MPCC_BOT_SEL[mpcc_id], 0, MPCC_BOT_SEL, 0xf);
+               REG_SET(MPCC_OPP_ID[mpcc_id],  0, MPCC_OPP_ID,  0xf);
+               REG_SET(MPCC_UPDATE_LOCK_SEL[mpcc_id], 0, MPCC_UPDATE_LOCK_SEL, 0xf);
+       }
+}
+
+static void mpc1_init_mpcc(struct mpcc *mpcc, int mpcc_inst)
+{
+       mpcc->mpcc_id = mpcc_inst;
+       mpcc->dpp_id = 0xf;
+       mpcc->mpcc_bot = NULL;
+       mpcc->blnd_cfg.overlap_only = false;
+       mpcc->blnd_cfg.global_alpha = 0xff;
+       mpcc->blnd_cfg.global_gain = 0xff;
+       mpcc->sm_cfg.enable = false;
+}
+
+/*
+ * Reset the MPCC HW status by disconnecting all muxes.
+ *
+ * Parameters:
+ * [in/out] mpc                - MPC context.
+ *
+ * Return:  void
+ */
+void mpc1_mpc_init(struct mpc *mpc)
+{
+       struct dcn10_mpc *mpc10 = TO_DCN10_MPC(mpc);
+       int mpcc_id;
+       int opp_id;
+
+       mpc10->mpcc_in_use_mask = 0;
+       for (mpcc_id = 0; mpcc_id < mpc10->num_mpcc; mpcc_id++) {
+               REG_SET(MPCC_TOP_SEL[mpcc_id], 0, MPCC_TOP_SEL, 0xf);
+               REG_SET(MPCC_BOT_SEL[mpcc_id], 0, MPCC_BOT_SEL, 0xf);
+               REG_SET(MPCC_OPP_ID[mpcc_id],  0, MPCC_OPP_ID,  0xf);
+               REG_SET(MPCC_UPDATE_LOCK_SEL[mpcc_id], 0, MPCC_UPDATE_LOCK_SEL, 0xf);
+
+               mpc1_init_mpcc(&(mpc->mpcc_array[mpcc_id]), mpcc_id);
+       }
+
+       for (opp_id = 0; opp_id < MAX_OPP; opp_id++) {
+               if (REG(MUX[opp_id]))
+                       REG_UPDATE(MUX[opp_id], MPC_OUT_MUX, 0xf);
+       }
+}
+
+void mpc1_mpc_init_single_inst(struct mpc *mpc, unsigned int mpcc_id)
+{
+       struct dcn10_mpc *mpc10 = TO_DCN10_MPC(mpc);
+       int opp_id;
+
+       REG_GET(MPCC_OPP_ID[mpcc_id], MPCC_OPP_ID, &opp_id);
+
+       REG_SET(MPCC_TOP_SEL[mpcc_id], 0, MPCC_TOP_SEL, 0xf);
+       REG_SET(MPCC_BOT_SEL[mpcc_id], 0, MPCC_BOT_SEL, 0xf);
+       REG_SET(MPCC_OPP_ID[mpcc_id],  0, MPCC_OPP_ID,  0xf);
+       REG_SET(MPCC_UPDATE_LOCK_SEL[mpcc_id], 0, MPCC_UPDATE_LOCK_SEL, 0xf);
+
+       mpc1_init_mpcc(&(mpc->mpcc_array[mpcc_id]), mpcc_id);
+
+       if (opp_id < MAX_OPP && REG(MUX[opp_id]))
+               REG_UPDATE(MUX[opp_id], MPC_OUT_MUX, 0xf);
+}
+
+
+void mpc1_init_mpcc_list_from_hw(
+       struct mpc *mpc,
+       struct mpc_tree *tree)
+{
+       struct dcn10_mpc *mpc10 = TO_DCN10_MPC(mpc);
+       unsigned int opp_id;
+       unsigned int top_sel;
+       unsigned int bot_sel;
+       unsigned int out_mux;
+       struct mpcc *mpcc;
+       int mpcc_id;
+       int bot_mpcc_id;
+
+       REG_GET(MUX[tree->opp_id], MPC_OUT_MUX, &out_mux);
+
+       if (out_mux != 0xf) {
+               for (mpcc_id = 0; mpcc_id < mpc10->num_mpcc; mpcc_id++) {
+                       REG_GET(MPCC_OPP_ID[mpcc_id],  MPCC_OPP_ID,  &opp_id);
+                       REG_GET(MPCC_TOP_SEL[mpcc_id], MPCC_TOP_SEL, &top_sel);
+                       REG_GET(MPCC_BOT_SEL[mpcc_id],  MPCC_BOT_SEL, &bot_sel);
+
+                       if (bot_sel == mpcc_id)
+                               bot_sel = 0xf;
+
+                       if ((opp_id == tree->opp_id) && (top_sel != 0xf)) {
+                               mpcc = mpc1_get_mpcc(mpc, mpcc_id);
+                               mpcc->dpp_id = top_sel;
+                               mpc10->mpcc_in_use_mask |= 1 << mpcc_id;
+
+                               if (out_mux == mpcc_id)
+                                       tree->opp_list = mpcc;
+                               if (bot_sel != 0xf && bot_sel < mpc10->num_mpcc) {
+                                       bot_mpcc_id = bot_sel;
+                                       REG_GET(MPCC_OPP_ID[bot_mpcc_id],  MPCC_OPP_ID,  &opp_id);
+                                       REG_GET(MPCC_TOP_SEL[bot_mpcc_id], MPCC_TOP_SEL, &top_sel);
+                                       if ((opp_id == tree->opp_id) && (top_sel != 0xf)) {
+                                               struct mpcc *mpcc_bottom = mpc1_get_mpcc(mpc, bot_mpcc_id);
+
+                                               mpcc->mpcc_bot = mpcc_bottom;
+                                       }
+                               }
+                       }
+               }
+       }
+}
+
+void mpc1_read_mpcc_state(
+               struct mpc *mpc,
+               int mpcc_inst,
+               struct mpcc_state *s)
+{
+       struct dcn10_mpc *mpc10 = TO_DCN10_MPC(mpc);
+
+       REG_GET(MPCC_OPP_ID[mpcc_inst], MPCC_OPP_ID, &s->opp_id);
+       REG_GET(MPCC_TOP_SEL[mpcc_inst], MPCC_TOP_SEL, &s->dpp_id);
+       REG_GET(MPCC_BOT_SEL[mpcc_inst], MPCC_BOT_SEL, &s->bot_mpcc_id);
+       REG_GET_4(MPCC_CONTROL[mpcc_inst], MPCC_MODE, &s->mode,
+                       MPCC_ALPHA_BLND_MODE, &s->alpha_mode,
+                       MPCC_ALPHA_MULTIPLIED_MODE, &s->pre_multiplied_alpha,
+                       MPCC_BLND_ACTIVE_OVERLAP_ONLY, &s->overlap_only);
+       REG_GET_2(MPCC_STATUS[mpcc_inst], MPCC_IDLE, &s->idle,
+                       MPCC_BUSY, &s->busy);
+}
+
+void mpc1_cursor_lock(struct mpc *mpc, int opp_id, bool lock)
+{
+       struct dcn10_mpc *mpc10 = TO_DCN10_MPC(mpc);
+
+       REG_SET(CUR[opp_id], 0, CUR_VUPDATE_LOCK_SET, lock ? 1 : 0);
+}
+
+unsigned int mpc1_get_mpc_out_mux(struct mpc *mpc, int opp_id)
+{
+       struct dcn10_mpc *mpc10 = TO_DCN10_MPC(mpc);
+       uint32_t val = 0xf;
+
+       if (opp_id < MAX_OPP && REG(MUX[opp_id]))
+               REG_GET(MUX[opp_id], MPC_OUT_MUX, &val);
+
+       return val;
+}
+
+static const struct mpc_funcs dcn10_mpc_funcs = {
+       .read_mpcc_state = mpc1_read_mpcc_state,
+       .insert_plane = mpc1_insert_plane,
+       .remove_mpcc = mpc1_remove_mpcc,
+       .mpc_init = mpc1_mpc_init,
+       .mpc_init_single_inst = mpc1_mpc_init_single_inst,
+       .get_mpcc_for_dpp = mpc1_get_mpcc_for_dpp,
+       .wait_for_idle = mpc1_assert_idle_mpcc,
+       .assert_mpcc_idle_before_connect = mpc1_assert_mpcc_idle_before_connect,
+       .init_mpcc_list_from_hw = mpc1_init_mpcc_list_from_hw,
+       .update_blending = mpc1_update_blending,
+       .cursor_lock = mpc1_cursor_lock,
+       .set_denorm = NULL,
+       .set_denorm_clamp = NULL,
+       .set_output_csc = NULL,
+       .set_output_gamma = NULL,
+       .get_mpc_out_mux = mpc1_get_mpc_out_mux,
+       .set_bg_color = mpc1_set_bg_color,
+};
+
+void dcn10_mpc_construct(struct dcn10_mpc *mpc10,
+       struct dc_context *ctx,
+       const struct dcn_mpc_registers *mpc_regs,
+       const struct dcn_mpc_shift *mpc_shift,
+       const struct dcn_mpc_mask *mpc_mask,
+       int num_mpcc)
+{
+       int i;
+
+       mpc10->base.ctx = ctx;
+
+       mpc10->base.funcs = &dcn10_mpc_funcs;
+
+       mpc10->mpc_regs = mpc_regs;
+       mpc10->mpc_shift = mpc_shift;
+       mpc10->mpc_mask = mpc_mask;
+
+       mpc10->mpcc_in_use_mask = 0;
+       mpc10->num_mpcc = num_mpcc;
+
+       for (i = 0; i < MAX_MPCC; i++)
+               mpc1_init_mpcc(&mpc10->base.mpcc_array[i], i);
+}
+
diff --git a/drivers/gpu/drm/amd/display/dc/mpc/dcn10/dcn10_mpc.h b/drivers/gpu/drm/amd/display/dc/mpc/dcn10/dcn10_mpc.h
new file mode 100644 (file)
index 0000000..dbfffc6
--- /dev/null
@@ -0,0 +1,204 @@
+/* Copyright 2012-15 Advanced Micro Devices, Inc.
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining a
+ * copy of this software and associated documentation files (the "Software"),
+ * to deal in the Software without restriction, including without limitation
+ * the rights to use, copy, modify, merge, publish, distribute, sublicense,
+ * and/or sell copies of the Software, and to permit persons to whom the
+ * Software is furnished to do so, subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be included in
+ * all copies or substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
+ * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
+ * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
+ * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
+ * OTHER DEALINGS IN THE SOFTWARE.
+ *
+ * Authors: AMD
+ *
+ */
+
+#ifndef __DC_MPCC_DCN10_H__
+#define __DC_MPCC_DCN10_H__
+
+#include "mpc.h"
+
+#define TO_DCN10_MPC(mpc_base) \
+       container_of(mpc_base, struct dcn10_mpc, base)
+
+#define MPC_COMMON_REG_LIST_DCN1_0(inst) \
+       SRII(MPCC_TOP_SEL, MPCC, inst),\
+       SRII(MPCC_BOT_SEL, MPCC, inst),\
+       SRII(MPCC_CONTROL, MPCC, inst),\
+       SRII(MPCC_STATUS, MPCC, inst),\
+       SRII(MPCC_OPP_ID, MPCC, inst),\
+       SRII(MPCC_BG_G_Y, MPCC, inst),\
+       SRII(MPCC_BG_R_CR, MPCC, inst),\
+       SRII(MPCC_BG_B_CB, MPCC, inst),\
+       SRII(MPCC_SM_CONTROL, MPCC, inst),\
+       SRII(MPCC_UPDATE_LOCK_SEL, MPCC, inst)
+
+#define MPC_OUT_MUX_COMMON_REG_LIST_DCN1_0(inst) \
+       SRII(MUX, MPC_OUT, inst),\
+       VUPDATE_SRII(CUR, VUPDATE_LOCK_SET, inst)
+
+#define MPC_COMMON_REG_VARIABLE_LIST \
+       uint32_t MPCC_TOP_SEL[MAX_MPCC]; \
+       uint32_t MPCC_BOT_SEL[MAX_MPCC]; \
+       uint32_t MPCC_CONTROL[MAX_MPCC]; \
+       uint32_t MPCC_STATUS[MAX_MPCC]; \
+       uint32_t MPCC_OPP_ID[MAX_MPCC]; \
+       uint32_t MPCC_BG_G_Y[MAX_MPCC]; \
+       uint32_t MPCC_BG_R_CR[MAX_MPCC]; \
+       uint32_t MPCC_BG_B_CB[MAX_MPCC]; \
+       uint32_t MPCC_SM_CONTROL[MAX_MPCC]; \
+       uint32_t MUX[MAX_OPP]; \
+       uint32_t MPCC_UPDATE_LOCK_SEL[MAX_MPCC]; \
+       uint32_t CUR[MAX_OPP];
+
+#define MPC_COMMON_MASK_SH_LIST_DCN1_0(mask_sh)\
+       SF(MPCC0_MPCC_TOP_SEL, MPCC_TOP_SEL, mask_sh),\
+       SF(MPCC0_MPCC_BOT_SEL, MPCC_BOT_SEL, mask_sh),\
+       SF(MPCC0_MPCC_CONTROL, MPCC_MODE, mask_sh),\
+       SF(MPCC0_MPCC_CONTROL, MPCC_ALPHA_BLND_MODE, mask_sh),\
+       SF(MPCC0_MPCC_CONTROL, MPCC_ALPHA_MULTIPLIED_MODE, mask_sh),\
+       SF(MPCC0_MPCC_CONTROL, MPCC_BLND_ACTIVE_OVERLAP_ONLY, mask_sh),\
+       SF(MPCC0_MPCC_CONTROL, MPCC_GLOBAL_ALPHA, mask_sh),\
+       SF(MPCC0_MPCC_CONTROL, MPCC_GLOBAL_GAIN, mask_sh),\
+       SF(MPCC0_MPCC_STATUS, MPCC_IDLE, mask_sh),\
+       SF(MPCC0_MPCC_STATUS, MPCC_BUSY, mask_sh),\
+       SF(MPCC0_MPCC_OPP_ID, MPCC_OPP_ID, mask_sh),\
+       SF(MPCC0_MPCC_BG_G_Y, MPCC_BG_G_Y, mask_sh),\
+       SF(MPCC0_MPCC_BG_R_CR, MPCC_BG_R_CR, mask_sh),\
+       SF(MPCC0_MPCC_BG_B_CB, MPCC_BG_B_CB, mask_sh),\
+       SF(MPCC0_MPCC_SM_CONTROL, MPCC_SM_EN, mask_sh),\
+       SF(MPCC0_MPCC_SM_CONTROL, MPCC_SM_MODE, mask_sh),\
+       SF(MPCC0_MPCC_SM_CONTROL, MPCC_SM_FRAME_ALT, mask_sh),\
+       SF(MPCC0_MPCC_SM_CONTROL, MPCC_SM_FIELD_ALT, mask_sh),\
+       SF(MPCC0_MPCC_SM_CONTROL, MPCC_SM_FORCE_NEXT_FRAME_POL, mask_sh),\
+       SF(MPCC0_MPCC_SM_CONTROL, MPCC_SM_FORCE_NEXT_TOP_POL, mask_sh),\
+       SF(MPC_OUT0_MUX, MPC_OUT_MUX, mask_sh),\
+       SF(MPCC0_MPCC_UPDATE_LOCK_SEL, MPCC_UPDATE_LOCK_SEL, mask_sh)
+
+#define MPC_REG_FIELD_LIST(type) \
+       type MPCC_TOP_SEL;\
+       type MPCC_BOT_SEL;\
+       type MPCC_MODE;\
+       type MPCC_ALPHA_BLND_MODE;\
+       type MPCC_ALPHA_MULTIPLIED_MODE;\
+       type MPCC_BLND_ACTIVE_OVERLAP_ONLY;\
+       type MPCC_GLOBAL_ALPHA;\
+       type MPCC_GLOBAL_GAIN;\
+       type MPCC_IDLE;\
+       type MPCC_BUSY;\
+       type MPCC_OPP_ID;\
+       type MPCC_BG_G_Y;\
+       type MPCC_BG_R_CR;\
+       type MPCC_BG_B_CB;\
+       type MPCC_SM_EN;\
+       type MPCC_SM_MODE;\
+       type MPCC_SM_FRAME_ALT;\
+       type MPCC_SM_FIELD_ALT;\
+       type MPCC_SM_FORCE_NEXT_FRAME_POL;\
+       type MPCC_SM_FORCE_NEXT_TOP_POL;\
+       type MPC_OUT_MUX;\
+       type MPCC_UPDATE_LOCK_SEL;\
+       type CUR_VUPDATE_LOCK_SET;
+
+struct dcn_mpc_registers {
+       MPC_COMMON_REG_VARIABLE_LIST
+};
+
+struct dcn_mpc_shift {
+       MPC_REG_FIELD_LIST(uint8_t)
+};
+
+struct dcn_mpc_mask {
+       MPC_REG_FIELD_LIST(uint32_t)
+};
+
+struct dcn10_mpc {
+       struct mpc base;
+
+       int mpcc_in_use_mask;
+       int num_mpcc;
+       const struct dcn_mpc_registers *mpc_regs;
+       const struct dcn_mpc_shift *mpc_shift;
+       const struct dcn_mpc_mask *mpc_mask;
+};
+
+void dcn10_mpc_construct(struct dcn10_mpc *mpcc10,
+       struct dc_context *ctx,
+       const struct dcn_mpc_registers *mpc_regs,
+       const struct dcn_mpc_shift *mpc_shift,
+       const struct dcn_mpc_mask *mpc_mask,
+       int num_mpcc);
+
+struct mpcc *mpc1_insert_plane(
+       struct mpc *mpc,
+       struct mpc_tree *tree,
+       struct mpcc_blnd_cfg *blnd_cfg,
+       struct mpcc_sm_cfg *sm_cfg,
+       struct mpcc *insert_above_mpcc,
+       int dpp_id,
+       int mpcc_id);
+
+void mpc1_remove_mpcc(
+       struct mpc *mpc,
+       struct mpc_tree *tree,
+       struct mpcc *mpcc);
+
+void mpc1_mpc_init(
+       struct mpc *mpc);
+
+void mpc1_mpc_init_single_inst(
+       struct mpc *mpc,
+       unsigned int mpcc_id);
+
+void mpc1_assert_idle_mpcc(
+       struct mpc *mpc,
+       int id);
+
+void mpc1_set_bg_color(
+       struct mpc *mpc,
+       struct tg_color *bg_color,
+       int id);
+
+void mpc1_update_stereo_mix(
+       struct mpc *mpc,
+       struct mpcc_sm_cfg *sm_cfg,
+       int mpcc_id);
+
+bool mpc1_is_mpcc_idle(
+       struct mpc *mpc,
+       int mpcc_id);
+
+void mpc1_assert_mpcc_idle_before_connect(
+       struct mpc *mpc,
+       int mpcc_id);
+
+void mpc1_init_mpcc_list_from_hw(
+       struct mpc *mpc,
+       struct mpc_tree *tree);
+
+struct mpcc *mpc1_get_mpcc(
+       struct mpc *mpc,
+       int mpcc_id);
+
+struct mpcc *mpc1_get_mpcc_for_dpp(
+       struct mpc_tree *tree,
+       int dpp_id);
+
+void mpc1_read_mpcc_state(
+               struct mpc *mpc,
+               int mpcc_inst,
+               struct mpcc_state *s);
+
+void mpc1_cursor_lock(struct mpc *mpc, int opp_id, bool lock);
+
+unsigned int mpc1_get_mpc_out_mux(struct mpc *mpc, int opp_id);
+#endif
diff --git a/drivers/gpu/drm/amd/display/dc/mpc/dcn20/dcn20_mpc.c b/drivers/gpu/drm/amd/display/dc/mpc/dcn20/dcn20_mpc.c
new file mode 100644 (file)
index 0000000..ea73473
--- /dev/null
@@ -0,0 +1,610 @@
+/*
+ * Copyright 2012-15 Advanced Micro Devices, Inc.
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining a
+ * copy of this software and associated documentation files (the "Software"),
+ * to deal in the Software without restriction, including without limitation
+ * the rights to use, copy, modify, merge, publish, distribute, sublicense,
+ * and/or sell copies of the Software, and to permit persons to whom the
+ * Software is furnished to do so, subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be included in
+ * all copies or substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
+ * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
+ * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
+ * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
+ * OTHER DEALINGS IN THE SOFTWARE.
+ *
+ * Authors: AMD
+ *
+ */
+
+#include "dcn20_mpc.h"
+
+#include "reg_helper.h"
+#include "dc.h"
+#include "mem_input.h"
+#include "dcn10/dcn10_cm_common.h"
+
+#define REG(reg)\
+       mpc20->mpc_regs->reg
+
+#define IND_REG(index) \
+       (index)
+
+#define CTX \
+       mpc20->base.ctx
+
+#undef FN
+#define FN(reg_name, field_name) \
+       mpc20->mpc_shift->field_name, mpc20->mpc_mask->field_name
+
+#define NUM_ELEMENTS(a) (sizeof(a) / sizeof((a)[0]))
+
+void mpc2_update_blending(
+       struct mpc *mpc,
+       struct mpcc_blnd_cfg *blnd_cfg,
+       int mpcc_id)
+{
+       struct dcn20_mpc *mpc20 = TO_DCN20_MPC(mpc);
+
+       struct mpcc *mpcc = mpc1_get_mpcc(mpc, mpcc_id);
+
+       REG_UPDATE_7(MPCC_CONTROL[mpcc_id],
+                       MPCC_ALPHA_BLND_MODE,           blnd_cfg->alpha_mode,
+                       MPCC_ALPHA_MULTIPLIED_MODE,     blnd_cfg->pre_multiplied_alpha,
+                       MPCC_BLND_ACTIVE_OVERLAP_ONLY,  blnd_cfg->overlap_only,
+                       MPCC_GLOBAL_ALPHA,              blnd_cfg->global_alpha,
+                       MPCC_GLOBAL_GAIN,               blnd_cfg->global_gain,
+                       MPCC_BG_BPC,                    blnd_cfg->background_color_bpc,
+                       MPCC_BOT_GAIN_MODE,             blnd_cfg->bottom_gain_mode);
+
+       REG_SET(MPCC_TOP_GAIN[mpcc_id], 0, MPCC_TOP_GAIN, blnd_cfg->top_gain);
+       REG_SET(MPCC_BOT_GAIN_INSIDE[mpcc_id], 0, MPCC_BOT_GAIN_INSIDE, blnd_cfg->bottom_inside_gain);
+       REG_SET(MPCC_BOT_GAIN_OUTSIDE[mpcc_id], 0, MPCC_BOT_GAIN_OUTSIDE, blnd_cfg->bottom_outside_gain);
+
+       mpcc->blnd_cfg = *blnd_cfg;
+}
+
+void mpc2_set_denorm(
+               struct mpc *mpc,
+               int opp_id,
+               enum dc_color_depth output_depth)
+{
+       struct dcn20_mpc *mpc20 = TO_DCN20_MPC(mpc);
+       int denorm_mode = 0;
+
+       switch (output_depth) {
+       case COLOR_DEPTH_666:
+               denorm_mode = 1;
+               break;
+       case COLOR_DEPTH_888:
+               denorm_mode = 2;
+               break;
+       case COLOR_DEPTH_999:
+               denorm_mode = 3;
+               break;
+       case COLOR_DEPTH_101010:
+               denorm_mode = 4;
+               break;
+       case COLOR_DEPTH_111111:
+               denorm_mode = 5;
+               break;
+       case COLOR_DEPTH_121212:
+               denorm_mode = 6;
+               break;
+       case COLOR_DEPTH_141414:
+       case COLOR_DEPTH_161616:
+       default:
+               /* not valid used case! */
+               break;
+       }
+
+       REG_UPDATE(DENORM_CONTROL[opp_id],
+                       MPC_OUT_DENORM_MODE, denorm_mode);
+}
+
+void mpc2_set_denorm_clamp(
+               struct mpc *mpc,
+               int opp_id,
+               struct mpc_denorm_clamp denorm_clamp)
+{
+       struct dcn20_mpc *mpc20 = TO_DCN20_MPC(mpc);
+
+       REG_UPDATE_2(DENORM_CONTROL[opp_id],
+                       MPC_OUT_DENORM_CLAMP_MAX_R_CR, denorm_clamp.clamp_max_r_cr,
+                       MPC_OUT_DENORM_CLAMP_MIN_R_CR, denorm_clamp.clamp_min_r_cr);
+       REG_UPDATE_2(DENORM_CLAMP_G_Y[opp_id],
+                       MPC_OUT_DENORM_CLAMP_MAX_G_Y, denorm_clamp.clamp_max_g_y,
+                       MPC_OUT_DENORM_CLAMP_MIN_G_Y, denorm_clamp.clamp_min_g_y);
+       REG_UPDATE_2(DENORM_CLAMP_B_CB[opp_id],
+                       MPC_OUT_DENORM_CLAMP_MAX_B_CB, denorm_clamp.clamp_max_b_cb,
+                       MPC_OUT_DENORM_CLAMP_MIN_B_CB, denorm_clamp.clamp_min_b_cb);
+}
+
+
+
+void mpc2_set_output_csc(
+               struct mpc *mpc,
+               int opp_id,
+               const uint16_t *regval,
+               enum mpc_output_csc_mode ocsc_mode)
+{
+       uint32_t cur_mode;
+       struct dcn20_mpc *mpc20 = TO_DCN20_MPC(mpc);
+       struct color_matrices_reg ocsc_regs;
+
+       if (ocsc_mode == MPC_OUTPUT_CSC_DISABLE) {
+               REG_SET(CSC_MODE[opp_id], 0, MPC_OCSC_MODE, ocsc_mode);
+               return;
+       }
+
+       if (regval == NULL) {
+               BREAK_TO_DEBUGGER();
+               return;
+       }
+
+       /* determine which CSC coefficients (A or B) we are using
+        * currently.  select the alternate set to double buffer
+        * the CSC update so CSC is updated on frame boundary
+        */
+       IX_REG_GET(MPC_OCSC_TEST_DEBUG_INDEX, MPC_OCSC_TEST_DEBUG_DATA,
+                                               MPC_OCSC_TEST_DEBUG_DATA_STATUS_IDX,
+                                               MPC_OCSC_TEST_DEBUG_DATA_OCSC_MODE, &cur_mode);
+
+       if (cur_mode != MPC_OUTPUT_CSC_COEF_A)
+               ocsc_mode = MPC_OUTPUT_CSC_COEF_A;
+       else
+               ocsc_mode = MPC_OUTPUT_CSC_COEF_B;
+
+       ocsc_regs.shifts.csc_c11 = mpc20->mpc_shift->MPC_OCSC_C11_A;
+       ocsc_regs.masks.csc_c11  = mpc20->mpc_mask->MPC_OCSC_C11_A;
+       ocsc_regs.shifts.csc_c12 = mpc20->mpc_shift->MPC_OCSC_C12_A;
+       ocsc_regs.masks.csc_c12 = mpc20->mpc_mask->MPC_OCSC_C12_A;
+
+       if (ocsc_mode == MPC_OUTPUT_CSC_COEF_A) {
+               ocsc_regs.csc_c11_c12 = REG(CSC_C11_C12_A[opp_id]);
+               ocsc_regs.csc_c33_c34 = REG(CSC_C33_C34_A[opp_id]);
+       } else {
+               ocsc_regs.csc_c11_c12 = REG(CSC_C11_C12_B[opp_id]);
+               ocsc_regs.csc_c33_c34 = REG(CSC_C33_C34_B[opp_id]);
+       }
+
+       cm_helper_program_color_matrices(
+                       mpc20->base.ctx,
+                       regval,
+                       &ocsc_regs);
+
+       REG_SET(CSC_MODE[opp_id], 0, MPC_OCSC_MODE, ocsc_mode);
+}
+
+void mpc2_set_ocsc_default(
+               struct mpc *mpc,
+               int opp_id,
+               enum dc_color_space color_space,
+               enum mpc_output_csc_mode ocsc_mode)
+{
+       uint32_t cur_mode;
+       struct dcn20_mpc *mpc20 = TO_DCN20_MPC(mpc);
+       uint32_t arr_size;
+       struct color_matrices_reg ocsc_regs;
+       const uint16_t *regval = NULL;
+
+       if (ocsc_mode == MPC_OUTPUT_CSC_DISABLE) {
+               REG_SET(CSC_MODE[opp_id], 0, MPC_OCSC_MODE, ocsc_mode);
+               return;
+       }
+
+       regval = find_color_matrix(color_space, &arr_size);
+
+       if (regval == NULL) {
+               BREAK_TO_DEBUGGER();
+               return;
+       }
+
+       /* determine which CSC coefficients (A or B) we are using
+        * currently.  select the alternate set to double buffer
+        * the CSC update so CSC is updated on frame boundary
+        */
+       IX_REG_GET(MPC_OCSC_TEST_DEBUG_INDEX, MPC_OCSC_TEST_DEBUG_DATA,
+                                               MPC_OCSC_TEST_DEBUG_DATA_STATUS_IDX,
+                                               MPC_OCSC_TEST_DEBUG_DATA_OCSC_MODE, &cur_mode);
+
+       if (cur_mode != MPC_OUTPUT_CSC_COEF_A)
+               ocsc_mode = MPC_OUTPUT_CSC_COEF_A;
+       else
+               ocsc_mode = MPC_OUTPUT_CSC_COEF_B;
+
+       ocsc_regs.shifts.csc_c11 = mpc20->mpc_shift->MPC_OCSC_C11_A;
+       ocsc_regs.masks.csc_c11  = mpc20->mpc_mask->MPC_OCSC_C11_A;
+       ocsc_regs.shifts.csc_c12 = mpc20->mpc_shift->MPC_OCSC_C12_A;
+       ocsc_regs.masks.csc_c12 = mpc20->mpc_mask->MPC_OCSC_C12_A;
+
+
+       if (ocsc_mode == MPC_OUTPUT_CSC_COEF_A) {
+               ocsc_regs.csc_c11_c12 = REG(CSC_C11_C12_A[opp_id]);
+               ocsc_regs.csc_c33_c34 = REG(CSC_C33_C34_A[opp_id]);
+       } else {
+               ocsc_regs.csc_c11_c12 = REG(CSC_C11_C12_B[opp_id]);
+               ocsc_regs.csc_c33_c34 = REG(CSC_C33_C34_B[opp_id]);
+       }
+
+       cm_helper_program_color_matrices(
+                       mpc20->base.ctx,
+                       regval,
+                       &ocsc_regs);
+
+       REG_SET(CSC_MODE[opp_id], 0, MPC_OCSC_MODE, ocsc_mode);
+}
+
+static void mpc2_ogam_get_reg_field(
+               struct mpc *mpc,
+               struct xfer_func_reg *reg)
+{
+       struct dcn20_mpc *mpc20 = TO_DCN20_MPC(mpc);
+
+       reg->shifts.exp_region0_lut_offset = mpc20->mpc_shift->MPCC_OGAM_RAMA_EXP_REGION0_LUT_OFFSET;
+       reg->masks.exp_region0_lut_offset = mpc20->mpc_mask->MPCC_OGAM_RAMA_EXP_REGION0_LUT_OFFSET;
+       reg->shifts.exp_region0_num_segments = mpc20->mpc_shift->MPCC_OGAM_RAMA_EXP_REGION0_NUM_SEGMENTS;
+       reg->masks.exp_region0_num_segments = mpc20->mpc_mask->MPCC_OGAM_RAMA_EXP_REGION0_NUM_SEGMENTS;
+       reg->shifts.exp_region1_lut_offset = mpc20->mpc_shift->MPCC_OGAM_RAMA_EXP_REGION1_LUT_OFFSET;
+       reg->masks.exp_region1_lut_offset = mpc20->mpc_mask->MPCC_OGAM_RAMA_EXP_REGION1_LUT_OFFSET;
+       reg->shifts.exp_region1_num_segments = mpc20->mpc_shift->MPCC_OGAM_RAMA_EXP_REGION1_NUM_SEGMENTS;
+       reg->masks.exp_region1_num_segments = mpc20->mpc_mask->MPCC_OGAM_RAMA_EXP_REGION1_NUM_SEGMENTS;
+       reg->shifts.field_region_end = mpc20->mpc_shift->MPCC_OGAM_RAMA_EXP_REGION_END_B;
+       reg->masks.field_region_end = mpc20->mpc_mask->MPCC_OGAM_RAMA_EXP_REGION_END_B;
+       reg->shifts.field_region_end_slope = mpc20->mpc_shift->MPCC_OGAM_RAMA_EXP_REGION_END_SLOPE_B;
+       reg->masks.field_region_end_slope = mpc20->mpc_mask->MPCC_OGAM_RAMA_EXP_REGION_END_SLOPE_B;
+       reg->shifts.field_region_end_base = mpc20->mpc_shift->MPCC_OGAM_RAMA_EXP_REGION_END_BASE_B;
+       reg->masks.field_region_end_base = mpc20->mpc_mask->MPCC_OGAM_RAMA_EXP_REGION_END_BASE_B;
+       reg->shifts.field_region_linear_slope = mpc20->mpc_shift->MPCC_OGAM_RAMA_EXP_REGION_LINEAR_SLOPE_B;
+       reg->masks.field_region_linear_slope = mpc20->mpc_mask->MPCC_OGAM_RAMA_EXP_REGION_LINEAR_SLOPE_B;
+       reg->shifts.exp_region_start = mpc20->mpc_shift->MPCC_OGAM_RAMA_EXP_REGION_START_B;
+       reg->masks.exp_region_start = mpc20->mpc_mask->MPCC_OGAM_RAMA_EXP_REGION_START_B;
+       reg->shifts.exp_resion_start_segment = mpc20->mpc_shift->MPCC_OGAM_RAMA_EXP_REGION_START_SEGMENT_B;
+       reg->masks.exp_resion_start_segment = mpc20->mpc_mask->MPCC_OGAM_RAMA_EXP_REGION_START_SEGMENT_B;
+}
+
+void mpc20_power_on_ogam_lut(
+               struct mpc *mpc, int mpcc_id,
+               bool power_on)
+{
+       struct dcn20_mpc *mpc20 = TO_DCN20_MPC(mpc);
+
+       REG_SET(MPCC_MEM_PWR_CTRL[mpcc_id], 0,
+                       MPCC_OGAM_MEM_PWR_DIS, power_on == true ? 1:0);
+
+}
+
+static void mpc20_configure_ogam_lut(
+               struct mpc *mpc, int mpcc_id,
+               bool is_ram_a)
+{
+       struct dcn20_mpc *mpc20 = TO_DCN20_MPC(mpc);
+
+       REG_UPDATE_2(MPCC_OGAM_LUT_RAM_CONTROL[mpcc_id],
+                       MPCC_OGAM_LUT_WRITE_EN_MASK, 7,
+                       MPCC_OGAM_LUT_RAM_SEL, is_ram_a == true ? 0:1);
+
+       REG_SET(MPCC_OGAM_LUT_INDEX[mpcc_id], 0, MPCC_OGAM_LUT_INDEX, 0);
+}
+
+static enum dc_lut_mode mpc20_get_ogam_current(struct mpc *mpc, int mpcc_id)
+{
+       enum dc_lut_mode mode;
+       uint32_t state_mode;
+       struct dcn20_mpc *mpc20 = TO_DCN20_MPC(mpc);
+
+       REG_GET(MPCC_OGAM_LUT_RAM_CONTROL[mpcc_id], MPCC_OGAM_CONFIG_STATUS, &state_mode);
+
+       switch (state_mode) {
+       case 0:
+               mode = LUT_BYPASS;
+               break;
+       case 1:
+               mode = LUT_RAM_A;
+               break;
+       case 2:
+               mode = LUT_RAM_B;
+               break;
+       default:
+               mode = LUT_BYPASS;
+               break;
+       }
+
+       return mode;
+}
+
+static void mpc2_program_lutb(struct mpc *mpc, int mpcc_id,
+                       const struct pwl_params *params)
+{
+       struct dcn20_mpc *mpc20 = TO_DCN20_MPC(mpc);
+       struct xfer_func_reg gam_regs;
+
+       mpc2_ogam_get_reg_field(mpc, &gam_regs);
+
+       gam_regs.start_cntl_b = REG(MPCC_OGAM_RAMB_START_CNTL_B[mpcc_id]);
+       gam_regs.start_cntl_g = REG(MPCC_OGAM_RAMB_START_CNTL_G[mpcc_id]);
+       gam_regs.start_cntl_r = REG(MPCC_OGAM_RAMB_START_CNTL_R[mpcc_id]);
+       gam_regs.start_slope_cntl_b = REG(MPCC_OGAM_RAMB_SLOPE_CNTL_B[mpcc_id]);
+       gam_regs.start_slope_cntl_g = REG(MPCC_OGAM_RAMB_SLOPE_CNTL_G[mpcc_id]);
+       gam_regs.start_slope_cntl_r = REG(MPCC_OGAM_RAMB_SLOPE_CNTL_R[mpcc_id]);
+       gam_regs.start_end_cntl1_b = REG(MPCC_OGAM_RAMB_END_CNTL1_B[mpcc_id]);
+       gam_regs.start_end_cntl2_b = REG(MPCC_OGAM_RAMB_END_CNTL2_B[mpcc_id]);
+       gam_regs.start_end_cntl1_g = REG(MPCC_OGAM_RAMB_END_CNTL1_G[mpcc_id]);
+       gam_regs.start_end_cntl2_g = REG(MPCC_OGAM_RAMB_END_CNTL2_G[mpcc_id]);
+       gam_regs.start_end_cntl1_r = REG(MPCC_OGAM_RAMB_END_CNTL1_R[mpcc_id]);
+       gam_regs.start_end_cntl2_r = REG(MPCC_OGAM_RAMB_END_CNTL2_R[mpcc_id]);
+       gam_regs.region_start = REG(MPCC_OGAM_RAMB_REGION_0_1[mpcc_id]);
+       gam_regs.region_end = REG(MPCC_OGAM_RAMB_REGION_32_33[mpcc_id]);
+
+       cm_helper_program_xfer_func(mpc20->base.ctx, params, &gam_regs);
+
+}
+
+static void mpc2_program_luta(struct mpc *mpc, int mpcc_id,
+               const struct pwl_params *params)
+{
+       struct dcn20_mpc *mpc20 = TO_DCN20_MPC(mpc);
+       struct xfer_func_reg gam_regs;
+
+       mpc2_ogam_get_reg_field(mpc, &gam_regs);
+
+       gam_regs.start_cntl_b = REG(MPCC_OGAM_RAMA_START_CNTL_B[mpcc_id]);
+       gam_regs.start_cntl_g = REG(MPCC_OGAM_RAMA_START_CNTL_G[mpcc_id]);
+       gam_regs.start_cntl_r = REG(MPCC_OGAM_RAMA_START_CNTL_R[mpcc_id]);
+       gam_regs.start_slope_cntl_b = REG(MPCC_OGAM_RAMA_SLOPE_CNTL_B[mpcc_id]);
+       gam_regs.start_slope_cntl_g = REG(MPCC_OGAM_RAMA_SLOPE_CNTL_G[mpcc_id]);
+       gam_regs.start_slope_cntl_r = REG(MPCC_OGAM_RAMA_SLOPE_CNTL_R[mpcc_id]);
+       gam_regs.start_end_cntl1_b = REG(MPCC_OGAM_RAMA_END_CNTL1_B[mpcc_id]);
+       gam_regs.start_end_cntl2_b = REG(MPCC_OGAM_RAMA_END_CNTL2_B[mpcc_id]);
+       gam_regs.start_end_cntl1_g = REG(MPCC_OGAM_RAMA_END_CNTL1_G[mpcc_id]);
+       gam_regs.start_end_cntl2_g = REG(MPCC_OGAM_RAMA_END_CNTL2_G[mpcc_id]);
+       gam_regs.start_end_cntl1_r = REG(MPCC_OGAM_RAMA_END_CNTL1_R[mpcc_id]);
+       gam_regs.start_end_cntl2_r = REG(MPCC_OGAM_RAMA_END_CNTL2_R[mpcc_id]);
+       gam_regs.region_start = REG(MPCC_OGAM_RAMA_REGION_0_1[mpcc_id]);
+       gam_regs.region_end = REG(MPCC_OGAM_RAMA_REGION_32_33[mpcc_id]);
+
+       cm_helper_program_xfer_func(mpc20->base.ctx, params, &gam_regs);
+
+}
+
+static void mpc20_program_ogam_pwl(
+               struct mpc *mpc, int mpcc_id,
+               const struct pwl_result_data *rgb,
+               uint32_t num)
+{
+       uint32_t i;
+       struct dcn20_mpc *mpc20 = TO_DCN20_MPC(mpc);
+
+       PERF_TRACE();
+       REG_SEQ_START();
+
+       for (i = 0 ; i < num; i++) {
+               REG_SET(MPCC_OGAM_LUT_DATA[mpcc_id], 0, MPCC_OGAM_LUT_DATA, rgb[i].red_reg);
+               REG_SET(MPCC_OGAM_LUT_DATA[mpcc_id], 0, MPCC_OGAM_LUT_DATA, rgb[i].green_reg);
+               REG_SET(MPCC_OGAM_LUT_DATA[mpcc_id], 0, MPCC_OGAM_LUT_DATA, rgb[i].blue_reg);
+
+               REG_SET(MPCC_OGAM_LUT_DATA[mpcc_id], 0,
+                               MPCC_OGAM_LUT_DATA, rgb[i].delta_red_reg);
+               REG_SET(MPCC_OGAM_LUT_DATA[mpcc_id], 0,
+                               MPCC_OGAM_LUT_DATA, rgb[i].delta_green_reg);
+               REG_SET(MPCC_OGAM_LUT_DATA[mpcc_id], 0,
+                               MPCC_OGAM_LUT_DATA, rgb[i].delta_blue_reg);
+       }
+
+       REG_SEQ_SUBMIT();
+       PERF_TRACE();
+       REG_SEQ_WAIT_DONE();
+       PERF_TRACE();
+}
+
+static void apply_DEDCN20_305_wa(struct mpc *mpc, int mpcc_id,
+                                enum dc_lut_mode current_mode,
+                                enum dc_lut_mode next_mode)
+{
+       struct dcn20_mpc *mpc20 = TO_DCN20_MPC(mpc);
+
+       if (mpc->ctx->dc->debug.cm_in_bypass) {
+               REG_SET(MPCC_OGAM_MODE[mpcc_id], 0, MPCC_OGAM_MODE, 0);
+               return;
+       }
+
+       if (mpc->ctx->dc->work_arounds.dedcn20_305_wa == false) {
+               /*hw fixed in new review*/
+               return;
+       }
+       if (current_mode == LUT_BYPASS)
+               /*this will only work if OTG is locked.
+                *if we were to support OTG unlock case,
+                *the workaround will be more complex
+                */
+               REG_SET(MPCC_OGAM_MODE[mpcc_id], 0, MPCC_OGAM_MODE,
+                       next_mode == LUT_RAM_A ? 1:2);
+}
+
+void mpc2_set_output_gamma(
+               struct mpc *mpc,
+               int mpcc_id,
+               const struct pwl_params *params)
+{
+       enum dc_lut_mode current_mode;
+       enum dc_lut_mode next_mode;
+       struct dcn20_mpc *mpc20 = TO_DCN20_MPC(mpc);
+
+       if (mpc->ctx->dc->debug.cm_in_bypass) {
+               REG_SET(MPCC_OGAM_MODE[mpcc_id], 0, MPCC_OGAM_MODE, 0);
+               return;
+       }
+
+       if (params == NULL) {
+               REG_SET(MPCC_OGAM_MODE[mpcc_id], 0, MPCC_OGAM_MODE, 0);
+               return;
+       }
+
+       current_mode = mpc20_get_ogam_current(mpc, mpcc_id);
+       if (current_mode == LUT_BYPASS || current_mode == LUT_RAM_A)
+               next_mode = LUT_RAM_B;
+       else
+               next_mode = LUT_RAM_A;
+
+       mpc20_power_on_ogam_lut(mpc, mpcc_id, true);
+       mpc20_configure_ogam_lut(mpc, mpcc_id, next_mode == LUT_RAM_A);
+
+       if (next_mode == LUT_RAM_A)
+               mpc2_program_luta(mpc, mpcc_id, params);
+       else
+               mpc2_program_lutb(mpc, mpcc_id, params);
+
+       apply_DEDCN20_305_wa(mpc, mpcc_id, current_mode, next_mode);
+
+       mpc20_program_ogam_pwl(
+                       mpc, mpcc_id, params->rgb_resulted, params->hw_points_num);
+
+       REG_SET(MPCC_OGAM_MODE[mpcc_id], 0, MPCC_OGAM_MODE,
+               next_mode == LUT_RAM_A ? 1:2);
+}
+void mpc2_assert_idle_mpcc(struct mpc *mpc, int id)
+{
+       struct dcn20_mpc *mpc20 = TO_DCN20_MPC(mpc);
+       unsigned int mpc_disabled;
+
+       ASSERT(!(mpc20->mpcc_in_use_mask & 1 << id));
+       REG_GET(MPCC_STATUS[id], MPCC_DISABLED, &mpc_disabled);
+       if (mpc_disabled)
+               return;
+
+       REG_WAIT(MPCC_STATUS[id],
+                       MPCC_IDLE, 1,
+                       1, 100000);
+}
+
+void mpc2_assert_mpcc_idle_before_connect(struct mpc *mpc, int mpcc_id)
+{
+       struct dcn20_mpc *mpc20 = TO_DCN20_MPC(mpc);
+       unsigned int top_sel, mpc_busy, mpc_idle, mpc_disabled;
+
+       REG_GET(MPCC_TOP_SEL[mpcc_id],
+                       MPCC_TOP_SEL, &top_sel);
+
+       REG_GET_3(MPCC_STATUS[mpcc_id],
+                       MPCC_BUSY, &mpc_busy,
+                       MPCC_IDLE, &mpc_idle,
+                       MPCC_DISABLED, &mpc_disabled);
+
+       if (top_sel == 0xf) {
+               ASSERT(!mpc_busy);
+               ASSERT(mpc_idle);
+               ASSERT(mpc_disabled);
+       } else {
+               ASSERT(!mpc_disabled);
+               ASSERT(!mpc_idle);
+       }
+}
+
+static void mpc2_init_mpcc(struct mpcc *mpcc, int mpcc_inst)
+{
+       mpcc->mpcc_id = mpcc_inst;
+       mpcc->dpp_id = 0xf;
+       mpcc->mpcc_bot = NULL;
+       mpcc->blnd_cfg.overlap_only = false;
+       mpcc->blnd_cfg.global_alpha = 0xff;
+       mpcc->blnd_cfg.global_gain = 0xff;
+       mpcc->blnd_cfg.background_color_bpc = 4;
+       mpcc->blnd_cfg.bottom_gain_mode = 0;
+       mpcc->blnd_cfg.top_gain = 0x1f000;
+       mpcc->blnd_cfg.bottom_inside_gain = 0x1f000;
+       mpcc->blnd_cfg.bottom_outside_gain = 0x1f000;
+       mpcc->sm_cfg.enable = false;
+}
+
+static struct mpcc *mpc2_get_mpcc_for_dpp(struct mpc_tree *tree, int dpp_id)
+{
+       struct mpcc *tmp_mpcc = tree->opp_list;
+
+       while (tmp_mpcc != NULL) {
+               if (tmp_mpcc->dpp_id == 0xf || tmp_mpcc->dpp_id == dpp_id)
+                       return tmp_mpcc;
+
+               /* avoid circular linked list */
+               ASSERT(tmp_mpcc != tmp_mpcc->mpcc_bot);
+               if (tmp_mpcc == tmp_mpcc->mpcc_bot)
+                       break;
+
+               tmp_mpcc = tmp_mpcc->mpcc_bot;
+       }
+       return NULL;
+}
+
+static void mpc2_read_mpcc_state(
+               struct mpc *mpc,
+               int mpcc_inst,
+               struct mpcc_state *s)
+{
+       struct dcn20_mpc *mpc20 = TO_DCN20_MPC(mpc);
+
+       REG_GET(MPCC_OPP_ID[mpcc_inst], MPCC_OPP_ID, &s->opp_id);
+       REG_GET(MPCC_TOP_SEL[mpcc_inst], MPCC_TOP_SEL, &s->dpp_id);
+       REG_GET(MPCC_BOT_SEL[mpcc_inst], MPCC_BOT_SEL, &s->bot_mpcc_id);
+       REG_GET_4(MPCC_CONTROL[mpcc_inst], MPCC_MODE, &s->mode,
+                       MPCC_ALPHA_BLND_MODE, &s->alpha_mode,
+                       MPCC_ALPHA_MULTIPLIED_MODE, &s->pre_multiplied_alpha,
+                       MPCC_BLND_ACTIVE_OVERLAP_ONLY, &s->overlap_only);
+       REG_GET_2(MPCC_STATUS[mpcc_inst], MPCC_IDLE, &s->idle,
+                       MPCC_BUSY, &s->busy);
+
+       /* Gamma block state */
+       REG_GET(MPCC_OGAM_LUT_RAM_CONTROL[mpcc_inst],
+               MPCC_OGAM_CONFIG_STATUS, &s->rgam_mode);
+}
+
+static const struct mpc_funcs dcn20_mpc_funcs = {
+       .read_mpcc_state = mpc2_read_mpcc_state,
+       .insert_plane = mpc1_insert_plane,
+       .remove_mpcc = mpc1_remove_mpcc,
+       .mpc_init = mpc1_mpc_init,
+       .mpc_init_single_inst = mpc1_mpc_init_single_inst,
+       .update_blending = mpc2_update_blending,
+       .cursor_lock = mpc1_cursor_lock,
+       .get_mpcc_for_dpp = mpc2_get_mpcc_for_dpp,
+       .wait_for_idle = mpc2_assert_idle_mpcc,
+       .assert_mpcc_idle_before_connect = mpc2_assert_mpcc_idle_before_connect,
+       .init_mpcc_list_from_hw = mpc1_init_mpcc_list_from_hw,
+       .set_denorm = mpc2_set_denorm,
+       .set_denorm_clamp = mpc2_set_denorm_clamp,
+       .set_output_csc = mpc2_set_output_csc,
+       .set_ocsc_default = mpc2_set_ocsc_default,
+       .set_output_gamma = mpc2_set_output_gamma,
+       .power_on_mpc_mem_pwr = mpc20_power_on_ogam_lut,
+       .get_mpc_out_mux = mpc1_get_mpc_out_mux,
+       .set_bg_color = mpc1_set_bg_color,
+};
+
+void dcn20_mpc_construct(struct dcn20_mpc *mpc20,
+       struct dc_context *ctx,
+       const struct dcn20_mpc_registers *mpc_regs,
+       const struct dcn20_mpc_shift *mpc_shift,
+       const struct dcn20_mpc_mask *mpc_mask,
+       int num_mpcc)
+{
+       int i;
+
+       mpc20->base.ctx = ctx;
+
+       mpc20->base.funcs = &dcn20_mpc_funcs;
+
+       mpc20->mpc_regs = mpc_regs;
+       mpc20->mpc_shift = mpc_shift;
+       mpc20->mpc_mask = mpc_mask;
+
+       mpc20->mpcc_in_use_mask = 0;
+       mpc20->num_mpcc = num_mpcc;
+
+       for (i = 0; i < MAX_MPCC; i++)
+               mpc2_init_mpcc(&mpc20->base.mpcc_array[i], i);
+}
+
diff --git a/drivers/gpu/drm/amd/display/dc/mpc/dcn20/dcn20_mpc.h b/drivers/gpu/drm/amd/display/dc/mpc/dcn20/dcn20_mpc.h
new file mode 100644 (file)
index 0000000..496658f
--- /dev/null
@@ -0,0 +1,312 @@
+/* Copyright 2012-15 Advanced Micro Devices, Inc.
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining a
+ * copy of this software and associated documentation files (the "Software"),
+ * to deal in the Software without restriction, including without limitation
+ * the rights to use, copy, modify, merge, publish, distribute, sublicense,
+ * and/or sell copies of the Software, and to permit persons to whom the
+ * Software is furnished to do so, subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be included in
+ * all copies or substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
+ * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
+ * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
+ * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
+ * OTHER DEALINGS IN THE SOFTWARE.
+ *
+ * Authors: AMD
+ *
+ */
+
+#ifndef __DC_MPCC_DCN20_H__
+#define __DC_MPCC_DCN20_H__
+
+#include "dcn10/dcn10_mpc.h"
+
+#define TO_DCN20_MPC(mpc_base) \
+       container_of(mpc_base, struct dcn20_mpc, base)
+
+#define MPC_REG_LIST_DCN2_0(inst)\
+       MPC_COMMON_REG_LIST_DCN1_0(inst),\
+       SRII(MPCC_TOP_GAIN, MPCC, inst),\
+       SRII(MPCC_BOT_GAIN_INSIDE, MPCC, inst),\
+       SRII(MPCC_BOT_GAIN_OUTSIDE, MPCC, inst),\
+       SRII(MPCC_OGAM_RAMA_START_CNTL_B, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMA_START_CNTL_G, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMA_START_CNTL_R, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMA_SLOPE_CNTL_B, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMA_SLOPE_CNTL_G, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMA_SLOPE_CNTL_R, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMA_END_CNTL1_B, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMA_END_CNTL2_B, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMA_END_CNTL1_G, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMA_END_CNTL2_G, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMA_END_CNTL1_R, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMA_END_CNTL2_R, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMA_REGION_0_1, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMA_REGION_32_33, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMB_START_CNTL_B, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMB_START_CNTL_G, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMB_START_CNTL_R, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMB_SLOPE_CNTL_B, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMB_SLOPE_CNTL_G, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMB_SLOPE_CNTL_R, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMB_END_CNTL1_B, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMB_END_CNTL2_B, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMB_END_CNTL1_G, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMB_END_CNTL2_G, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMB_END_CNTL1_R, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMB_END_CNTL2_R, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMB_REGION_0_1, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMB_REGION_32_33, MPCC_OGAM, inst),\
+       SRII(MPCC_MEM_PWR_CTRL, MPCC, inst),\
+       SRII(MPCC_OGAM_LUT_INDEX, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_LUT_RAM_CONTROL, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_LUT_DATA, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_MODE, MPCC_OGAM, inst)
+
+#define MPC_OUT_MUX_REG_LIST_DCN2_0(inst) \
+       MPC_OUT_MUX_COMMON_REG_LIST_DCN1_0(inst),\
+       SRII(CSC_MODE, MPC_OUT, inst),\
+       SRII(CSC_C11_C12_A, MPC_OUT, inst),\
+       SRII(CSC_C33_C34_A, MPC_OUT, inst),\
+       SRII(CSC_C11_C12_B, MPC_OUT, inst),\
+       SRII(CSC_C33_C34_B, MPC_OUT, inst),\
+       SRII(DENORM_CONTROL, MPC_OUT, inst),\
+       SRII(DENORM_CLAMP_G_Y, MPC_OUT, inst),\
+       SRII(DENORM_CLAMP_B_CB, MPC_OUT, inst)
+
+#define MPC_DBG_REG_LIST_DCN2_0() \
+       SR(MPC_OCSC_TEST_DEBUG_DATA),\
+       SR(MPC_OCSC_TEST_DEBUG_INDEX)
+
+#define MPC_REG_VARIABLE_LIST_DCN2_0 \
+       MPC_COMMON_REG_VARIABLE_LIST \
+       uint32_t MPCC_TOP_GAIN[MAX_MPCC]; \
+       uint32_t MPCC_BOT_GAIN_INSIDE[MAX_MPCC]; \
+       uint32_t MPCC_BOT_GAIN_OUTSIDE[MAX_MPCC]; \
+       uint32_t MPCC_OGAM_RAMA_START_CNTL_B[MAX_MPCC]; \
+       uint32_t MPCC_OGAM_RAMA_START_CNTL_G[MAX_MPCC]; \
+       uint32_t MPCC_OGAM_RAMA_START_CNTL_R[MAX_MPCC]; \
+       uint32_t MPCC_OGAM_RAMA_SLOPE_CNTL_B[MAX_MPCC]; \
+       uint32_t MPCC_OGAM_RAMA_SLOPE_CNTL_G[MAX_MPCC]; \
+       uint32_t MPCC_OGAM_RAMA_SLOPE_CNTL_R[MAX_MPCC]; \
+       uint32_t MPCC_OGAM_RAMA_END_CNTL1_B[MAX_MPCC]; \
+       uint32_t MPCC_OGAM_RAMA_END_CNTL2_B[MAX_MPCC]; \
+       uint32_t MPCC_OGAM_RAMA_END_CNTL1_G[MAX_MPCC]; \
+       uint32_t MPCC_OGAM_RAMA_END_CNTL2_G[MAX_MPCC]; \
+       uint32_t MPCC_OGAM_RAMA_END_CNTL1_R[MAX_MPCC]; \
+       uint32_t MPCC_OGAM_RAMA_END_CNTL2_R[MAX_MPCC]; \
+       uint32_t MPCC_OGAM_RAMA_REGION_0_1[MAX_MPCC]; \
+       uint32_t MPCC_OGAM_RAMA_REGION_32_33[MAX_MPCC]; \
+       uint32_t MPCC_OGAM_RAMB_START_CNTL_B[MAX_MPCC]; \
+       uint32_t MPCC_OGAM_RAMB_START_CNTL_G[MAX_MPCC]; \
+       uint32_t MPCC_OGAM_RAMB_START_CNTL_R[MAX_MPCC]; \
+       uint32_t MPCC_OGAM_RAMB_SLOPE_CNTL_B[MAX_MPCC]; \
+       uint32_t MPCC_OGAM_RAMB_SLOPE_CNTL_G[MAX_MPCC]; \
+       uint32_t MPCC_OGAM_RAMB_SLOPE_CNTL_R[MAX_MPCC]; \
+       uint32_t MPCC_OGAM_RAMB_END_CNTL1_B[MAX_MPCC]; \
+       uint32_t MPCC_OGAM_RAMB_END_CNTL2_B[MAX_MPCC]; \
+       uint32_t MPCC_OGAM_RAMB_END_CNTL1_G[MAX_MPCC]; \
+       uint32_t MPCC_OGAM_RAMB_END_CNTL2_G[MAX_MPCC]; \
+       uint32_t MPCC_OGAM_RAMB_END_CNTL1_R[MAX_MPCC]; \
+       uint32_t MPCC_OGAM_RAMB_END_CNTL2_R[MAX_MPCC]; \
+       uint32_t MPCC_OGAM_RAMB_REGION_0_1[MAX_MPCC]; \
+       uint32_t MPCC_OGAM_RAMB_REGION_32_33[MAX_MPCC];\
+       uint32_t MPCC_MEM_PWR_CTRL[MAX_MPCC];\
+       uint32_t MPCC_OGAM_LUT_INDEX[MAX_MPCC];\
+       uint32_t MPCC_OGAM_LUT_RAM_CONTROL[MAX_MPCC];\
+       uint32_t MPCC_OGAM_LUT_DATA[MAX_MPCC];\
+       uint32_t MPCC_OGAM_MODE[MAX_MPCC];\
+       uint32_t MPC_OCSC_TEST_DEBUG_DATA;\
+       uint32_t MPC_OCSC_TEST_DEBUG_INDEX;\
+       uint32_t CSC_MODE[MAX_OPP]; \
+       uint32_t CSC_C11_C12_A[MAX_OPP]; \
+       uint32_t CSC_C33_C34_A[MAX_OPP]; \
+       uint32_t CSC_C11_C12_B[MAX_OPP]; \
+       uint32_t CSC_C33_C34_B[MAX_OPP]; \
+       uint32_t DENORM_CONTROL[MAX_OPP]; \
+       uint32_t DENORM_CLAMP_G_Y[MAX_OPP]; \
+       uint32_t DENORM_CLAMP_B_CB[MAX_OPP];
+
+#define MPC_COMMON_MASK_SH_LIST_DCN2_0(mask_sh) \
+       MPC_COMMON_MASK_SH_LIST_DCN1_0(mask_sh),\
+       SF(MPCC0_MPCC_CONTROL, MPCC_BG_BPC, mask_sh),\
+       SF(MPCC0_MPCC_CONTROL, MPCC_BOT_GAIN_MODE, mask_sh),\
+       SF(MPCC0_MPCC_TOP_GAIN, MPCC_TOP_GAIN, mask_sh),\
+       SF(MPCC0_MPCC_BOT_GAIN_INSIDE, MPCC_BOT_GAIN_INSIDE, mask_sh),\
+       SF(MPCC0_MPCC_BOT_GAIN_OUTSIDE, MPCC_BOT_GAIN_OUTSIDE, mask_sh),\
+       SF(MPC_OCSC_TEST_DEBUG_INDEX, MPC_OCSC_TEST_DEBUG_INDEX, mask_sh),\
+       SF(MPC_OUT0_CSC_MODE, MPC_OCSC_MODE, mask_sh),\
+       SF(MPC_OUT0_CSC_C11_C12_A, MPC_OCSC_C11_A, mask_sh),\
+       SF(MPC_OUT0_CSC_C11_C12_A, MPC_OCSC_C12_A, mask_sh),\
+       SF(MPCC0_MPCC_STATUS, MPCC_DISABLED, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_REGION_0_1, MPCC_OGAM_RAMA_EXP_REGION0_LUT_OFFSET, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_REGION_0_1, MPCC_OGAM_RAMA_EXP_REGION0_NUM_SEGMENTS, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_REGION_0_1, MPCC_OGAM_RAMA_EXP_REGION1_LUT_OFFSET, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_REGION_0_1, MPCC_OGAM_RAMA_EXP_REGION1_NUM_SEGMENTS, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_END_CNTL1_B, MPCC_OGAM_RAMA_EXP_REGION_END_B, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_END_CNTL2_B, MPCC_OGAM_RAMA_EXP_REGION_END_SLOPE_B, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_END_CNTL2_B, MPCC_OGAM_RAMA_EXP_REGION_END_BASE_B, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_SLOPE_CNTL_B, MPCC_OGAM_RAMA_EXP_REGION_LINEAR_SLOPE_B, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_START_CNTL_B, MPCC_OGAM_RAMA_EXP_REGION_START_B, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_START_CNTL_B, MPCC_OGAM_RAMA_EXP_REGION_START_SEGMENT_B, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMB_REGION_0_1, MPCC_OGAM_RAMB_EXP_REGION0_LUT_OFFSET, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMB_REGION_0_1, MPCC_OGAM_RAMB_EXP_REGION0_NUM_SEGMENTS, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMB_REGION_0_1, MPCC_OGAM_RAMB_EXP_REGION1_LUT_OFFSET, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMB_REGION_0_1, MPCC_OGAM_RAMB_EXP_REGION1_NUM_SEGMENTS, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMB_END_CNTL1_B, MPCC_OGAM_RAMB_EXP_REGION_END_B, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMB_END_CNTL2_B, MPCC_OGAM_RAMB_EXP_REGION_END_SLOPE_B, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMB_END_CNTL2_B, MPCC_OGAM_RAMB_EXP_REGION_END_BASE_B, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMB_SLOPE_CNTL_B, MPCC_OGAM_RAMB_EXP_REGION_LINEAR_SLOPE_B, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMB_START_CNTL_B, MPCC_OGAM_RAMB_EXP_REGION_START_B, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMB_START_CNTL_B, MPCC_OGAM_RAMB_EXP_REGION_START_SEGMENT_B, mask_sh),\
+       SF(MPCC0_MPCC_MEM_PWR_CTRL, MPCC_OGAM_MEM_PWR_FORCE, mask_sh),\
+       SF(MPCC0_MPCC_MEM_PWR_CTRL, MPCC_OGAM_MEM_PWR_DIS, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_LUT_INDEX, MPCC_OGAM_LUT_INDEX, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_LUT_RAM_CONTROL, MPCC_OGAM_LUT_WRITE_EN_MASK, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_LUT_RAM_CONTROL, MPCC_OGAM_LUT_RAM_SEL, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_LUT_RAM_CONTROL, MPCC_OGAM_CONFIG_STATUS, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_LUT_DATA, MPCC_OGAM_LUT_DATA, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_MODE, MPCC_OGAM_MODE, mask_sh),\
+       SF(MPC_OUT0_DENORM_CONTROL, MPC_OUT_DENORM_MODE, mask_sh),\
+       SF(MPC_OUT0_DENORM_CONTROL, MPC_OUT_DENORM_CLAMP_MAX_R_CR, mask_sh),\
+       SF(MPC_OUT0_DENORM_CONTROL, MPC_OUT_DENORM_CLAMP_MIN_R_CR, mask_sh),\
+       SF(MPC_OUT0_DENORM_CLAMP_G_Y, MPC_OUT_DENORM_CLAMP_MAX_G_Y, mask_sh),\
+       SF(MPC_OUT0_DENORM_CLAMP_G_Y, MPC_OUT_DENORM_CLAMP_MIN_G_Y, mask_sh),\
+       SF(MPC_OUT0_DENORM_CLAMP_B_CB, MPC_OUT_DENORM_CLAMP_MAX_B_CB, mask_sh),\
+       SF(MPC_OUT0_DENORM_CLAMP_B_CB, MPC_OUT_DENORM_CLAMP_MIN_B_CB, mask_sh),\
+       SF(CUR_VUPDATE_LOCK_SET0, CUR_VUPDATE_LOCK_SET, mask_sh)
+
+/*
+ *     DCN2 MPC_OCSC debug status register:
+ *
+ *             Status index including current OCSC Mode is 1
+ *                     OCSC Mode: [1..0]
+ */
+#define MPC_OCSC_TEST_DEBUG_DATA_STATUS_IDX 1
+
+#define MPC_DEBUG_REG_LIST_SH_DCN20 \
+       .MPC_OCSC_TEST_DEBUG_DATA_OCSC_MODE = 0
+
+#define MPC_DEBUG_REG_LIST_MASK_DCN20 \
+       .MPC_OCSC_TEST_DEBUG_DATA_OCSC_MODE = 0x3
+
+#define MPC_REG_FIELD_LIST_DCN2_0(type) \
+       MPC_REG_FIELD_LIST(type)\
+       type MPCC_BG_BPC;\
+       type MPCC_BOT_GAIN_MODE;\
+       type MPCC_TOP_GAIN;\
+       type MPCC_BOT_GAIN_INSIDE;\
+       type MPCC_BOT_GAIN_OUTSIDE;\
+       type MPC_OCSC_TEST_DEBUG_DATA_OCSC_MODE;\
+       type MPC_OCSC_TEST_DEBUG_INDEX;\
+       type MPC_OCSC_MODE;\
+       type MPC_OCSC_C11_A;\
+       type MPC_OCSC_C12_A;\
+       type MPCC_OGAM_RAMA_EXP_REGION0_LUT_OFFSET;\
+       type MPCC_OGAM_RAMA_EXP_REGION0_NUM_SEGMENTS;\
+       type MPCC_OGAM_RAMA_EXP_REGION1_LUT_OFFSET;\
+       type MPCC_OGAM_RAMA_EXP_REGION1_NUM_SEGMENTS;\
+       type MPCC_OGAM_RAMA_EXP_REGION_END_B;\
+       type MPCC_OGAM_RAMA_EXP_REGION_END_SLOPE_B;\
+       type MPCC_OGAM_RAMA_EXP_REGION_END_BASE_B;\
+       type MPCC_OGAM_RAMA_EXP_REGION_LINEAR_SLOPE_B;\
+       type MPCC_OGAM_RAMA_EXP_REGION_START_B;\
+       type MPCC_OGAM_RAMA_EXP_REGION_START_SEGMENT_B;\
+       type MPCC_OGAM_RAMB_EXP_REGION0_LUT_OFFSET;\
+       type MPCC_OGAM_RAMB_EXP_REGION0_NUM_SEGMENTS;\
+       type MPCC_OGAM_RAMB_EXP_REGION1_LUT_OFFSET;\
+       type MPCC_OGAM_RAMB_EXP_REGION1_NUM_SEGMENTS;\
+       type MPCC_OGAM_RAMB_EXP_REGION_END_B;\
+       type MPCC_OGAM_RAMB_EXP_REGION_END_SLOPE_B;\
+       type MPCC_OGAM_RAMB_EXP_REGION_END_BASE_B;\
+       type MPCC_OGAM_RAMB_EXP_REGION_LINEAR_SLOPE_B;\
+       type MPCC_OGAM_RAMB_EXP_REGION_START_B;\
+       type MPCC_OGAM_RAMB_EXP_REGION_START_SEGMENT_B;\
+       type MPCC_OGAM_MEM_PWR_FORCE;\
+       type MPCC_OGAM_LUT_INDEX;\
+       type MPCC_OGAM_LUT_WRITE_EN_MASK;\
+       type MPCC_OGAM_LUT_RAM_SEL;\
+       type MPCC_OGAM_CONFIG_STATUS;\
+       type MPCC_OGAM_LUT_DATA;\
+       type MPCC_OGAM_MODE;\
+       type MPC_OUT_DENORM_MODE;\
+       type MPC_OUT_DENORM_CLAMP_MAX_R_CR;\
+       type MPC_OUT_DENORM_CLAMP_MIN_R_CR;\
+       type MPC_OUT_DENORM_CLAMP_MAX_G_Y;\
+       type MPC_OUT_DENORM_CLAMP_MIN_G_Y;\
+       type MPC_OUT_DENORM_CLAMP_MAX_B_CB;\
+       type MPC_OUT_DENORM_CLAMP_MIN_B_CB;\
+       type MPCC_DISABLED;\
+       type MPCC_OGAM_MEM_PWR_DIS;
+
+struct dcn20_mpc_registers {
+       MPC_REG_VARIABLE_LIST_DCN2_0
+};
+
+struct dcn20_mpc_shift {
+       MPC_REG_FIELD_LIST_DCN2_0(uint8_t)
+};
+
+struct dcn20_mpc_mask {
+       MPC_REG_FIELD_LIST_DCN2_0(uint32_t)
+};
+
+struct dcn20_mpc {
+       struct mpc base;
+
+       int mpcc_in_use_mask;
+       int num_mpcc;
+       const struct dcn20_mpc_registers *mpc_regs;
+       const struct dcn20_mpc_shift *mpc_shift;
+       const struct dcn20_mpc_mask *mpc_mask;
+};
+
+void dcn20_mpc_construct(struct dcn20_mpc *mpcc20,
+       struct dc_context *ctx,
+       const struct dcn20_mpc_registers *mpc_regs,
+       const struct dcn20_mpc_shift *mpc_shift,
+       const struct dcn20_mpc_mask *mpc_mask,
+       int num_mpcc);
+
+void mpc2_update_blending(
+       struct mpc *mpc,
+       struct mpcc_blnd_cfg *blnd_cfg,
+       int mpcc_id);
+
+void mpc2_set_denorm(
+       struct mpc *mpc,
+       int opp_id,
+       enum dc_color_depth output_depth);
+
+void mpc2_set_denorm_clamp(
+       struct mpc *mpc,
+       int opp_id,
+       struct mpc_denorm_clamp denorm_clamp);
+
+void mpc2_set_output_csc(
+       struct mpc *mpc,
+       int opp_id,
+       const uint16_t *regval,
+       enum mpc_output_csc_mode ocsc_mode);
+
+void mpc2_set_ocsc_default(
+       struct mpc *mpc,
+       int opp_id,
+       enum dc_color_space color_space,
+       enum mpc_output_csc_mode ocsc_mode);
+
+void mpc2_set_output_gamma(
+       struct mpc *mpc,
+       int mpcc_id,
+       const struct pwl_params *params);
+
+void mpc2_assert_idle_mpcc(struct mpc *mpc, int id);
+void mpc2_assert_mpcc_idle_before_connect(struct mpc *mpc, int mpcc_id);
+void mpc20_power_on_ogam_lut(struct mpc *mpc, int mpcc_id, bool power_on);
+#endif
diff --git a/drivers/gpu/drm/amd/display/dc/mpc/dcn30/dcn30_mpc.c b/drivers/gpu/drm/amd/display/dc/mpc/dcn30/dcn30_mpc.c
new file mode 100644 (file)
index 0000000..fe26fde
--- /dev/null
@@ -0,0 +1,1558 @@
+/*
+ * Copyright 2020 Advanced Micro Devices, Inc.
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining a
+ * copy of this software and associated documentation files (the "Software"),
+ * to deal in the Software without restriction, including without limitation
+ * the rights to use, copy, modify, merge, publish, distribute, sublicense,
+ * and/or sell copies of the Software, and to permit persons to whom the
+ * Software is furnished to do so, subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be included in
+ * all copies or substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
+ * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
+ * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
+ * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
+ * OTHER DEALINGS IN THE SOFTWARE.
+ *
+ * Authors: AMD
+ *
+ */
+
+#include "reg_helper.h"
+#include "dcn30_mpc.h"
+#include "dcn30/dcn30_cm_common.h"
+#include "basics/conversion.h"
+#include "dcn10/dcn10_cm_common.h"
+#include "dc.h"
+
+#define REG(reg)\
+       mpc30->mpc_regs->reg
+
+#define CTX \
+       mpc30->base.ctx
+
+#undef FN
+#define FN(reg_name, field_name) \
+       mpc30->mpc_shift->field_name, mpc30->mpc_mask->field_name
+
+
+#define NUM_ELEMENTS(a) (sizeof(a) / sizeof((a)[0]))
+
+
+void mpc3_mpc_init(struct mpc *mpc)
+{
+       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
+       int opp_id;
+
+       mpc1_mpc_init(mpc);
+
+       for (opp_id = 0; opp_id < MAX_OPP; opp_id++) {
+               if (REG(MUX[opp_id]))
+                       /* disable mpc out rate and flow control */
+                       REG_UPDATE_2(MUX[opp_id], MPC_OUT_RATE_CONTROL_DISABLE,
+                                       1, MPC_OUT_FLOW_CONTROL_COUNT, 0);
+       }
+}
+
+void mpc3_mpc_init_single_inst(struct mpc *mpc, unsigned int mpcc_id)
+{
+       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
+
+       mpc1_mpc_init_single_inst(mpc, mpcc_id);
+
+       /* assuming mpc out mux is connected to opp with the same index at this
+        * point in time (e.g. transitioning from vbios to driver)
+        */
+       if (mpcc_id < MAX_OPP && REG(MUX[mpcc_id]))
+               /* disable mpc out rate and flow control */
+               REG_UPDATE_2(MUX[mpcc_id], MPC_OUT_RATE_CONTROL_DISABLE,
+                               1, MPC_OUT_FLOW_CONTROL_COUNT, 0);
+}
+
+bool mpc3_is_dwb_idle(
+       struct mpc *mpc,
+       int dwb_id)
+{
+       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
+       unsigned int status;
+
+       REG_GET(DWB_MUX[dwb_id], MPC_DWB0_MUX_STATUS, &status);
+
+       if (status == 0xf)
+               return true;
+       else
+               return false;
+}
+
+void mpc3_set_dwb_mux(
+       struct mpc *mpc,
+       int dwb_id,
+       int mpcc_id)
+{
+       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
+
+       REG_SET(DWB_MUX[dwb_id], 0,
+               MPC_DWB0_MUX, mpcc_id);
+}
+
+void mpc3_disable_dwb_mux(
+       struct mpc *mpc,
+       int dwb_id)
+{
+       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
+
+       REG_SET(DWB_MUX[dwb_id], 0,
+               MPC_DWB0_MUX, 0xf);
+}
+
+enum dc_lut_mode mpc3_get_ogam_current(struct mpc *mpc, int mpcc_id)
+{
+       /*Contrary to DCN2 and DCN1 wherein a single status register field holds this info;
+        *in DCN3/3AG, we need to read two separate fields to retrieve the same info
+        */
+       enum dc_lut_mode mode;
+       uint32_t state_mode;
+       uint32_t state_ram_lut_in_use;
+       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
+
+       REG_GET_2(MPCC_OGAM_CONTROL[mpcc_id], MPCC_OGAM_MODE_CURRENT, &state_mode,
+                 MPCC_OGAM_SELECT_CURRENT, &state_ram_lut_in_use);
+
+       switch (state_mode) {
+       case 0:
+               mode = LUT_BYPASS;
+               break;
+       case 2:
+               switch (state_ram_lut_in_use) {
+               case 0:
+                       mode = LUT_RAM_A;
+                       break;
+               case 1:
+                       mode = LUT_RAM_B;
+                       break;
+               default:
+                       mode = LUT_BYPASS;
+                       break;
+               }
+               break;
+       default:
+               mode = LUT_BYPASS;
+               break;
+       }
+
+       return mode;
+}
+
+void mpc3_power_on_ogam_lut(
+               struct mpc *mpc, int mpcc_id,
+               bool power_on)
+{
+       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
+
+       /*
+        * Powering on: force memory active so the LUT can be updated.
+        * Powering off: allow entering memory low power mode
+        *
+        * Memory low power mode is controlled during MPC OGAM LUT init.
+        */
+       REG_UPDATE(MPCC_MEM_PWR_CTRL[mpcc_id],
+                  MPCC_OGAM_MEM_PWR_DIS, power_on != 0);
+
+       /* Wait for memory to be powered on - we won't be able to write to it otherwise. */
+       if (power_on)
+               REG_WAIT(MPCC_MEM_PWR_CTRL[mpcc_id], MPCC_OGAM_MEM_PWR_STATE, 0, 10, 10);
+}
+
+static void mpc3_configure_ogam_lut(
+               struct mpc *mpc, int mpcc_id,
+               bool is_ram_a)
+{
+       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
+
+       REG_UPDATE_2(MPCC_OGAM_LUT_CONTROL[mpcc_id],
+                       MPCC_OGAM_LUT_WRITE_COLOR_MASK, 7,
+                       MPCC_OGAM_LUT_HOST_SEL, is_ram_a == true ? 0:1);
+
+       REG_SET(MPCC_OGAM_LUT_INDEX[mpcc_id], 0, MPCC_OGAM_LUT_INDEX, 0);
+}
+
+static void mpc3_ogam_get_reg_field(
+               struct mpc *mpc,
+               struct dcn3_xfer_func_reg *reg)
+{
+       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
+
+       reg->shifts.field_region_start_base = mpc30->mpc_shift->MPCC_OGAM_RAMA_EXP_REGION_START_BASE_B;
+       reg->masks.field_region_start_base = mpc30->mpc_mask->MPCC_OGAM_RAMA_EXP_REGION_START_BASE_B;
+       reg->shifts.field_offset = mpc30->mpc_shift->MPCC_OGAM_RAMA_OFFSET_B;
+       reg->masks.field_offset = mpc30->mpc_mask->MPCC_OGAM_RAMA_OFFSET_B;
+
+       reg->shifts.exp_region0_lut_offset = mpc30->mpc_shift->MPCC_OGAM_RAMA_EXP_REGION0_LUT_OFFSET;
+       reg->masks.exp_region0_lut_offset = mpc30->mpc_mask->MPCC_OGAM_RAMA_EXP_REGION0_LUT_OFFSET;
+       reg->shifts.exp_region0_num_segments = mpc30->mpc_shift->MPCC_OGAM_RAMA_EXP_REGION0_NUM_SEGMENTS;
+       reg->masks.exp_region0_num_segments = mpc30->mpc_mask->MPCC_OGAM_RAMA_EXP_REGION0_NUM_SEGMENTS;
+       reg->shifts.exp_region1_lut_offset = mpc30->mpc_shift->MPCC_OGAM_RAMA_EXP_REGION1_LUT_OFFSET;
+       reg->masks.exp_region1_lut_offset = mpc30->mpc_mask->MPCC_OGAM_RAMA_EXP_REGION1_LUT_OFFSET;
+       reg->shifts.exp_region1_num_segments = mpc30->mpc_shift->MPCC_OGAM_RAMA_EXP_REGION1_NUM_SEGMENTS;
+       reg->masks.exp_region1_num_segments = mpc30->mpc_mask->MPCC_OGAM_RAMA_EXP_REGION1_NUM_SEGMENTS;
+
+       reg->shifts.field_region_end = mpc30->mpc_shift->MPCC_OGAM_RAMA_EXP_REGION_END_B;
+       reg->masks.field_region_end = mpc30->mpc_mask->MPCC_OGAM_RAMA_EXP_REGION_END_B;
+       reg->shifts.field_region_end_slope = mpc30->mpc_shift->MPCC_OGAM_RAMA_EXP_REGION_END_SLOPE_B;
+       reg->masks.field_region_end_slope = mpc30->mpc_mask->MPCC_OGAM_RAMA_EXP_REGION_END_SLOPE_B;
+       reg->shifts.field_region_end_base = mpc30->mpc_shift->MPCC_OGAM_RAMA_EXP_REGION_END_BASE_B;
+       reg->masks.field_region_end_base = mpc30->mpc_mask->MPCC_OGAM_RAMA_EXP_REGION_END_BASE_B;
+       reg->shifts.field_region_linear_slope = mpc30->mpc_shift->MPCC_OGAM_RAMA_EXP_REGION_START_SLOPE_B;
+       reg->masks.field_region_linear_slope = mpc30->mpc_mask->MPCC_OGAM_RAMA_EXP_REGION_START_SLOPE_B;
+       reg->shifts.exp_region_start = mpc30->mpc_shift->MPCC_OGAM_RAMA_EXP_REGION_START_B;
+       reg->masks.exp_region_start = mpc30->mpc_mask->MPCC_OGAM_RAMA_EXP_REGION_START_B;
+       reg->shifts.exp_resion_start_segment = mpc30->mpc_shift->MPCC_OGAM_RAMA_EXP_REGION_START_SEGMENT_B;
+       reg->masks.exp_resion_start_segment = mpc30->mpc_mask->MPCC_OGAM_RAMA_EXP_REGION_START_SEGMENT_B;
+}
+
+static void mpc3_program_luta(struct mpc *mpc, int mpcc_id,
+               const struct pwl_params *params)
+{
+       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
+       struct dcn3_xfer_func_reg gam_regs;
+
+       mpc3_ogam_get_reg_field(mpc, &gam_regs);
+
+       gam_regs.start_cntl_b = REG(MPCC_OGAM_RAMA_START_CNTL_B[mpcc_id]);
+       gam_regs.start_cntl_g = REG(MPCC_OGAM_RAMA_START_CNTL_G[mpcc_id]);
+       gam_regs.start_cntl_r = REG(MPCC_OGAM_RAMA_START_CNTL_R[mpcc_id]);
+       gam_regs.start_slope_cntl_b = REG(MPCC_OGAM_RAMA_START_SLOPE_CNTL_B[mpcc_id]);
+       gam_regs.start_slope_cntl_g = REG(MPCC_OGAM_RAMA_START_SLOPE_CNTL_G[mpcc_id]);
+       gam_regs.start_slope_cntl_r = REG(MPCC_OGAM_RAMA_START_SLOPE_CNTL_R[mpcc_id]);
+       gam_regs.start_end_cntl1_b = REG(MPCC_OGAM_RAMA_END_CNTL1_B[mpcc_id]);
+       gam_regs.start_end_cntl2_b = REG(MPCC_OGAM_RAMA_END_CNTL2_B[mpcc_id]);
+       gam_regs.start_end_cntl1_g = REG(MPCC_OGAM_RAMA_END_CNTL1_G[mpcc_id]);
+       gam_regs.start_end_cntl2_g = REG(MPCC_OGAM_RAMA_END_CNTL2_G[mpcc_id]);
+       gam_regs.start_end_cntl1_r = REG(MPCC_OGAM_RAMA_END_CNTL1_R[mpcc_id]);
+       gam_regs.start_end_cntl2_r = REG(MPCC_OGAM_RAMA_END_CNTL2_R[mpcc_id]);
+       gam_regs.region_start = REG(MPCC_OGAM_RAMA_REGION_0_1[mpcc_id]);
+       gam_regs.region_end = REG(MPCC_OGAM_RAMA_REGION_32_33[mpcc_id]);
+       //New registers in DCN3AG/DCN OGAM block
+       gam_regs.offset_b =  REG(MPCC_OGAM_RAMA_OFFSET_B[mpcc_id]);
+       gam_regs.offset_g =  REG(MPCC_OGAM_RAMA_OFFSET_G[mpcc_id]);
+       gam_regs.offset_r =  REG(MPCC_OGAM_RAMA_OFFSET_R[mpcc_id]);
+       gam_regs.start_base_cntl_b = REG(MPCC_OGAM_RAMA_START_BASE_CNTL_B[mpcc_id]);
+       gam_regs.start_base_cntl_g = REG(MPCC_OGAM_RAMA_START_BASE_CNTL_G[mpcc_id]);
+       gam_regs.start_base_cntl_r = REG(MPCC_OGAM_RAMA_START_BASE_CNTL_R[mpcc_id]);
+
+       cm_helper_program_gamcor_xfer_func(mpc30->base.ctx, params, &gam_regs);
+}
+
+static void mpc3_program_lutb(struct mpc *mpc, int mpcc_id,
+               const struct pwl_params *params)
+{
+       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
+       struct dcn3_xfer_func_reg gam_regs;
+
+       mpc3_ogam_get_reg_field(mpc, &gam_regs);
+
+       gam_regs.start_cntl_b = REG(MPCC_OGAM_RAMB_START_CNTL_B[mpcc_id]);
+       gam_regs.start_cntl_g = REG(MPCC_OGAM_RAMB_START_CNTL_G[mpcc_id]);
+       gam_regs.start_cntl_r = REG(MPCC_OGAM_RAMB_START_CNTL_R[mpcc_id]);
+       gam_regs.start_slope_cntl_b = REG(MPCC_OGAM_RAMB_START_SLOPE_CNTL_B[mpcc_id]);
+       gam_regs.start_slope_cntl_g = REG(MPCC_OGAM_RAMB_START_SLOPE_CNTL_G[mpcc_id]);
+       gam_regs.start_slope_cntl_r = REG(MPCC_OGAM_RAMB_START_SLOPE_CNTL_R[mpcc_id]);
+       gam_regs.start_end_cntl1_b = REG(MPCC_OGAM_RAMB_END_CNTL1_B[mpcc_id]);
+       gam_regs.start_end_cntl2_b = REG(MPCC_OGAM_RAMB_END_CNTL2_B[mpcc_id]);
+       gam_regs.start_end_cntl1_g = REG(MPCC_OGAM_RAMB_END_CNTL1_G[mpcc_id]);
+       gam_regs.start_end_cntl2_g = REG(MPCC_OGAM_RAMB_END_CNTL2_G[mpcc_id]);
+       gam_regs.start_end_cntl1_r = REG(MPCC_OGAM_RAMB_END_CNTL1_R[mpcc_id]);
+       gam_regs.start_end_cntl2_r = REG(MPCC_OGAM_RAMB_END_CNTL2_R[mpcc_id]);
+       gam_regs.region_start = REG(MPCC_OGAM_RAMB_REGION_0_1[mpcc_id]);
+       gam_regs.region_end = REG(MPCC_OGAM_RAMB_REGION_32_33[mpcc_id]);
+       //New registers in DCN3AG/DCN OGAM block
+       gam_regs.offset_b =  REG(MPCC_OGAM_RAMB_OFFSET_B[mpcc_id]);
+       gam_regs.offset_g =  REG(MPCC_OGAM_RAMB_OFFSET_G[mpcc_id]);
+       gam_regs.offset_r =  REG(MPCC_OGAM_RAMB_OFFSET_R[mpcc_id]);
+       gam_regs.start_base_cntl_b = REG(MPCC_OGAM_RAMB_START_BASE_CNTL_B[mpcc_id]);
+       gam_regs.start_base_cntl_g = REG(MPCC_OGAM_RAMB_START_BASE_CNTL_G[mpcc_id]);
+       gam_regs.start_base_cntl_r = REG(MPCC_OGAM_RAMB_START_BASE_CNTL_R[mpcc_id]);
+
+       cm_helper_program_gamcor_xfer_func(mpc30->base.ctx, params, &gam_regs);
+}
+
+
+static void mpc3_program_ogam_pwl(
+               struct mpc *mpc, int mpcc_id,
+               const struct pwl_result_data *rgb,
+               uint32_t num)
+{
+       uint32_t i;
+       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
+
+       if (is_rgb_equal(rgb,  num)) {
+               for (i = 0 ; i < num; i++)
+                       REG_SET(MPCC_OGAM_LUT_DATA[mpcc_id], 0, MPCC_OGAM_LUT_DATA, rgb[i].red_reg);
+       } else {
+
+               REG_UPDATE(MPCC_OGAM_LUT_CONTROL[mpcc_id],
+                               MPCC_OGAM_LUT_WRITE_COLOR_MASK, 4);
+
+               for (i = 0 ; i < num; i++)
+                       REG_SET(MPCC_OGAM_LUT_DATA[mpcc_id], 0, MPCC_OGAM_LUT_DATA, rgb[i].red_reg);
+
+               REG_SET(MPCC_OGAM_LUT_INDEX[mpcc_id], 0, MPCC_OGAM_LUT_INDEX, 0);
+
+               REG_UPDATE(MPCC_OGAM_LUT_CONTROL[mpcc_id],
+                               MPCC_OGAM_LUT_WRITE_COLOR_MASK, 2);
+
+               for (i = 0 ; i < num; i++)
+                       REG_SET(MPCC_OGAM_LUT_DATA[mpcc_id], 0, MPCC_OGAM_LUT_DATA, rgb[i].green_reg);
+
+               REG_SET(MPCC_OGAM_LUT_INDEX[mpcc_id], 0, MPCC_OGAM_LUT_INDEX, 0);
+
+               REG_UPDATE(MPCC_OGAM_LUT_CONTROL[mpcc_id],
+                               MPCC_OGAM_LUT_WRITE_COLOR_MASK, 1);
+
+               for (i = 0 ; i < num; i++)
+                       REG_SET(MPCC_OGAM_LUT_DATA[mpcc_id], 0, MPCC_OGAM_LUT_DATA, rgb[i].blue_reg);
+
+       }
+
+}
+
+void mpc3_set_output_gamma(
+               struct mpc *mpc,
+               int mpcc_id,
+               const struct pwl_params *params)
+{
+       enum dc_lut_mode current_mode;
+       enum dc_lut_mode next_mode;
+       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
+
+       if (mpc->ctx->dc->debug.cm_in_bypass) {
+               REG_SET(MPCC_OGAM_MODE[mpcc_id], 0, MPCC_OGAM_MODE, 0);
+               return;
+       }
+
+       if (params == NULL) { //disable OGAM
+               REG_SET(MPCC_OGAM_CONTROL[mpcc_id], 0, MPCC_OGAM_MODE, 0);
+               return;
+       }
+       //enable OGAM
+       REG_SET(MPCC_OGAM_CONTROL[mpcc_id], 0, MPCC_OGAM_MODE, 2);
+
+       current_mode = mpc3_get_ogam_current(mpc, mpcc_id);
+       if (current_mode == LUT_BYPASS)
+               next_mode = LUT_RAM_A;
+       else if (current_mode == LUT_RAM_A)
+               next_mode = LUT_RAM_B;
+       else
+               next_mode = LUT_RAM_A;
+
+       mpc3_power_on_ogam_lut(mpc, mpcc_id, true);
+       mpc3_configure_ogam_lut(mpc, mpcc_id, next_mode == LUT_RAM_A);
+
+       if (next_mode == LUT_RAM_A)
+               mpc3_program_luta(mpc, mpcc_id, params);
+       else
+               mpc3_program_lutb(mpc, mpcc_id, params);
+
+       mpc3_program_ogam_pwl(
+                       mpc, mpcc_id, params->rgb_resulted, params->hw_points_num);
+
+       /*we need to program 2 fields here as apposed to 1*/
+       REG_UPDATE(MPCC_OGAM_CONTROL[mpcc_id],
+                       MPCC_OGAM_SELECT, next_mode == LUT_RAM_A ? 0:1);
+
+       if (mpc->ctx->dc->debug.enable_mem_low_power.bits.mpc)
+               mpc3_power_on_ogam_lut(mpc, mpcc_id, false);
+}
+
+void mpc3_set_denorm(
+               struct mpc *mpc,
+               int opp_id,
+               enum dc_color_depth output_depth)
+{
+       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
+       /* De-normalize Fixed U1.13 color data to different target bit depths. 0 is bypass*/
+       int denorm_mode = 0;
+
+       switch (output_depth) {
+       case COLOR_DEPTH_666:
+               denorm_mode = 1;
+               break;
+       case COLOR_DEPTH_888:
+               denorm_mode = 2;
+               break;
+       case COLOR_DEPTH_999:
+               denorm_mode = 3;
+               break;
+       case COLOR_DEPTH_101010:
+               denorm_mode = 4;
+               break;
+       case COLOR_DEPTH_111111:
+               denorm_mode = 5;
+               break;
+       case COLOR_DEPTH_121212:
+               denorm_mode = 6;
+               break;
+       case COLOR_DEPTH_141414:
+       case COLOR_DEPTH_161616:
+       default:
+               /* not valid used case! */
+               break;
+       }
+
+       REG_UPDATE(DENORM_CONTROL[opp_id],
+                       MPC_OUT_DENORM_MODE, denorm_mode);
+}
+
+void mpc3_set_denorm_clamp(
+               struct mpc *mpc,
+               int opp_id,
+               struct mpc_denorm_clamp denorm_clamp)
+{
+       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
+
+       /*program min and max clamp values for the pixel components*/
+       REG_UPDATE_2(DENORM_CONTROL[opp_id],
+                       MPC_OUT_DENORM_CLAMP_MAX_R_CR, denorm_clamp.clamp_max_r_cr,
+                       MPC_OUT_DENORM_CLAMP_MIN_R_CR, denorm_clamp.clamp_min_r_cr);
+       REG_UPDATE_2(DENORM_CLAMP_G_Y[opp_id],
+                       MPC_OUT_DENORM_CLAMP_MAX_G_Y, denorm_clamp.clamp_max_g_y,
+                       MPC_OUT_DENORM_CLAMP_MIN_G_Y, denorm_clamp.clamp_min_g_y);
+       REG_UPDATE_2(DENORM_CLAMP_B_CB[opp_id],
+                       MPC_OUT_DENORM_CLAMP_MAX_B_CB, denorm_clamp.clamp_max_b_cb,
+                       MPC_OUT_DENORM_CLAMP_MIN_B_CB, denorm_clamp.clamp_min_b_cb);
+}
+
+static enum dc_lut_mode mpc3_get_shaper_current(struct mpc *mpc, uint32_t rmu_idx)
+{
+       enum dc_lut_mode mode;
+       uint32_t state_mode;
+       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
+
+       REG_GET(SHAPER_CONTROL[rmu_idx], MPC_RMU_SHAPER_LUT_MODE_CURRENT, &state_mode);
+
+       switch (state_mode) {
+       case 0:
+               mode = LUT_BYPASS;
+               break;
+       case 1:
+               mode = LUT_RAM_A;
+               break;
+       case 2:
+               mode = LUT_RAM_B;
+               break;
+       default:
+               mode = LUT_BYPASS;
+               break;
+       }
+
+       return mode;
+}
+
+static void mpc3_configure_shaper_lut(
+               struct mpc *mpc,
+               bool is_ram_a,
+               uint32_t rmu_idx)
+{
+       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
+
+       REG_UPDATE(SHAPER_LUT_WRITE_EN_MASK[rmu_idx],
+                       MPC_RMU_SHAPER_LUT_WRITE_EN_MASK, 7);
+       REG_UPDATE(SHAPER_LUT_WRITE_EN_MASK[rmu_idx],
+                       MPC_RMU_SHAPER_LUT_WRITE_SEL, is_ram_a == true ? 0:1);
+       REG_SET(SHAPER_LUT_INDEX[rmu_idx], 0, MPC_RMU_SHAPER_LUT_INDEX, 0);
+}
+
+static void mpc3_program_shaper_luta_settings(
+               struct mpc *mpc,
+               const struct pwl_params *params,
+               uint32_t rmu_idx)
+{
+       const struct gamma_curve *curve;
+       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
+
+       REG_SET_2(SHAPER_RAMA_START_CNTL_B[rmu_idx], 0,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION_START_B, params->corner_points[0].blue.custom_float_x,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION_START_SEGMENT_B, 0);
+       REG_SET_2(SHAPER_RAMA_START_CNTL_G[rmu_idx], 0,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION_START_B, params->corner_points[0].green.custom_float_x,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION_START_SEGMENT_B, 0);
+       REG_SET_2(SHAPER_RAMA_START_CNTL_R[rmu_idx], 0,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION_START_B, params->corner_points[0].red.custom_float_x,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION_START_SEGMENT_B, 0);
+
+       REG_SET_2(SHAPER_RAMA_END_CNTL_B[rmu_idx], 0,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION_END_B, params->corner_points[1].blue.custom_float_x,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION_END_BASE_B, params->corner_points[1].blue.custom_float_y);
+       REG_SET_2(SHAPER_RAMA_END_CNTL_G[rmu_idx], 0,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION_END_B, params->corner_points[1].green.custom_float_x,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION_END_BASE_B, params->corner_points[1].green.custom_float_y);
+       REG_SET_2(SHAPER_RAMA_END_CNTL_R[rmu_idx], 0,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION_END_B, params->corner_points[1].red.custom_float_x,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION_END_BASE_B, params->corner_points[1].red.custom_float_y);
+
+       curve = params->arr_curve_points;
+       REG_SET_4(SHAPER_RAMA_REGION_0_1[rmu_idx], 0,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
+
+       curve += 2;
+       REG_SET_4(SHAPER_RAMA_REGION_2_3[rmu_idx], 0,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
+
+       curve += 2;
+       REG_SET_4(SHAPER_RAMA_REGION_4_5[rmu_idx], 0,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
+
+       curve += 2;
+       REG_SET_4(SHAPER_RAMA_REGION_6_7[rmu_idx], 0,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
+
+       curve += 2;
+       REG_SET_4(SHAPER_RAMA_REGION_8_9[rmu_idx], 0,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
+
+       curve += 2;
+       REG_SET_4(SHAPER_RAMA_REGION_10_11[rmu_idx], 0,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
+
+       curve += 2;
+       REG_SET_4(SHAPER_RAMA_REGION_12_13[rmu_idx], 0,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
+
+       curve += 2;
+       REG_SET_4(SHAPER_RAMA_REGION_14_15[rmu_idx], 0,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
+
+
+       curve += 2;
+       REG_SET_4(SHAPER_RAMA_REGION_16_17[rmu_idx], 0,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
+
+       curve += 2;
+       REG_SET_4(SHAPER_RAMA_REGION_18_19[rmu_idx], 0,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
+
+       curve += 2;
+       REG_SET_4(SHAPER_RAMA_REGION_20_21[rmu_idx], 0,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
+
+       curve += 2;
+       REG_SET_4(SHAPER_RAMA_REGION_22_23[rmu_idx], 0,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
+
+       curve += 2;
+       REG_SET_4(SHAPER_RAMA_REGION_24_25[rmu_idx], 0,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
+
+       curve += 2;
+       REG_SET_4(SHAPER_RAMA_REGION_26_27[rmu_idx], 0,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
+
+       curve += 2;
+       REG_SET_4(SHAPER_RAMA_REGION_28_29[rmu_idx], 0,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
+
+       curve += 2;
+       REG_SET_4(SHAPER_RAMA_REGION_30_31[rmu_idx], 0,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
+
+       curve += 2;
+       REG_SET_4(SHAPER_RAMA_REGION_32_33[rmu_idx], 0,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
+}
+
+static void mpc3_program_shaper_lutb_settings(
+               struct mpc *mpc,
+               const struct pwl_params *params,
+               uint32_t rmu_idx)
+{
+       const struct gamma_curve *curve;
+       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
+
+       REG_SET_2(SHAPER_RAMB_START_CNTL_B[rmu_idx], 0,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION_START_B, params->corner_points[0].blue.custom_float_x,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION_START_SEGMENT_B, 0);
+       REG_SET_2(SHAPER_RAMB_START_CNTL_G[rmu_idx], 0,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION_START_B, params->corner_points[0].green.custom_float_x,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION_START_SEGMENT_B, 0);
+       REG_SET_2(SHAPER_RAMB_START_CNTL_R[rmu_idx], 0,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION_START_B, params->corner_points[0].red.custom_float_x,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION_START_SEGMENT_B, 0);
+
+       REG_SET_2(SHAPER_RAMB_END_CNTL_B[rmu_idx], 0,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION_END_B, params->corner_points[1].blue.custom_float_x,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION_END_BASE_B, params->corner_points[1].blue.custom_float_y);
+       REG_SET_2(SHAPER_RAMB_END_CNTL_G[rmu_idx], 0,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION_END_B, params->corner_points[1].green.custom_float_x,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION_END_BASE_B, params->corner_points[1].green.custom_float_y);
+       REG_SET_2(SHAPER_RAMB_END_CNTL_R[rmu_idx], 0,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION_END_B, params->corner_points[1].red.custom_float_x,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION_END_BASE_B, params->corner_points[1].red.custom_float_y);
+
+       curve = params->arr_curve_points;
+       REG_SET_4(SHAPER_RAMB_REGION_0_1[rmu_idx], 0,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
+
+       curve += 2;
+       REG_SET_4(SHAPER_RAMB_REGION_2_3[rmu_idx], 0,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
+
+
+       curve += 2;
+       REG_SET_4(SHAPER_RAMB_REGION_4_5[rmu_idx], 0,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
+
+       curve += 2;
+       REG_SET_4(SHAPER_RAMB_REGION_6_7[rmu_idx], 0,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
+
+       curve += 2;
+       REG_SET_4(SHAPER_RAMB_REGION_8_9[rmu_idx], 0,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
+               MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
+
+       curve += 2;
+       REG_SET_4(SHAPER_RAMB_REGION_10_11[rmu_idx], 0,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
+
+       curve += 2;
+       REG_SET_4(SHAPER_RAMB_REGION_12_13[rmu_idx], 0,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
+
+       curve += 2;
+       REG_SET_4(SHAPER_RAMB_REGION_14_15[rmu_idx], 0,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
+
+
+       curve += 2;
+       REG_SET_4(SHAPER_RAMB_REGION_16_17[rmu_idx], 0,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
+
+       curve += 2;
+       REG_SET_4(SHAPER_RAMB_REGION_18_19[rmu_idx], 0,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
+
+       curve += 2;
+       REG_SET_4(SHAPER_RAMB_REGION_20_21[rmu_idx], 0,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
+
+       curve += 2;
+       REG_SET_4(SHAPER_RAMB_REGION_22_23[rmu_idx], 0,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
+
+       curve += 2;
+       REG_SET_4(SHAPER_RAMB_REGION_24_25[rmu_idx], 0,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
+
+       curve += 2;
+       REG_SET_4(SHAPER_RAMB_REGION_26_27[rmu_idx], 0,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
+
+       curve += 2;
+       REG_SET_4(SHAPER_RAMB_REGION_28_29[rmu_idx], 0,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
+
+       curve += 2;
+       REG_SET_4(SHAPER_RAMB_REGION_30_31[rmu_idx], 0,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
+
+       curve += 2;
+       REG_SET_4(SHAPER_RAMB_REGION_32_33[rmu_idx], 0,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, curve[0].offset,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, curve[0].segments_num,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, curve[1].offset,
+                       MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, curve[1].segments_num);
+}
+
+
+static void mpc3_program_shaper_lut(
+               struct mpc *mpc,
+               const struct pwl_result_data *rgb,
+               uint32_t num,
+               uint32_t rmu_idx)
+{
+       uint32_t i, red, green, blue;
+       uint32_t  red_delta, green_delta, blue_delta;
+       uint32_t  red_value, green_value, blue_value;
+
+       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
+
+       for (i = 0 ; i < num; i++) {
+
+               red   = rgb[i].red_reg;
+               green = rgb[i].green_reg;
+               blue  = rgb[i].blue_reg;
+
+               red_delta   = rgb[i].delta_red_reg;
+               green_delta = rgb[i].delta_green_reg;
+               blue_delta  = rgb[i].delta_blue_reg;
+
+               red_value   = ((red_delta   & 0x3ff) << 14) | (red   & 0x3fff);
+               green_value = ((green_delta & 0x3ff) << 14) | (green & 0x3fff);
+               blue_value  = ((blue_delta  & 0x3ff) << 14) | (blue  & 0x3fff);
+
+               REG_SET(SHAPER_LUT_DATA[rmu_idx], 0, MPC_RMU_SHAPER_LUT_DATA, red_value);
+               REG_SET(SHAPER_LUT_DATA[rmu_idx], 0, MPC_RMU_SHAPER_LUT_DATA, green_value);
+               REG_SET(SHAPER_LUT_DATA[rmu_idx], 0, MPC_RMU_SHAPER_LUT_DATA, blue_value);
+       }
+
+}
+
+static void mpc3_power_on_shaper_3dlut(
+               struct mpc *mpc,
+               uint32_t rmu_idx,
+       bool power_on)
+{
+       uint32_t power_status_shaper = 2;
+       uint32_t power_status_3dlut  = 2;
+       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
+       int max_retries = 10;
+
+       if (rmu_idx == 0) {
+               REG_SET(MPC_RMU_MEM_PWR_CTRL, 0,
+                       MPC_RMU0_MEM_PWR_DIS, power_on == true ? 1:0);
+               /* wait for memory to fully power up */
+               if (power_on && mpc->ctx->dc->debug.enable_mem_low_power.bits.mpc) {
+                       REG_WAIT(MPC_RMU_MEM_PWR_CTRL, MPC_RMU0_SHAPER_MEM_PWR_STATE, 0, 1, max_retries);
+                       REG_WAIT(MPC_RMU_MEM_PWR_CTRL, MPC_RMU0_3DLUT_MEM_PWR_STATE, 0, 1, max_retries);
+               }
+
+               /*read status is not mandatory, it is just for debugging*/
+               REG_GET(MPC_RMU_MEM_PWR_CTRL, MPC_RMU0_SHAPER_MEM_PWR_STATE, &power_status_shaper);
+               REG_GET(MPC_RMU_MEM_PWR_CTRL, MPC_RMU0_3DLUT_MEM_PWR_STATE, &power_status_3dlut);
+       } else if (rmu_idx == 1) {
+               REG_SET(MPC_RMU_MEM_PWR_CTRL, 0,
+                       MPC_RMU1_MEM_PWR_DIS, power_on == true ? 1:0);
+               if (power_on && mpc->ctx->dc->debug.enable_mem_low_power.bits.mpc) {
+                       REG_WAIT(MPC_RMU_MEM_PWR_CTRL, MPC_RMU1_SHAPER_MEM_PWR_STATE, 0, 1, max_retries);
+                       REG_WAIT(MPC_RMU_MEM_PWR_CTRL, MPC_RMU1_3DLUT_MEM_PWR_STATE, 0, 1, max_retries);
+               }
+
+               REG_GET(MPC_RMU_MEM_PWR_CTRL, MPC_RMU1_SHAPER_MEM_PWR_STATE, &power_status_shaper);
+               REG_GET(MPC_RMU_MEM_PWR_CTRL, MPC_RMU1_3DLUT_MEM_PWR_STATE, &power_status_3dlut);
+       }
+       /*TODO Add rmu_idx == 2 for SIENNA_CICHLID */
+       if (power_status_shaper != 0 && power_on == true)
+               BREAK_TO_DEBUGGER();
+
+       if (power_status_3dlut != 0 && power_on == true)
+               BREAK_TO_DEBUGGER();
+}
+
+
+
+bool mpc3_program_shaper(
+               struct mpc *mpc,
+               const struct pwl_params *params,
+               uint32_t rmu_idx)
+{
+       enum dc_lut_mode current_mode;
+       enum dc_lut_mode next_mode;
+
+       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
+
+       if (params == NULL) {
+               REG_SET(SHAPER_CONTROL[rmu_idx], 0, MPC_RMU_SHAPER_LUT_MODE, 0);
+               return false;
+       }
+
+       if (mpc->ctx->dc->debug.enable_mem_low_power.bits.mpc)
+               mpc3_power_on_shaper_3dlut(mpc, rmu_idx, true);
+
+       current_mode = mpc3_get_shaper_current(mpc, rmu_idx);
+
+       if (current_mode == LUT_BYPASS || current_mode == LUT_RAM_A)
+               next_mode = LUT_RAM_B;
+       else
+               next_mode = LUT_RAM_A;
+
+       mpc3_configure_shaper_lut(mpc, next_mode == LUT_RAM_A, rmu_idx);
+
+       if (next_mode == LUT_RAM_A)
+               mpc3_program_shaper_luta_settings(mpc, params, rmu_idx);
+       else
+               mpc3_program_shaper_lutb_settings(mpc, params, rmu_idx);
+
+       mpc3_program_shaper_lut(
+                       mpc, params->rgb_resulted, params->hw_points_num, rmu_idx);
+
+       REG_SET(SHAPER_CONTROL[rmu_idx], 0, MPC_RMU_SHAPER_LUT_MODE, next_mode == LUT_RAM_A ? 1:2);
+       mpc3_power_on_shaper_3dlut(mpc, rmu_idx, false);
+
+       return true;
+}
+
+static void mpc3_set_3dlut_mode(
+               struct mpc *mpc,
+               enum dc_lut_mode mode,
+               bool is_color_channel_12bits,
+               bool is_lut_size17x17x17,
+               uint32_t rmu_idx)
+{
+       uint32_t lut_mode;
+       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
+
+       if (mode == LUT_BYPASS)
+               lut_mode = 0;
+       else if (mode == LUT_RAM_A)
+               lut_mode = 1;
+       else
+               lut_mode = 2;
+
+       REG_UPDATE_2(RMU_3DLUT_MODE[rmu_idx],
+                       MPC_RMU_3DLUT_MODE, lut_mode,
+                       MPC_RMU_3DLUT_SIZE, is_lut_size17x17x17 == true ? 0 : 1);
+}
+
+static enum dc_lut_mode get3dlut_config(
+                       struct mpc *mpc,
+                       bool *is_17x17x17,
+                       bool *is_12bits_color_channel,
+                       int rmu_idx)
+{
+       uint32_t i_mode, i_enable_10bits, lut_size;
+       enum dc_lut_mode mode;
+       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
+
+       REG_GET(RMU_3DLUT_MODE[rmu_idx],
+                       MPC_RMU_3DLUT_MODE_CURRENT,  &i_mode);
+
+       REG_GET(RMU_3DLUT_READ_WRITE_CONTROL[rmu_idx],
+                       MPC_RMU_3DLUT_30BIT_EN, &i_enable_10bits);
+
+       switch (i_mode) {
+       case 0:
+               mode = LUT_BYPASS;
+               break;
+       case 1:
+               mode = LUT_RAM_A;
+               break;
+       case 2:
+               mode = LUT_RAM_B;
+               break;
+       default:
+               mode = LUT_BYPASS;
+               break;
+       }
+       if (i_enable_10bits > 0)
+               *is_12bits_color_channel = false;
+       else
+               *is_12bits_color_channel = true;
+
+       REG_GET(RMU_3DLUT_MODE[rmu_idx], MPC_RMU_3DLUT_SIZE, &lut_size);
+
+       if (lut_size == 0)
+               *is_17x17x17 = true;
+       else
+               *is_17x17x17 = false;
+
+       return mode;
+}
+
+static void mpc3_select_3dlut_ram(
+               struct mpc *mpc,
+               enum dc_lut_mode mode,
+               bool is_color_channel_12bits,
+               uint32_t rmu_idx)
+{
+       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
+
+       REG_UPDATE_2(RMU_3DLUT_READ_WRITE_CONTROL[rmu_idx],
+               MPC_RMU_3DLUT_RAM_SEL, mode == LUT_RAM_A ? 0 : 1,
+               MPC_RMU_3DLUT_30BIT_EN, is_color_channel_12bits == true ? 0:1);
+}
+
+static void mpc3_select_3dlut_ram_mask(
+               struct mpc *mpc,
+               uint32_t ram_selection_mask,
+               uint32_t rmu_idx)
+{
+       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
+
+       REG_UPDATE(RMU_3DLUT_READ_WRITE_CONTROL[rmu_idx], MPC_RMU_3DLUT_WRITE_EN_MASK,
+                       ram_selection_mask);
+       REG_SET(RMU_3DLUT_INDEX[rmu_idx], 0, MPC_RMU_3DLUT_INDEX, 0);
+}
+
+static void mpc3_set3dlut_ram12(
+               struct mpc *mpc,
+               const struct dc_rgb *lut,
+               uint32_t entries,
+               uint32_t rmu_idx)
+{
+       uint32_t i, red, green, blue, red1, green1, blue1;
+       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
+
+       for (i = 0 ; i < entries; i += 2) {
+               red   = lut[i].red<<4;
+               green = lut[i].green<<4;
+               blue  = lut[i].blue<<4;
+               red1   = lut[i+1].red<<4;
+               green1 = lut[i+1].green<<4;
+               blue1  = lut[i+1].blue<<4;
+
+               REG_SET_2(RMU_3DLUT_DATA[rmu_idx], 0,
+                               MPC_RMU_3DLUT_DATA0, red,
+                               MPC_RMU_3DLUT_DATA1, red1);
+
+               REG_SET_2(RMU_3DLUT_DATA[rmu_idx], 0,
+                               MPC_RMU_3DLUT_DATA0, green,
+                               MPC_RMU_3DLUT_DATA1, green1);
+
+               REG_SET_2(RMU_3DLUT_DATA[rmu_idx], 0,
+                               MPC_RMU_3DLUT_DATA0, blue,
+                               MPC_RMU_3DLUT_DATA1, blue1);
+       }
+}
+
+static void mpc3_set3dlut_ram10(
+               struct mpc *mpc,
+               const struct dc_rgb *lut,
+               uint32_t entries,
+               uint32_t rmu_idx)
+{
+       uint32_t i, red, green, blue, value;
+       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
+
+       for (i = 0; i < entries; i++) {
+               red   = lut[i].red;
+               green = lut[i].green;
+               blue  = lut[i].blue;
+               //should we shift red 22bit and green 12? ask Nvenko
+               value = (red<<20) | (green<<10) | blue;
+
+               REG_SET(RMU_3DLUT_DATA_30BIT[rmu_idx], 0, MPC_RMU_3DLUT_DATA_30BIT, value);
+       }
+
+}
+
+
+void mpc3_init_mpcc(struct mpcc *mpcc, int mpcc_inst)
+{
+       mpcc->mpcc_id = mpcc_inst;
+       mpcc->dpp_id = 0xf;
+       mpcc->mpcc_bot = NULL;
+       mpcc->blnd_cfg.overlap_only = false;
+       mpcc->blnd_cfg.global_alpha = 0xff;
+       mpcc->blnd_cfg.global_gain = 0xff;
+       mpcc->blnd_cfg.background_color_bpc = 4;
+       mpcc->blnd_cfg.bottom_gain_mode = 0;
+       mpcc->blnd_cfg.top_gain = 0x1f000;
+       mpcc->blnd_cfg.bottom_inside_gain = 0x1f000;
+       mpcc->blnd_cfg.bottom_outside_gain = 0x1f000;
+       mpcc->sm_cfg.enable = false;
+       mpcc->shared_bottom = false;
+}
+
+static void program_gamut_remap(
+               struct dcn30_mpc *mpc30,
+               int mpcc_id,
+               const uint16_t *regval,
+               int select)
+{
+       uint16_t selection = 0;
+       struct color_matrices_reg gam_regs;
+
+       if (regval == NULL || select == GAMUT_REMAP_BYPASS) {
+               REG_SET(MPCC_GAMUT_REMAP_MODE[mpcc_id], 0,
+                               MPCC_GAMUT_REMAP_MODE, GAMUT_REMAP_BYPASS);
+               return;
+       }
+       switch (select) {
+       case GAMUT_REMAP_COEFF:
+               selection = 1;
+               break;
+               /*this corresponds to GAMUT_REMAP coefficients set B
+                * we don't have common coefficient sets in dcn3ag/dcn3
+                */
+       case GAMUT_REMAP_COMA_COEFF:
+               selection = 2;
+               break;
+       default:
+               break;
+       }
+
+       gam_regs.shifts.csc_c11 = mpc30->mpc_shift->MPCC_GAMUT_REMAP_C11_A;
+       gam_regs.masks.csc_c11  = mpc30->mpc_mask->MPCC_GAMUT_REMAP_C11_A;
+       gam_regs.shifts.csc_c12 = mpc30->mpc_shift->MPCC_GAMUT_REMAP_C12_A;
+       gam_regs.masks.csc_c12 = mpc30->mpc_mask->MPCC_GAMUT_REMAP_C12_A;
+
+
+       if (select == GAMUT_REMAP_COEFF) {
+               gam_regs.csc_c11_c12 = REG(MPC_GAMUT_REMAP_C11_C12_A[mpcc_id]);
+               gam_regs.csc_c33_c34 = REG(MPC_GAMUT_REMAP_C33_C34_A[mpcc_id]);
+
+               cm_helper_program_color_matrices(
+                               mpc30->base.ctx,
+                               regval,
+                               &gam_regs);
+
+       } else  if (select == GAMUT_REMAP_COMA_COEFF) {
+
+               gam_regs.csc_c11_c12 = REG(MPC_GAMUT_REMAP_C11_C12_B[mpcc_id]);
+               gam_regs.csc_c33_c34 = REG(MPC_GAMUT_REMAP_C33_C34_B[mpcc_id]);
+
+               cm_helper_program_color_matrices(
+                               mpc30->base.ctx,
+                               regval,
+                               &gam_regs);
+
+       }
+       //select coefficient set to use
+       REG_SET(MPCC_GAMUT_REMAP_MODE[mpcc_id], 0,
+                                       MPCC_GAMUT_REMAP_MODE, selection);
+}
+
+void mpc3_set_gamut_remap(
+               struct mpc *mpc,
+               int mpcc_id,
+               const struct mpc_grph_gamut_adjustment *adjust)
+{
+       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
+       int i = 0;
+       int gamut_mode;
+
+       if (adjust->gamut_adjust_type != GRAPHICS_GAMUT_ADJUST_TYPE_SW)
+               program_gamut_remap(mpc30, mpcc_id, NULL, GAMUT_REMAP_BYPASS);
+       else {
+               struct fixed31_32 arr_matrix[12];
+               uint16_t arr_reg_val[12];
+
+               for (i = 0; i < 12; i++)
+                       arr_matrix[i] = adjust->temperature_matrix[i];
+
+               convert_float_matrix(
+                       arr_reg_val, arr_matrix, 12);
+
+               //current coefficient set in use
+               REG_GET(MPCC_GAMUT_REMAP_MODE[mpcc_id], MPCC_GAMUT_REMAP_MODE_CURRENT, &gamut_mode);
+
+               if (gamut_mode == 0)
+                       gamut_mode = 1; //use coefficient set A
+               else if (gamut_mode == 1)
+                       gamut_mode = 2;
+               else
+                       gamut_mode = 1;
+
+               program_gamut_remap(mpc30, mpcc_id, arr_reg_val, gamut_mode);
+       }
+}
+
+static void read_gamut_remap(struct dcn30_mpc *mpc30,
+                            int mpcc_id,
+                            uint16_t *regval,
+                            uint32_t *select)
+{
+       struct color_matrices_reg gam_regs;
+
+       //current coefficient set in use
+       REG_GET(MPCC_GAMUT_REMAP_MODE[mpcc_id], MPCC_GAMUT_REMAP_MODE_CURRENT, select);
+
+       gam_regs.shifts.csc_c11 = mpc30->mpc_shift->MPCC_GAMUT_REMAP_C11_A;
+       gam_regs.masks.csc_c11  = mpc30->mpc_mask->MPCC_GAMUT_REMAP_C11_A;
+       gam_regs.shifts.csc_c12 = mpc30->mpc_shift->MPCC_GAMUT_REMAP_C12_A;
+       gam_regs.masks.csc_c12 = mpc30->mpc_mask->MPCC_GAMUT_REMAP_C12_A;
+
+       if (*select == GAMUT_REMAP_COEFF) {
+               gam_regs.csc_c11_c12 = REG(MPC_GAMUT_REMAP_C11_C12_A[mpcc_id]);
+               gam_regs.csc_c33_c34 = REG(MPC_GAMUT_REMAP_C33_C34_A[mpcc_id]);
+
+               cm_helper_read_color_matrices(
+                               mpc30->base.ctx,
+                               regval,
+                               &gam_regs);
+
+       } else  if (*select == GAMUT_REMAP_COMA_COEFF) {
+
+               gam_regs.csc_c11_c12 = REG(MPC_GAMUT_REMAP_C11_C12_B[mpcc_id]);
+               gam_regs.csc_c33_c34 = REG(MPC_GAMUT_REMAP_C33_C34_B[mpcc_id]);
+
+               cm_helper_read_color_matrices(
+                               mpc30->base.ctx,
+                               regval,
+                               &gam_regs);
+
+       }
+
+}
+
+void mpc3_get_gamut_remap(struct mpc *mpc,
+                         int mpcc_id,
+                         struct mpc_grph_gamut_adjustment *adjust)
+{
+       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
+       uint16_t arr_reg_val[12] = {0};
+       int select;
+
+       read_gamut_remap(mpc30, mpcc_id, arr_reg_val, &select);
+
+       if (select == GAMUT_REMAP_BYPASS) {
+               adjust->gamut_adjust_type = GRAPHICS_GAMUT_ADJUST_TYPE_BYPASS;
+               return;
+       }
+
+       adjust->gamut_adjust_type = GRAPHICS_GAMUT_ADJUST_TYPE_SW;
+       convert_hw_matrix(adjust->temperature_matrix,
+                         arr_reg_val, ARRAY_SIZE(arr_reg_val));
+}
+
+bool mpc3_program_3dlut(
+               struct mpc *mpc,
+               const struct tetrahedral_params *params,
+               int rmu_idx)
+{
+       enum dc_lut_mode mode;
+       bool is_17x17x17;
+       bool is_12bits_color_channel;
+       const struct dc_rgb *lut0;
+       const struct dc_rgb *lut1;
+       const struct dc_rgb *lut2;
+       const struct dc_rgb *lut3;
+       int lut_size0;
+       int lut_size;
+
+       if (params == NULL) {
+               mpc3_set_3dlut_mode(mpc, LUT_BYPASS, false, false, rmu_idx);
+               return false;
+       }
+       mpc3_power_on_shaper_3dlut(mpc, rmu_idx, true);
+
+       mode = get3dlut_config(mpc, &is_17x17x17, &is_12bits_color_channel, rmu_idx);
+
+       if (mode == LUT_BYPASS || mode == LUT_RAM_B)
+               mode = LUT_RAM_A;
+       else
+               mode = LUT_RAM_B;
+
+       is_17x17x17 = !params->use_tetrahedral_9;
+       is_12bits_color_channel = params->use_12bits;
+       if (is_17x17x17) {
+               lut0 = params->tetrahedral_17.lut0;
+               lut1 = params->tetrahedral_17.lut1;
+               lut2 = params->tetrahedral_17.lut2;
+               lut3 = params->tetrahedral_17.lut3;
+               lut_size0 = sizeof(params->tetrahedral_17.lut0)/
+                                       sizeof(params->tetrahedral_17.lut0[0]);
+               lut_size  = sizeof(params->tetrahedral_17.lut1)/
+                                       sizeof(params->tetrahedral_17.lut1[0]);
+       } else {
+               lut0 = params->tetrahedral_9.lut0;
+               lut1 = params->tetrahedral_9.lut1;
+               lut2 = params->tetrahedral_9.lut2;
+               lut3 = params->tetrahedral_9.lut3;
+               lut_size0 = sizeof(params->tetrahedral_9.lut0)/
+                               sizeof(params->tetrahedral_9.lut0[0]);
+               lut_size  = sizeof(params->tetrahedral_9.lut1)/
+                               sizeof(params->tetrahedral_9.lut1[0]);
+               }
+
+       mpc3_select_3dlut_ram(mpc, mode,
+                               is_12bits_color_channel, rmu_idx);
+       mpc3_select_3dlut_ram_mask(mpc, 0x1, rmu_idx);
+       if (is_12bits_color_channel)
+               mpc3_set3dlut_ram12(mpc, lut0, lut_size0, rmu_idx);
+       else
+               mpc3_set3dlut_ram10(mpc, lut0, lut_size0, rmu_idx);
+
+       mpc3_select_3dlut_ram_mask(mpc, 0x2, rmu_idx);
+       if (is_12bits_color_channel)
+               mpc3_set3dlut_ram12(mpc, lut1, lut_size, rmu_idx);
+       else
+               mpc3_set3dlut_ram10(mpc, lut1, lut_size, rmu_idx);
+
+       mpc3_select_3dlut_ram_mask(mpc, 0x4, rmu_idx);
+       if (is_12bits_color_channel)
+               mpc3_set3dlut_ram12(mpc, lut2, lut_size, rmu_idx);
+       else
+               mpc3_set3dlut_ram10(mpc, lut2, lut_size, rmu_idx);
+
+       mpc3_select_3dlut_ram_mask(mpc, 0x8, rmu_idx);
+       if (is_12bits_color_channel)
+               mpc3_set3dlut_ram12(mpc, lut3, lut_size, rmu_idx);
+       else
+               mpc3_set3dlut_ram10(mpc, lut3, lut_size, rmu_idx);
+
+       mpc3_set_3dlut_mode(mpc, mode, is_12bits_color_channel,
+                                       is_17x17x17, rmu_idx);
+
+       if (mpc->ctx->dc->debug.enable_mem_low_power.bits.mpc)
+               mpc3_power_on_shaper_3dlut(mpc, rmu_idx, false);
+
+       return true;
+}
+
+void mpc3_set_output_csc(
+               struct mpc *mpc,
+               int opp_id,
+               const uint16_t *regval,
+               enum mpc_output_csc_mode ocsc_mode)
+{
+       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
+       struct color_matrices_reg ocsc_regs;
+
+       REG_WRITE(MPC_OUT_CSC_COEF_FORMAT, 0);
+
+       REG_SET(CSC_MODE[opp_id], 0, MPC_OCSC_MODE, ocsc_mode);
+
+       if (ocsc_mode == MPC_OUTPUT_CSC_DISABLE)
+               return;
+
+       if (regval == NULL) {
+               BREAK_TO_DEBUGGER();
+               return;
+       }
+
+       ocsc_regs.shifts.csc_c11 = mpc30->mpc_shift->MPC_OCSC_C11_A;
+       ocsc_regs.masks.csc_c11  = mpc30->mpc_mask->MPC_OCSC_C11_A;
+       ocsc_regs.shifts.csc_c12 = mpc30->mpc_shift->MPC_OCSC_C12_A;
+       ocsc_regs.masks.csc_c12 = mpc30->mpc_mask->MPC_OCSC_C12_A;
+
+       if (ocsc_mode == MPC_OUTPUT_CSC_COEF_A) {
+               ocsc_regs.csc_c11_c12 = REG(CSC_C11_C12_A[opp_id]);
+               ocsc_regs.csc_c33_c34 = REG(CSC_C33_C34_A[opp_id]);
+       } else {
+               ocsc_regs.csc_c11_c12 = REG(CSC_C11_C12_B[opp_id]);
+               ocsc_regs.csc_c33_c34 = REG(CSC_C33_C34_B[opp_id]);
+       }
+       cm_helper_program_color_matrices(
+                       mpc30->base.ctx,
+                       regval,
+                       &ocsc_regs);
+}
+
+void mpc3_set_ocsc_default(
+               struct mpc *mpc,
+               int opp_id,
+               enum dc_color_space color_space,
+               enum mpc_output_csc_mode ocsc_mode)
+{
+       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
+       uint32_t arr_size;
+       struct color_matrices_reg ocsc_regs;
+       const uint16_t *regval = NULL;
+
+       REG_WRITE(MPC_OUT_CSC_COEF_FORMAT, 0);
+
+       REG_SET(CSC_MODE[opp_id], 0, MPC_OCSC_MODE, ocsc_mode);
+       if (ocsc_mode == MPC_OUTPUT_CSC_DISABLE)
+               return;
+
+       regval = find_color_matrix(color_space, &arr_size);
+
+       if (regval == NULL) {
+               BREAK_TO_DEBUGGER();
+               return;
+       }
+
+       ocsc_regs.shifts.csc_c11 = mpc30->mpc_shift->MPC_OCSC_C11_A;
+       ocsc_regs.masks.csc_c11  = mpc30->mpc_mask->MPC_OCSC_C11_A;
+       ocsc_regs.shifts.csc_c12 = mpc30->mpc_shift->MPC_OCSC_C12_A;
+       ocsc_regs.masks.csc_c12 = mpc30->mpc_mask->MPC_OCSC_C12_A;
+
+
+       if (ocsc_mode == MPC_OUTPUT_CSC_COEF_A) {
+               ocsc_regs.csc_c11_c12 = REG(CSC_C11_C12_A[opp_id]);
+               ocsc_regs.csc_c33_c34 = REG(CSC_C33_C34_A[opp_id]);
+       } else {
+               ocsc_regs.csc_c11_c12 = REG(CSC_C11_C12_B[opp_id]);
+               ocsc_regs.csc_c33_c34 = REG(CSC_C33_C34_B[opp_id]);
+       }
+
+       cm_helper_program_color_matrices(
+                       mpc30->base.ctx,
+                       regval,
+                       &ocsc_regs);
+}
+
+void mpc3_set_rmu_mux(
+       struct mpc *mpc,
+       int rmu_idx,
+       int value)
+{
+       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
+
+       if (rmu_idx == 0)
+               REG_UPDATE(MPC_RMU_CONTROL, MPC_RMU0_MUX, value);
+       else if (rmu_idx == 1)
+               REG_UPDATE(MPC_RMU_CONTROL, MPC_RMU1_MUX, value);
+
+}
+
+uint32_t mpc3_get_rmu_mux_status(
+       struct mpc *mpc,
+       int rmu_idx)
+{
+       uint32_t status = 0xf;
+       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
+
+       if (rmu_idx == 0)
+               REG_GET(MPC_RMU_CONTROL, MPC_RMU0_MUX_STATUS, &status);
+       else if (rmu_idx == 1)
+               REG_GET(MPC_RMU_CONTROL, MPC_RMU1_MUX_STATUS, &status);
+
+       return status;
+}
+
+uint32_t mpcc3_acquire_rmu(struct mpc *mpc, int mpcc_id, int rmu_idx)
+{
+       uint32_t rmu_status;
+
+       //determine if this mpcc is already multiplexed to an RMU unit
+       rmu_status = mpc3_get_rmu_mux_status(mpc, rmu_idx);
+       if (rmu_status == mpcc_id)
+               //return rmu_idx of pre_acquired rmu unit
+               return rmu_idx;
+
+       if (rmu_status == 0xf) {//rmu unit is disabled
+               mpc3_set_rmu_mux(mpc, rmu_idx, mpcc_id);
+               return rmu_idx;
+       }
+
+       //no vacant RMU units or invalid parameters acquire_post_bldn_3dlut
+       return -1;
+}
+
+static int mpcc3_release_rmu(struct mpc *mpc, int mpcc_id)
+{
+       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
+       int rmu_idx;
+       uint32_t rmu_status;
+       int released_rmu = -1;
+
+       for (rmu_idx = 0; rmu_idx < mpc30->num_rmu; rmu_idx++) {
+               rmu_status = mpc3_get_rmu_mux_status(mpc, rmu_idx);
+               if (rmu_status == mpcc_id) {
+                       mpc3_set_rmu_mux(mpc, rmu_idx, 0xf);
+                       released_rmu = rmu_idx;
+                       break;
+               }
+       }
+       return released_rmu;
+
+}
+
+static void mpc3_set_mpc_mem_lp_mode(struct mpc *mpc)
+{
+       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
+       int mpcc_id;
+
+       if (mpc->ctx->dc->debug.enable_mem_low_power.bits.mpc) {
+               if (mpc30->mpc_mask->MPC_RMU0_MEM_LOW_PWR_MODE && mpc30->mpc_mask->MPC_RMU1_MEM_LOW_PWR_MODE) {
+                       REG_UPDATE(MPC_RMU_MEM_PWR_CTRL, MPC_RMU0_MEM_LOW_PWR_MODE, 3);
+                       REG_UPDATE(MPC_RMU_MEM_PWR_CTRL, MPC_RMU1_MEM_LOW_PWR_MODE, 3);
+               }
+
+               if (mpc30->mpc_mask->MPCC_OGAM_MEM_LOW_PWR_MODE) {
+                       for (mpcc_id = 0; mpcc_id < mpc30->num_mpcc; mpcc_id++)
+                               REG_UPDATE(MPCC_MEM_PWR_CTRL[mpcc_id], MPCC_OGAM_MEM_LOW_PWR_MODE, 3);
+               }
+       }
+}
+
+static void mpc3_read_mpcc_state(
+               struct mpc *mpc,
+               int mpcc_inst,
+               struct mpcc_state *s)
+{
+       struct dcn30_mpc *mpc30 = TO_DCN30_MPC(mpc);
+       uint32_t rmu_status = 0xf;
+
+       REG_GET(MPCC_OPP_ID[mpcc_inst], MPCC_OPP_ID, &s->opp_id);
+       REG_GET(MPCC_TOP_SEL[mpcc_inst], MPCC_TOP_SEL, &s->dpp_id);
+       REG_GET(MPCC_BOT_SEL[mpcc_inst], MPCC_BOT_SEL, &s->bot_mpcc_id);
+       REG_GET_4(MPCC_CONTROL[mpcc_inst], MPCC_MODE, &s->mode,
+                       MPCC_ALPHA_BLND_MODE, &s->alpha_mode,
+                       MPCC_ALPHA_MULTIPLIED_MODE, &s->pre_multiplied_alpha,
+                       MPCC_BLND_ACTIVE_OVERLAP_ONLY, &s->overlap_only);
+       REG_GET_2(MPCC_STATUS[mpcc_inst], MPCC_IDLE, &s->idle,
+                       MPCC_BUSY, &s->busy);
+
+       /* Color blocks state */
+       REG_GET(MPC_RMU_CONTROL, MPC_RMU0_MUX_STATUS, &rmu_status);
+
+       if (rmu_status == mpcc_inst) {
+               REG_GET(SHAPER_CONTROL[0],
+                       MPC_RMU_SHAPER_LUT_MODE_CURRENT, &s->shaper_lut_mode);
+               REG_GET(RMU_3DLUT_MODE[0],
+                       MPC_RMU_3DLUT_MODE_CURRENT,  &s->lut3d_mode);
+               REG_GET(RMU_3DLUT_READ_WRITE_CONTROL[0],
+                       MPC_RMU_3DLUT_30BIT_EN, &s->lut3d_bit_depth);
+               REG_GET(RMU_3DLUT_MODE[0],
+                       MPC_RMU_3DLUT_SIZE, &s->lut3d_size);
+       } else {
+               REG_GET(SHAPER_CONTROL[1],
+                       MPC_RMU_SHAPER_LUT_MODE_CURRENT, &s->shaper_lut_mode);
+               REG_GET(RMU_3DLUT_MODE[1],
+                       MPC_RMU_3DLUT_MODE_CURRENT,  &s->lut3d_mode);
+               REG_GET(RMU_3DLUT_READ_WRITE_CONTROL[1],
+                       MPC_RMU_3DLUT_30BIT_EN, &s->lut3d_bit_depth);
+               REG_GET(RMU_3DLUT_MODE[1],
+                       MPC_RMU_3DLUT_SIZE, &s->lut3d_size);
+       }
+
+       REG_GET_2(MPCC_OGAM_CONTROL[mpcc_inst],
+                 MPCC_OGAM_MODE_CURRENT, &s->rgam_mode,
+                 MPCC_OGAM_SELECT_CURRENT, &s->rgam_lut);
+}
+
+static const struct mpc_funcs dcn30_mpc_funcs = {
+       .read_mpcc_state = mpc3_read_mpcc_state,
+       .insert_plane = mpc1_insert_plane,
+       .remove_mpcc = mpc1_remove_mpcc,
+       .mpc_init = mpc3_mpc_init,
+       .mpc_init_single_inst = mpc3_mpc_init_single_inst,
+       .update_blending = mpc2_update_blending,
+       .cursor_lock = mpc1_cursor_lock,
+       .get_mpcc_for_dpp = mpc1_get_mpcc_for_dpp,
+       .wait_for_idle = mpc2_assert_idle_mpcc,
+       .assert_mpcc_idle_before_connect = mpc2_assert_mpcc_idle_before_connect,
+       .init_mpcc_list_from_hw = mpc1_init_mpcc_list_from_hw,
+       .set_denorm =  mpc3_set_denorm,
+       .set_denorm_clamp = mpc3_set_denorm_clamp,
+       .set_output_csc = mpc3_set_output_csc,
+       .set_ocsc_default = mpc3_set_ocsc_default,
+       .set_output_gamma = mpc3_set_output_gamma,
+       .insert_plane_to_secondary = NULL,
+       .remove_mpcc_from_secondary =  NULL,
+       .set_dwb_mux = mpc3_set_dwb_mux,
+       .disable_dwb_mux = mpc3_disable_dwb_mux,
+       .is_dwb_idle = mpc3_is_dwb_idle,
+       .set_gamut_remap = mpc3_set_gamut_remap,
+       .program_shaper = mpc3_program_shaper,
+       .acquire_rmu = mpcc3_acquire_rmu,
+       .program_3dlut = mpc3_program_3dlut,
+       .release_rmu = mpcc3_release_rmu,
+       .power_on_mpc_mem_pwr = mpc3_power_on_ogam_lut,
+       .get_mpc_out_mux = mpc1_get_mpc_out_mux,
+       .set_bg_color = mpc1_set_bg_color,
+       .set_mpc_mem_lp_mode = mpc3_set_mpc_mem_lp_mode,
+};
+
+void dcn30_mpc_construct(struct dcn30_mpc *mpc30,
+       struct dc_context *ctx,
+       const struct dcn30_mpc_registers *mpc_regs,
+       const struct dcn30_mpc_shift *mpc_shift,
+       const struct dcn30_mpc_mask *mpc_mask,
+       int num_mpcc,
+       int num_rmu)
+{
+       int i;
+
+       mpc30->base.ctx = ctx;
+
+       mpc30->base.funcs = &dcn30_mpc_funcs;
+
+       mpc30->mpc_regs = mpc_regs;
+       mpc30->mpc_shift = mpc_shift;
+       mpc30->mpc_mask = mpc_mask;
+
+       mpc30->mpcc_in_use_mask = 0;
+       mpc30->num_mpcc = num_mpcc;
+       mpc30->num_rmu = num_rmu;
+
+       for (i = 0; i < MAX_MPCC; i++)
+               mpc3_init_mpcc(&mpc30->base.mpcc_array[i], i);
+}
+
diff --git a/drivers/gpu/drm/amd/display/dc/mpc/dcn30/dcn30_mpc.h b/drivers/gpu/drm/amd/display/dc/mpc/dcn30/dcn30_mpc.h
new file mode 100644 (file)
index 0000000..ce93003
--- /dev/null
@@ -0,0 +1,1098 @@
+/* Copyright 2020 Advanced Micro Devices, Inc.
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining a
+ * copy of this software and associated documentation files (the "Software"),
+ * to deal in the Software without restriction, including without limitation
+ * the rights to use, copy, modify, merge, publish, distribute, sublicense,
+ * and/or sell copies of the Software, and to permit persons to whom the
+ * Software is furnished to do so, subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be included in
+ * all copies or substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
+ * THE COPYRIGHT HOLDER(S) OR AUTHOR(S) BE LIABLE FOR ANY CLAIM, DAMAGES OR
+ * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE,
+ * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
+ * OTHER DEALINGS IN THE SOFTWARE.
+ *
+ * Authors: AMD
+ *
+ */
+
+#ifndef __DC_MPCC_DCN30_H__
+#define __DC_MPCC_DCN30_H__
+
+#include "dcn20/dcn20_mpc.h"
+
+#define MAX_RMU 3
+
+#define TO_DCN30_MPC(mpc_base) \
+       container_of(mpc_base, struct dcn30_mpc, base)
+
+#ifdef SRII_MPC_RMU
+#undef SRII_MPC_RMU
+
+#define SRII_MPC_RMU(reg_name, block, id)\
+       .RMU##_##reg_name[id] = BASE(mm ## block ## id ## _ ## reg_name ## _BASE_IDX) + \
+                                       mm ## block ## id ## _ ## reg_name
+
+#endif
+
+
+#define MPC_REG_LIST_DCN3_0(inst)\
+       MPC_COMMON_REG_LIST_DCN1_0(inst),\
+       SRII(MPCC_TOP_GAIN, MPCC, inst),\
+       SRII(MPCC_BOT_GAIN_INSIDE, MPCC, inst),\
+       SRII(MPCC_BOT_GAIN_OUTSIDE, MPCC, inst),\
+       SRII(MPCC_MEM_PWR_CTRL, MPCC, inst),\
+       SRII(MPCC_OGAM_LUT_INDEX, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_LUT_DATA, MPCC_OGAM, inst), \
+       SRII(MPCC_GAMUT_REMAP_COEF_FORMAT, MPCC_OGAM, inst),\
+       SRII(MPCC_GAMUT_REMAP_MODE, MPCC_OGAM, inst),\
+       SRII(MPC_GAMUT_REMAP_C11_C12_A, MPCC_OGAM, inst),\
+       SRII(MPC_GAMUT_REMAP_C33_C34_A, MPCC_OGAM, inst),\
+       SRII(MPC_GAMUT_REMAP_C11_C12_B, MPCC_OGAM, inst),\
+       SRII(MPC_GAMUT_REMAP_C33_C34_B, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMA_START_CNTL_B, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMA_START_CNTL_G, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMA_START_CNTL_R, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMA_START_SLOPE_CNTL_B, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMA_START_SLOPE_CNTL_G, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMA_START_SLOPE_CNTL_R, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMA_END_CNTL1_B, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMA_END_CNTL2_B, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMA_END_CNTL1_G, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMA_END_CNTL2_G, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMA_END_CNTL1_R, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMA_END_CNTL2_R, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMA_REGION_0_1, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMA_REGION_32_33, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMA_OFFSET_B, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMA_OFFSET_G, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMA_OFFSET_R, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMA_START_BASE_CNTL_B, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMA_START_BASE_CNTL_G, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMA_START_BASE_CNTL_R, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMB_START_CNTL_B, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMB_START_CNTL_G, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMB_START_CNTL_R, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMB_START_SLOPE_CNTL_B, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMB_START_SLOPE_CNTL_G, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMB_START_SLOPE_CNTL_R, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMB_END_CNTL1_B, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMB_END_CNTL2_B, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMB_END_CNTL1_G, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMB_END_CNTL2_G, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMB_END_CNTL1_R, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMB_END_CNTL2_R, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMB_REGION_0_1, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMB_REGION_32_33, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMB_OFFSET_B, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMB_OFFSET_G, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMB_OFFSET_R, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMB_START_BASE_CNTL_B, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMB_START_BASE_CNTL_G, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_RAMB_START_BASE_CNTL_R, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_CONTROL, MPCC_OGAM, inst),\
+       SRII(MPCC_OGAM_LUT_CONTROL, MPCC_OGAM, inst)
+
+#define MPC_OUT_MUX_REG_LIST_DCN3_0(inst) \
+       MPC_OUT_MUX_COMMON_REG_LIST_DCN1_0(inst),\
+       SRII(CSC_MODE, MPC_OUT, inst),\
+       SRII(CSC_C11_C12_A, MPC_OUT, inst),\
+       SRII(CSC_C33_C34_A, MPC_OUT, inst),\
+       SRII(CSC_C11_C12_B, MPC_OUT, inst),\
+       SRII(CSC_C33_C34_B, MPC_OUT, inst),\
+       SRII(DENORM_CONTROL, MPC_OUT, inst),\
+       SRII(DENORM_CLAMP_G_Y, MPC_OUT, inst),\
+       SRII(DENORM_CLAMP_B_CB, MPC_OUT, inst), \
+       SR(MPC_OUT_CSC_COEF_FORMAT)
+
+#define MPC_RMU_GLOBAL_REG_LIST_DCN3AG \
+       SR(MPC_RMU_CONTROL),\
+       SR(MPC_RMU_MEM_PWR_CTRL)
+
+#define MPC_RMU_REG_LIST_DCN3AG(inst) \
+       SRII(SHAPER_CONTROL, MPC_RMU, inst),\
+       SRII(SHAPER_OFFSET_R, MPC_RMU, inst),\
+       SRII(SHAPER_OFFSET_G, MPC_RMU, inst),\
+       SRII(SHAPER_OFFSET_B, MPC_RMU, inst),\
+       SRII(SHAPER_SCALE_R, MPC_RMU, inst),\
+       SRII(SHAPER_SCALE_G_B, MPC_RMU, inst),\
+       SRII(SHAPER_LUT_INDEX, MPC_RMU, inst),\
+       SRII(SHAPER_LUT_DATA, MPC_RMU, inst),\
+       SRII(SHAPER_LUT_WRITE_EN_MASK, MPC_RMU, inst),\
+       SRII(SHAPER_RAMA_START_CNTL_B, MPC_RMU, inst),\
+       SRII(SHAPER_RAMA_START_CNTL_G, MPC_RMU, inst),\
+       SRII(SHAPER_RAMA_START_CNTL_R, MPC_RMU, inst),\
+       SRII(SHAPER_RAMA_END_CNTL_B, MPC_RMU, inst),\
+       SRII(SHAPER_RAMA_END_CNTL_G, MPC_RMU, inst),\
+       SRII(SHAPER_RAMA_END_CNTL_R, MPC_RMU, inst),\
+       SRII(SHAPER_RAMA_REGION_0_1, MPC_RMU, inst),\
+       SRII(SHAPER_RAMA_REGION_2_3, MPC_RMU, inst),\
+       SRII(SHAPER_RAMA_REGION_4_5, MPC_RMU, inst),\
+       SRII(SHAPER_RAMA_REGION_6_7, MPC_RMU, inst),\
+       SRII(SHAPER_RAMA_REGION_8_9, MPC_RMU, inst),\
+       SRII(SHAPER_RAMA_REGION_10_11, MPC_RMU, inst),\
+       SRII(SHAPER_RAMA_REGION_12_13, MPC_RMU, inst),\
+       SRII(SHAPER_RAMA_REGION_14_15, MPC_RMU, inst),\
+       SRII(SHAPER_RAMA_REGION_16_17, MPC_RMU, inst),\
+       SRII(SHAPER_RAMA_REGION_18_19, MPC_RMU, inst),\
+       SRII(SHAPER_RAMA_REGION_20_21, MPC_RMU, inst),\
+       SRII(SHAPER_RAMA_REGION_22_23, MPC_RMU, inst),\
+       SRII(SHAPER_RAMA_REGION_24_25, MPC_RMU, inst),\
+       SRII(SHAPER_RAMA_REGION_26_27, MPC_RMU, inst),\
+       SRII(SHAPER_RAMA_REGION_28_29, MPC_RMU, inst),\
+       SRII(SHAPER_RAMA_REGION_30_31, MPC_RMU, inst),\
+       SRII(SHAPER_RAMA_REGION_32_33, MPC_RMU, inst),\
+       SRII(SHAPER_RAMB_START_CNTL_B, MPC_RMU, inst),\
+       SRII(SHAPER_RAMB_START_CNTL_G, MPC_RMU, inst),\
+       SRII(SHAPER_RAMB_START_CNTL_R, MPC_RMU, inst),\
+       SRII(SHAPER_RAMB_END_CNTL_B, MPC_RMU, inst),\
+       SRII(SHAPER_RAMB_END_CNTL_G, MPC_RMU, inst),\
+       SRII(SHAPER_RAMB_END_CNTL_R, MPC_RMU, inst),\
+       SRII(SHAPER_RAMB_REGION_0_1, MPC_RMU, inst),\
+       SRII(SHAPER_RAMB_REGION_2_3, MPC_RMU, inst),\
+       SRII(SHAPER_RAMB_REGION_4_5, MPC_RMU, inst),\
+       SRII(SHAPER_RAMB_REGION_6_7, MPC_RMU, inst),\
+       SRII(SHAPER_RAMB_REGION_8_9, MPC_RMU, inst),\
+       SRII(SHAPER_RAMB_REGION_10_11, MPC_RMU, inst),\
+       SRII(SHAPER_RAMB_REGION_12_13, MPC_RMU, inst),\
+       SRII(SHAPER_RAMB_REGION_14_15, MPC_RMU, inst),\
+       SRII(SHAPER_RAMB_REGION_16_17, MPC_RMU, inst),\
+       SRII(SHAPER_RAMB_REGION_18_19, MPC_RMU, inst),\
+       SRII(SHAPER_RAMB_REGION_20_21, MPC_RMU, inst),\
+       SRII(SHAPER_RAMB_REGION_22_23, MPC_RMU, inst),\
+       SRII(SHAPER_RAMB_REGION_24_25, MPC_RMU, inst),\
+       SRII(SHAPER_RAMB_REGION_26_27, MPC_RMU, inst),\
+       SRII(SHAPER_RAMB_REGION_28_29, MPC_RMU, inst),\
+       SRII(SHAPER_RAMB_REGION_30_31, MPC_RMU, inst),\
+       SRII(SHAPER_RAMB_REGION_32_33, MPC_RMU, inst),\
+       SRII_MPC_RMU(3DLUT_MODE, MPC_RMU, inst),\
+       SRII_MPC_RMU(3DLUT_INDEX, MPC_RMU, inst),\
+       SRII_MPC_RMU(3DLUT_DATA, MPC_RMU, inst),\
+       SRII_MPC_RMU(3DLUT_DATA_30BIT, MPC_RMU, inst),\
+       SRII_MPC_RMU(3DLUT_READ_WRITE_CONTROL, MPC_RMU, inst),\
+       SRII_MPC_RMU(3DLUT_OUT_NORM_FACTOR, MPC_RMU, inst),\
+       SRII_MPC_RMU(3DLUT_OUT_OFFSET_R, MPC_RMU, inst),\
+       SRII_MPC_RMU(3DLUT_OUT_OFFSET_G, MPC_RMU, inst),\
+       SRII_MPC_RMU(3DLUT_OUT_OFFSET_B, MPC_RMU, inst)
+
+
+#define MPC_DWB_MUX_REG_LIST_DCN3_0(inst) \
+       SRII_DWB(DWB_MUX, MUX, MPC_DWB, inst)
+
+#define MPC_REG_VARIABLE_LIST_DCN3_0 \
+       MPC_REG_VARIABLE_LIST_DCN2_0 \
+       uint32_t DWB_MUX[MAX_DWB]; \
+       uint32_t MPCC_GAMUT_REMAP_COEF_FORMAT[MAX_MPCC]; \
+       uint32_t MPCC_GAMUT_REMAP_MODE[MAX_MPCC]; \
+       uint32_t MPC_GAMUT_REMAP_C11_C12_A[MAX_MPCC]; \
+       uint32_t MPC_GAMUT_REMAP_C33_C34_A[MAX_MPCC]; \
+       uint32_t MPC_GAMUT_REMAP_C11_C12_B[MAX_MPCC]; \
+       uint32_t MPC_GAMUT_REMAP_C33_C34_B[MAX_MPCC]; \
+       uint32_t MPC_RMU_CONTROL; \
+       uint32_t MPC_RMU_MEM_PWR_CTRL; \
+       uint32_t SHAPER_CONTROL[MAX_RMU]; \
+       uint32_t SHAPER_OFFSET_R[MAX_RMU]; \
+       uint32_t SHAPER_OFFSET_G[MAX_RMU]; \
+       uint32_t SHAPER_OFFSET_B[MAX_RMU]; \
+       uint32_t SHAPER_SCALE_R[MAX_RMU]; \
+       uint32_t SHAPER_SCALE_G_B[MAX_RMU]; \
+       uint32_t SHAPER_LUT_INDEX[MAX_RMU]; \
+       uint32_t SHAPER_LUT_DATA[MAX_RMU]; \
+       uint32_t SHAPER_LUT_WRITE_EN_MASK[MAX_RMU]; \
+       uint32_t SHAPER_RAMA_START_CNTL_B[MAX_RMU]; \
+       uint32_t SHAPER_RAMA_START_CNTL_G[MAX_RMU]; \
+       uint32_t SHAPER_RAMA_START_CNTL_R[MAX_RMU]; \
+       uint32_t SHAPER_RAMA_END_CNTL_B[MAX_RMU]; \
+       uint32_t SHAPER_RAMA_END_CNTL_G[MAX_RMU]; \
+       uint32_t SHAPER_RAMA_END_CNTL_R[MAX_RMU]; \
+       uint32_t SHAPER_RAMA_REGION_0_1[MAX_RMU]; \
+       uint32_t SHAPER_RAMA_REGION_2_3[MAX_RMU]; \
+       uint32_t SHAPER_RAMA_REGION_4_5[MAX_RMU]; \
+       uint32_t SHAPER_RAMA_REGION_6_7[MAX_RMU]; \
+       uint32_t SHAPER_RAMA_REGION_8_9[MAX_RMU]; \
+       uint32_t SHAPER_RAMA_REGION_10_11[MAX_RMU]; \
+       uint32_t SHAPER_RAMA_REGION_12_13[MAX_RMU]; \
+       uint32_t SHAPER_RAMA_REGION_14_15[MAX_RMU]; \
+       uint32_t SHAPER_RAMA_REGION_16_17[MAX_RMU]; \
+       uint32_t SHAPER_RAMA_REGION_18_19[MAX_RMU]; \
+       uint32_t SHAPER_RAMA_REGION_20_21[MAX_RMU]; \
+       uint32_t SHAPER_RAMA_REGION_22_23[MAX_RMU]; \
+       uint32_t SHAPER_RAMA_REGION_24_25[MAX_RMU]; \
+       uint32_t SHAPER_RAMA_REGION_26_27[MAX_RMU]; \
+       uint32_t SHAPER_RAMA_REGION_28_29[MAX_RMU]; \
+       uint32_t SHAPER_RAMA_REGION_30_31[MAX_RMU]; \
+       uint32_t SHAPER_RAMA_REGION_32_33[MAX_RMU]; \
+       uint32_t MPCC_OGAM_RAMA_START_SLOPE_CNTL_B[MAX_MPCC]; \
+       uint32_t MPCC_OGAM_RAMA_START_SLOPE_CNTL_G[MAX_MPCC]; \
+       uint32_t MPCC_OGAM_RAMA_START_SLOPE_CNTL_R[MAX_MPCC]; \
+       uint32_t MPCC_OGAM_RAMA_OFFSET_B[MAX_MPCC]; \
+       uint32_t MPCC_OGAM_RAMA_OFFSET_G[MAX_MPCC]; \
+       uint32_t MPCC_OGAM_RAMA_OFFSET_R[MAX_MPCC]; \
+       uint32_t MPCC_OGAM_RAMA_START_BASE_CNTL_B[MAX_MPCC]; \
+       uint32_t MPCC_OGAM_RAMA_START_BASE_CNTL_G[MAX_MPCC]; \
+       uint32_t MPCC_OGAM_RAMA_START_BASE_CNTL_R[MAX_MPCC];\
+       uint32_t SHAPER_RAMB_START_CNTL_B[MAX_RMU]; \
+       uint32_t SHAPER_RAMB_START_CNTL_G[MAX_RMU]; \
+       uint32_t SHAPER_RAMB_START_CNTL_R[MAX_RMU]; \
+       uint32_t SHAPER_RAMB_END_CNTL_B[MAX_RMU]; \
+       uint32_t SHAPER_RAMB_END_CNTL_G[MAX_RMU]; \
+       uint32_t SHAPER_RAMB_END_CNTL_R[MAX_RMU]; \
+       uint32_t SHAPER_RAMB_REGION_0_1[MAX_RMU]; \
+       uint32_t SHAPER_RAMB_REGION_2_3[MAX_RMU]; \
+       uint32_t SHAPER_RAMB_REGION_4_5[MAX_RMU]; \
+       uint32_t SHAPER_RAMB_REGION_6_7[MAX_RMU]; \
+       uint32_t SHAPER_RAMB_REGION_8_9[MAX_RMU]; \
+       uint32_t SHAPER_RAMB_REGION_10_11[MAX_RMU]; \
+       uint32_t SHAPER_RAMB_REGION_12_13[MAX_RMU]; \
+       uint32_t SHAPER_RAMB_REGION_14_15[MAX_RMU]; \
+       uint32_t SHAPER_RAMB_REGION_16_17[MAX_RMU]; \
+       uint32_t SHAPER_RAMB_REGION_18_19[MAX_RMU]; \
+       uint32_t SHAPER_RAMB_REGION_20_21[MAX_RMU]; \
+       uint32_t SHAPER_RAMB_REGION_22_23[MAX_RMU]; \
+       uint32_t SHAPER_RAMB_REGION_24_25[MAX_RMU]; \
+       uint32_t SHAPER_RAMB_REGION_26_27[MAX_RMU]; \
+       uint32_t SHAPER_RAMB_REGION_28_29[MAX_RMU]; \
+       uint32_t SHAPER_RAMB_REGION_30_31[MAX_RMU]; \
+       uint32_t SHAPER_RAMB_REGION_32_33[MAX_RMU]; \
+       uint32_t RMU_3DLUT_MODE[MAX_RMU]; \
+       uint32_t RMU_3DLUT_INDEX[MAX_RMU]; \
+       uint32_t RMU_3DLUT_DATA[MAX_RMU]; \
+       uint32_t RMU_3DLUT_DATA_30BIT[MAX_RMU]; \
+       uint32_t RMU_3DLUT_READ_WRITE_CONTROL[MAX_RMU]; \
+       uint32_t RMU_3DLUT_OUT_NORM_FACTOR[MAX_RMU]; \
+       uint32_t RMU_3DLUT_OUT_OFFSET_R[MAX_RMU]; \
+       uint32_t RMU_3DLUT_OUT_OFFSET_G[MAX_RMU]; \
+       uint32_t RMU_3DLUT_OUT_OFFSET_B[MAX_RMU]; \
+       uint32_t MPCC_OGAM_RAMB_START_SLOPE_CNTL_B[MAX_MPCC]; \
+       uint32_t MPCC_OGAM_RAMB_START_SLOPE_CNTL_G[MAX_MPCC]; \
+       uint32_t MPCC_OGAM_RAMB_START_SLOPE_CNTL_R[MAX_MPCC]; \
+       uint32_t MPCC_OGAM_CONTROL[MAX_MPCC]; \
+       uint32_t MPCC_OGAM_LUT_CONTROL[MAX_MPCC]; \
+       uint32_t MPCC_OGAM_RAMB_OFFSET_B[MAX_MPCC]; \
+       uint32_t MPCC_OGAM_RAMB_OFFSET_G[MAX_MPCC]; \
+       uint32_t MPCC_OGAM_RAMB_OFFSET_R[MAX_MPCC]; \
+       uint32_t MPCC_OGAM_RAMB_START_BASE_CNTL_B[MAX_MPCC]; \
+       uint32_t MPCC_OGAM_RAMB_START_BASE_CNTL_G[MAX_MPCC]; \
+       uint32_t MPCC_OGAM_RAMB_START_BASE_CNTL_R[MAX_MPCC]; \
+       uint32_t MPC_OUT_CSC_COEF_FORMAT
+
+#define MPC_REG_VARIABLE_LIST_DCN32 \
+       uint32_t MPCC_MOVABLE_CM_LOCATION_CONTROL[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_CONTROL[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_OFFSET_R[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_OFFSET_G[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_OFFSET_B[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_SCALE_R[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_SCALE_G_B[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_LUT_INDEX[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_LUT_DATA[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_LUT_WRITE_EN_MASK[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_RAMA_START_CNTL_B[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_RAMA_START_CNTL_G[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_RAMA_START_CNTL_R[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_RAMA_END_CNTL_B[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_RAMA_END_CNTL_G[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_RAMA_END_CNTL_R[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_RAMA_REGION_0_1[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_RAMA_REGION_2_3[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_RAMA_REGION_4_5[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_RAMA_REGION_6_7[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_RAMA_REGION_8_9[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_RAMA_REGION_10_11[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_RAMA_REGION_12_13[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_RAMA_REGION_14_15[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_RAMA_REGION_16_17[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_RAMA_REGION_18_19[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_RAMA_REGION_20_21[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_RAMA_REGION_22_23[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_RAMA_REGION_24_25[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_RAMA_REGION_26_27[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_RAMA_REGION_28_29[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_RAMA_REGION_30_31[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_RAMA_REGION_32_33[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_RAMB_START_CNTL_B[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_RAMB_START_CNTL_G[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_RAMB_START_CNTL_R[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_RAMB_END_CNTL_B[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_RAMB_END_CNTL_G[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_RAMB_END_CNTL_R[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_RAMB_REGION_0_1[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_RAMB_REGION_2_3[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_RAMB_REGION_4_5[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_RAMB_REGION_6_7[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_RAMB_REGION_8_9[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_RAMB_REGION_10_11[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_RAMB_REGION_12_13[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_RAMB_REGION_14_15[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_RAMB_REGION_16_17[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_RAMB_REGION_18_19[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_RAMB_REGION_20_21[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_RAMB_REGION_22_23[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_RAMB_REGION_24_25[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_RAMB_REGION_26_27[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_RAMB_REGION_28_29[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_RAMB_REGION_30_31[MAX_MPCC]; \
+       uint32_t MPCC_MCM_SHAPER_RAMB_REGION_32_33[MAX_MPCC]; \
+       uint32_t MPCC_MCM_3DLUT_MODE[MAX_MPCC]; \
+       uint32_t MPCC_MCM_3DLUT_INDEX[MAX_MPCC]; \
+       uint32_t MPCC_MCM_3DLUT_DATA[MAX_MPCC]; \
+       uint32_t MPCC_MCM_3DLUT_DATA_30BIT[MAX_MPCC]; \
+       uint32_t MPCC_MCM_3DLUT_READ_WRITE_CONTROL[MAX_MPCC]; \
+       uint32_t MPCC_MCM_3DLUT_OUT_NORM_FACTOR[MAX_MPCC]; \
+       uint32_t MPCC_MCM_3DLUT_OUT_OFFSET_R[MAX_MPCC]; \
+       uint32_t MPCC_MCM_3DLUT_OUT_OFFSET_G[MAX_MPCC]; \
+       uint32_t MPCC_MCM_3DLUT_OUT_OFFSET_B[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_CONTROL[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_LUT_INDEX[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_LUT_DATA[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_LUT_CONTROL[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMA_START_CNTL_B[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMA_START_CNTL_G[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMA_START_CNTL_R[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMA_START_SLOPE_CNTL_B[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMA_START_SLOPE_CNTL_G[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMA_START_SLOPE_CNTL_R[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMA_START_BASE_CNTL_B[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMA_START_BASE_CNTL_G[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMA_START_BASE_CNTL_R[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMA_END_CNTL1_B[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMA_END_CNTL2_B[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMA_END_CNTL1_G[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMA_END_CNTL2_G[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMA_END_CNTL1_R[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMA_END_CNTL2_R[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMA_OFFSET_B[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMA_OFFSET_G[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMA_OFFSET_R[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMA_REGION_0_1[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMA_REGION_2_3[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMA_REGION_4_5[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMA_REGION_6_7[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMA_REGION_8_9[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMA_REGION_10_11[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMA_REGION_12_13[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMA_REGION_14_15[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMA_REGION_16_17[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMA_REGION_18_19[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMA_REGION_20_21[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMA_REGION_22_23[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMA_REGION_24_25[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMA_REGION_26_27[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMA_REGION_28_29[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMA_REGION_30_31[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMA_REGION_32_33[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMB_START_CNTL_B[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMB_START_CNTL_G[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMB_START_CNTL_R[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMB_START_SLOPE_CNTL_B[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMB_START_SLOPE_CNTL_G[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMB_START_SLOPE_CNTL_R[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMB_START_BASE_CNTL_B[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMB_START_BASE_CNTL_G[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMB_START_BASE_CNTL_R[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMB_END_CNTL1_B[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMB_END_CNTL2_B[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMB_END_CNTL1_G[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMB_END_CNTL2_G[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMB_END_CNTL1_R[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMB_END_CNTL2_R[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMB_OFFSET_B[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMB_OFFSET_G[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMB_OFFSET_R[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMB_REGION_0_1[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMB_REGION_2_3[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMB_REGION_4_5[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMB_REGION_6_7[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMB_REGION_8_9[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMB_REGION_10_11[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMB_REGION_12_13[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMB_REGION_14_15[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMB_REGION_16_17[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMB_REGION_18_19[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMB_REGION_20_21[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMB_REGION_22_23[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMB_REGION_24_25[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMB_REGION_26_27[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMB_REGION_28_29[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMB_REGION_30_31[MAX_MPCC]; \
+       uint32_t MPCC_MCM_1DLUT_RAMB_REGION_32_33[MAX_MPCC]; \
+       uint32_t MPCC_MCM_MEM_PWR_CTRL[MAX_MPCC]
+
+#define MPC_COMMON_MASK_SH_LIST_DCN3_0(mask_sh) \
+       MPC_COMMON_MASK_SH_LIST_DCN1_0(mask_sh),\
+       SF(MPCC0_MPCC_CONTROL, MPCC_BG_BPC, mask_sh),\
+       SF(MPCC0_MPCC_CONTROL, MPCC_BOT_GAIN_MODE, mask_sh),\
+       SF(MPCC0_MPCC_TOP_GAIN, MPCC_TOP_GAIN, mask_sh),\
+       SF(MPCC0_MPCC_BOT_GAIN_INSIDE, MPCC_BOT_GAIN_INSIDE, mask_sh),\
+       SF(MPCC0_MPCC_BOT_GAIN_OUTSIDE, MPCC_BOT_GAIN_OUTSIDE, mask_sh),\
+       SF(MPC_OUT0_CSC_MODE, MPC_OCSC_MODE, mask_sh),\
+       SF(MPC_OUT0_CSC_C11_C12_A, MPC_OCSC_C11_A, mask_sh),\
+       SF(MPC_OUT0_CSC_C11_C12_A, MPC_OCSC_C12_A, mask_sh),\
+       SF(MPCC0_MPCC_STATUS, MPCC_DISABLED, mask_sh),\
+       SF(MPCC0_MPCC_MEM_PWR_CTRL, MPCC_OGAM_MEM_PWR_FORCE, mask_sh),\
+       SF(MPCC0_MPCC_MEM_PWR_CTRL, MPCC_OGAM_MEM_PWR_DIS, mask_sh),\
+       SF(MPCC0_MPCC_MEM_PWR_CTRL, MPCC_OGAM_MEM_PWR_STATE, mask_sh),\
+       SF(MPC_OUT0_DENORM_CONTROL, MPC_OUT_DENORM_MODE, mask_sh),\
+       SF(MPC_OUT0_DENORM_CONTROL, MPC_OUT_DENORM_CLAMP_MAX_R_CR, mask_sh),\
+       SF(MPC_OUT0_DENORM_CONTROL, MPC_OUT_DENORM_CLAMP_MIN_R_CR, mask_sh),\
+       SF(MPC_OUT0_DENORM_CLAMP_G_Y, MPC_OUT_DENORM_CLAMP_MAX_G_Y, mask_sh),\
+       SF(MPC_OUT0_DENORM_CLAMP_G_Y, MPC_OUT_DENORM_CLAMP_MIN_G_Y, mask_sh),\
+       SF(MPC_OUT0_DENORM_CLAMP_B_CB, MPC_OUT_DENORM_CLAMP_MAX_B_CB, mask_sh),\
+       SF(MPC_OUT0_DENORM_CLAMP_B_CB, MPC_OUT_DENORM_CLAMP_MIN_B_CB, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_GAMUT_REMAP_MODE, MPCC_GAMUT_REMAP_MODE, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_GAMUT_REMAP_MODE, MPCC_GAMUT_REMAP_MODE_CURRENT, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_GAMUT_REMAP_COEF_FORMAT, MPCC_GAMUT_REMAP_COEF_FORMAT, mask_sh),\
+       SF(MPCC_OGAM0_MPC_GAMUT_REMAP_C11_C12_A, MPCC_GAMUT_REMAP_C11_A, mask_sh),\
+       SF(MPCC_OGAM0_MPC_GAMUT_REMAP_C11_C12_A, MPCC_GAMUT_REMAP_C12_A, mask_sh),\
+       SF(MPC_DWB0_MUX, MPC_DWB0_MUX, mask_sh),\
+       SF(MPC_DWB0_MUX, MPC_DWB0_MUX_STATUS, mask_sh),\
+       SF(MPC_OUT0_MUX, MPC_OUT_RATE_CONTROL, mask_sh),\
+       SF(MPC_OUT0_MUX, MPC_OUT_RATE_CONTROL_DISABLE, mask_sh),\
+       SF(MPC_OUT0_MUX, MPC_OUT_FLOW_CONTROL_MODE, mask_sh),\
+       SF(MPC_OUT0_MUX, MPC_OUT_FLOW_CONTROL_COUNT, mask_sh), \
+       SF(MPC_RMU_CONTROL, MPC_RMU0_MUX, mask_sh), \
+       SF(MPC_RMU_CONTROL, MPC_RMU1_MUX, mask_sh), \
+       SF(MPC_RMU_CONTROL, MPC_RMU0_MUX_STATUS, mask_sh), \
+       SF(MPC_RMU_CONTROL, MPC_RMU1_MUX_STATUS, mask_sh), \
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_REGION_0_1, MPCC_OGAM_RAMA_EXP_REGION0_LUT_OFFSET, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_REGION_0_1, MPCC_OGAM_RAMA_EXP_REGION0_NUM_SEGMENTS, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_REGION_0_1, MPCC_OGAM_RAMA_EXP_REGION1_LUT_OFFSET, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_REGION_0_1, MPCC_OGAM_RAMA_EXP_REGION1_NUM_SEGMENTS, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_END_CNTL2_B, MPCC_OGAM_RAMA_EXP_REGION_END_SLOPE_B, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_END_CNTL2_B, MPCC_OGAM_RAMA_EXP_REGION_END_B, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_END_CNTL1_B, MPCC_OGAM_RAMA_EXP_REGION_END_BASE_B, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_START_SLOPE_CNTL_B, MPCC_OGAM_RAMA_EXP_REGION_START_SLOPE_B, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_START_BASE_CNTL_B, MPCC_OGAM_RAMA_EXP_REGION_START_BASE_B, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_START_CNTL_B, MPCC_OGAM_RAMA_EXP_REGION_START_B, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_START_CNTL_B, MPCC_OGAM_RAMA_EXP_REGION_START_SEGMENT_B, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_OFFSET_B, MPCC_OGAM_RAMA_OFFSET_B, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_OFFSET_G, MPCC_OGAM_RAMA_OFFSET_G, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_OFFSET_R, MPCC_OGAM_RAMA_OFFSET_R, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_LUT_INDEX, MPCC_OGAM_LUT_INDEX, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_CONTROL, MPCC_OGAM_MODE, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_CONTROL, MPCC_OGAM_SELECT, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_CONTROL, MPCC_OGAM_PWL_DISABLE, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_CONTROL, MPCC_OGAM_MODE_CURRENT, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_CONTROL, MPCC_OGAM_SELECT_CURRENT, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_LUT_CONTROL, MPCC_OGAM_LUT_WRITE_COLOR_MASK, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_LUT_CONTROL, MPCC_OGAM_LUT_READ_COLOR_SEL, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_LUT_CONTROL, MPCC_OGAM_LUT_READ_DBG, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_LUT_CONTROL, MPCC_OGAM_LUT_HOST_SEL, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_LUT_CONTROL, MPCC_OGAM_LUT_CONFIG_MODE, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_LUT_CONTROL, MPCC_OGAM_LUT_STATUS, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_LUT_DATA, MPCC_OGAM_LUT_DATA, mask_sh),\
+       SF(MPC_RMU0_3DLUT_MODE, MPC_RMU_3DLUT_MODE, mask_sh),\
+       SF(MPC_RMU0_3DLUT_MODE, MPC_RMU_3DLUT_SIZE, mask_sh),\
+       SF(MPC_RMU0_3DLUT_MODE, MPC_RMU_3DLUT_MODE_CURRENT, mask_sh),\
+       SF(MPC_RMU0_3DLUT_READ_WRITE_CONTROL, MPC_RMU_3DLUT_WRITE_EN_MASK, mask_sh),\
+       SF(MPC_RMU0_3DLUT_READ_WRITE_CONTROL, MPC_RMU_3DLUT_RAM_SEL, mask_sh),\
+       SF(MPC_RMU0_3DLUT_READ_WRITE_CONTROL, MPC_RMU_3DLUT_30BIT_EN, mask_sh),\
+       SF(MPC_RMU0_3DLUT_READ_WRITE_CONTROL, MPC_RMU_3DLUT_CONFIG_STATUS, mask_sh),\
+       SF(MPC_RMU0_3DLUT_READ_WRITE_CONTROL, MPC_RMU_3DLUT_READ_SEL, mask_sh),\
+       SF(MPC_RMU0_3DLUT_INDEX, MPC_RMU_3DLUT_INDEX, mask_sh),\
+       SF(MPC_RMU0_3DLUT_DATA, MPC_RMU_3DLUT_DATA0, mask_sh),\
+       SF(MPC_RMU0_3DLUT_DATA, MPC_RMU_3DLUT_DATA1, mask_sh),\
+       SF(MPC_RMU0_3DLUT_DATA_30BIT, MPC_RMU_3DLUT_DATA_30BIT, mask_sh),\
+       SF(MPC_RMU0_SHAPER_CONTROL, MPC_RMU_SHAPER_LUT_MODE, mask_sh),\
+       SF(MPC_RMU0_SHAPER_CONTROL, MPC_RMU_SHAPER_LUT_MODE_CURRENT, mask_sh),\
+       SF(MPC_RMU0_SHAPER_OFFSET_R, MPC_RMU_SHAPER_OFFSET_R, mask_sh),\
+       SF(MPC_RMU0_SHAPER_OFFSET_G, MPC_RMU_SHAPER_OFFSET_G, mask_sh),\
+       SF(MPC_RMU0_SHAPER_OFFSET_B, MPC_RMU_SHAPER_OFFSET_B, mask_sh),\
+       SF(MPC_RMU0_SHAPER_SCALE_R, MPC_RMU_SHAPER_SCALE_R, mask_sh),\
+       SF(MPC_RMU0_SHAPER_SCALE_G_B, MPC_RMU_SHAPER_SCALE_G, mask_sh),\
+       SF(MPC_RMU0_SHAPER_SCALE_G_B, MPC_RMU_SHAPER_SCALE_B, mask_sh),\
+       SF(MPC_RMU0_SHAPER_LUT_INDEX, MPC_RMU_SHAPER_LUT_INDEX, mask_sh),\
+       SF(MPC_RMU0_SHAPER_LUT_DATA, MPC_RMU_SHAPER_LUT_DATA, mask_sh),\
+       SF(MPC_RMU0_SHAPER_LUT_WRITE_EN_MASK, MPC_RMU_SHAPER_LUT_WRITE_EN_MASK, mask_sh),\
+       SF(MPC_RMU0_SHAPER_LUT_WRITE_EN_MASK, MPC_RMU_SHAPER_LUT_WRITE_SEL, mask_sh),\
+       SF(MPC_RMU0_SHAPER_LUT_WRITE_EN_MASK, MPC_RMU_SHAPER_CONFIG_STATUS, mask_sh),\
+       SF(MPC_RMU0_SHAPER_RAMA_START_CNTL_B, MPC_RMU_SHAPER_RAMA_EXP_REGION_START_B, mask_sh),\
+       SF(MPC_RMU0_SHAPER_RAMA_START_CNTL_B, MPC_RMU_SHAPER_RAMA_EXP_REGION_START_SEGMENT_B, mask_sh),\
+       SF(MPC_RMU0_SHAPER_RAMA_END_CNTL_B, MPC_RMU_SHAPER_RAMA_EXP_REGION_END_B, mask_sh),\
+       SF(MPC_RMU0_SHAPER_RAMA_END_CNTL_B, MPC_RMU_SHAPER_RAMA_EXP_REGION_END_BASE_B, mask_sh),\
+       SF(MPC_RMU0_SHAPER_RAMA_REGION_0_1, MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, mask_sh),\
+       SF(MPC_RMU0_SHAPER_RAMA_REGION_0_1, MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, mask_sh),\
+       SF(MPC_RMU0_SHAPER_RAMA_REGION_0_1, MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, mask_sh),\
+       SF(MPC_RMU0_SHAPER_RAMA_REGION_0_1, MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, mask_sh),\
+       SF(MPC_RMU_MEM_PWR_CTRL, MPC_RMU0_MEM_PWR_FORCE, mask_sh),\
+       SF(MPC_RMU_MEM_PWR_CTRL, MPC_RMU0_MEM_PWR_DIS, mask_sh),\
+       SF(MPC_RMU_MEM_PWR_CTRL, MPC_RMU0_SHAPER_MEM_PWR_STATE, mask_sh),\
+       SF(MPC_RMU_MEM_PWR_CTRL, MPC_RMU0_3DLUT_MEM_PWR_STATE, mask_sh),\
+       SF(MPC_RMU_MEM_PWR_CTRL, MPC_RMU1_MEM_PWR_FORCE, mask_sh),\
+       SF(MPC_RMU_MEM_PWR_CTRL, MPC_RMU1_MEM_PWR_DIS, mask_sh),\
+       SF(MPC_RMU_MEM_PWR_CTRL, MPC_RMU1_SHAPER_MEM_PWR_STATE, mask_sh),\
+       SF(MPC_RMU_MEM_PWR_CTRL, MPC_RMU1_3DLUT_MEM_PWR_STATE, mask_sh),\
+       SF(CUR_VUPDATE_LOCK_SET0, CUR_VUPDATE_LOCK_SET, mask_sh)
+
+
+#define MPC_COMMON_MASK_SH_LIST_DCN30(mask_sh) \
+       MPC_COMMON_MASK_SH_LIST_DCN1_0(mask_sh),\
+       SF(MPCC0_MPCC_CONTROL, MPCC_BG_BPC, mask_sh),\
+       SF(MPCC0_MPCC_CONTROL, MPCC_BOT_GAIN_MODE, mask_sh),\
+       SF(MPCC0_MPCC_TOP_GAIN, MPCC_TOP_GAIN, mask_sh),\
+       SF(MPCC0_MPCC_BOT_GAIN_INSIDE, MPCC_BOT_GAIN_INSIDE, mask_sh),\
+       SF(MPCC0_MPCC_BOT_GAIN_OUTSIDE, MPCC_BOT_GAIN_OUTSIDE, mask_sh),\
+       SF(MPC_OUT0_CSC_MODE, MPC_OCSC_MODE, mask_sh),\
+       SF(MPC_OUT0_CSC_C11_C12_A, MPC_OCSC_C11_A, mask_sh),\
+       SF(MPC_OUT0_CSC_C11_C12_A, MPC_OCSC_C12_A, mask_sh),\
+       SF(MPCC0_MPCC_STATUS, MPCC_DISABLED, mask_sh),\
+       SF(MPCC0_MPCC_MEM_PWR_CTRL, MPCC_OGAM_MEM_PWR_FORCE, mask_sh),\
+       SF(MPCC0_MPCC_MEM_PWR_CTRL, MPCC_OGAM_MEM_PWR_DIS, mask_sh),\
+       SF(MPCC0_MPCC_MEM_PWR_CTRL, MPCC_OGAM_MEM_LOW_PWR_MODE, mask_sh),\
+       SF(MPCC0_MPCC_MEM_PWR_CTRL, MPCC_OGAM_MEM_PWR_STATE, mask_sh),\
+       SF(MPC_OUT0_DENORM_CONTROL, MPC_OUT_DENORM_MODE, mask_sh),\
+       SF(MPC_OUT0_DENORM_CONTROL, MPC_OUT_DENORM_CLAMP_MAX_R_CR, mask_sh),\
+       SF(MPC_OUT0_DENORM_CONTROL, MPC_OUT_DENORM_CLAMP_MIN_R_CR, mask_sh),\
+       SF(MPC_OUT0_DENORM_CLAMP_G_Y, MPC_OUT_DENORM_CLAMP_MAX_G_Y, mask_sh),\
+       SF(MPC_OUT0_DENORM_CLAMP_G_Y, MPC_OUT_DENORM_CLAMP_MIN_G_Y, mask_sh),\
+       SF(MPC_OUT0_DENORM_CLAMP_B_CB, MPC_OUT_DENORM_CLAMP_MAX_B_CB, mask_sh),\
+       SF(MPC_OUT0_DENORM_CLAMP_B_CB, MPC_OUT_DENORM_CLAMP_MIN_B_CB, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_GAMUT_REMAP_MODE, MPCC_GAMUT_REMAP_MODE, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_GAMUT_REMAP_MODE, MPCC_GAMUT_REMAP_MODE_CURRENT, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_GAMUT_REMAP_COEF_FORMAT, MPCC_GAMUT_REMAP_COEF_FORMAT, mask_sh),\
+       SF(MPCC_OGAM0_MPC_GAMUT_REMAP_C11_C12_A, MPCC_GAMUT_REMAP_C11_A, mask_sh),\
+       SF(MPCC_OGAM0_MPC_GAMUT_REMAP_C11_C12_A, MPCC_GAMUT_REMAP_C12_A, mask_sh),\
+       SF(MPC_DWB0_MUX, MPC_DWB0_MUX, mask_sh),\
+       SF(MPC_DWB0_MUX, MPC_DWB0_MUX_STATUS, mask_sh),\
+       SF(MPC_OUT0_MUX, MPC_OUT_RATE_CONTROL, mask_sh),\
+       SF(MPC_OUT0_MUX, MPC_OUT_RATE_CONTROL_DISABLE, mask_sh),\
+       SF(MPC_OUT0_MUX, MPC_OUT_FLOW_CONTROL_MODE, mask_sh),\
+       SF(MPC_OUT0_MUX, MPC_OUT_FLOW_CONTROL_COUNT, mask_sh), \
+       SF(MPC_RMU_CONTROL, MPC_RMU0_MUX, mask_sh), \
+       SF(MPC_RMU_CONTROL, MPC_RMU1_MUX, mask_sh), \
+       SF(MPC_RMU_CONTROL, MPC_RMU0_MUX_STATUS, mask_sh), \
+       SF(MPC_RMU_CONTROL, MPC_RMU1_MUX_STATUS, mask_sh), \
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_REGION_0_1, MPCC_OGAM_RAMA_EXP_REGION0_LUT_OFFSET, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_REGION_0_1, MPCC_OGAM_RAMA_EXP_REGION0_NUM_SEGMENTS, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_REGION_0_1, MPCC_OGAM_RAMA_EXP_REGION1_LUT_OFFSET, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_REGION_0_1, MPCC_OGAM_RAMA_EXP_REGION1_NUM_SEGMENTS, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_END_CNTL2_B, MPCC_OGAM_RAMA_EXP_REGION_END_SLOPE_B, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_END_CNTL2_B, MPCC_OGAM_RAMA_EXP_REGION_END_B, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_END_CNTL1_B, MPCC_OGAM_RAMA_EXP_REGION_END_BASE_B, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_START_SLOPE_CNTL_B, MPCC_OGAM_RAMA_EXP_REGION_START_SLOPE_B, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_START_BASE_CNTL_B, MPCC_OGAM_RAMA_EXP_REGION_START_BASE_B, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_START_CNTL_B, MPCC_OGAM_RAMA_EXP_REGION_START_B, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_START_CNTL_B, MPCC_OGAM_RAMA_EXP_REGION_START_SEGMENT_B, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_OFFSET_B, MPCC_OGAM_RAMA_OFFSET_B, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_OFFSET_G, MPCC_OGAM_RAMA_OFFSET_G, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_OFFSET_R, MPCC_OGAM_RAMA_OFFSET_R, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_LUT_INDEX, MPCC_OGAM_LUT_INDEX, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_CONTROL, MPCC_OGAM_MODE, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_CONTROL, MPCC_OGAM_SELECT, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_CONTROL, MPCC_OGAM_PWL_DISABLE, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_CONTROL, MPCC_OGAM_MODE_CURRENT, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_CONTROL, MPCC_OGAM_SELECT_CURRENT, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_LUT_CONTROL, MPCC_OGAM_LUT_WRITE_COLOR_MASK, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_LUT_CONTROL, MPCC_OGAM_LUT_READ_COLOR_SEL, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_LUT_CONTROL, MPCC_OGAM_LUT_READ_DBG, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_LUT_CONTROL, MPCC_OGAM_LUT_HOST_SEL, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_LUT_CONTROL, MPCC_OGAM_LUT_CONFIG_MODE, mask_sh),\
+       /*SF(MPCC_OGAM0_MPCC_OGAM_LUT_CONTROL, MPCC_OGAM_LUT_STATUS, mask_sh),*/\
+       SF(MPCC_OGAM0_MPCC_OGAM_LUT_DATA, MPCC_OGAM_LUT_DATA, mask_sh),\
+       SF(MPC_RMU0_3DLUT_MODE, MPC_RMU_3DLUT_MODE, mask_sh),\
+       SF(MPC_RMU0_3DLUT_MODE, MPC_RMU_3DLUT_SIZE, mask_sh),\
+       /*SF(MPC_RMU0_3DLUT_MODE, MPC_RMU_3DLUT_MODE_CURRENT, mask_sh),*/\
+       SF(MPC_RMU0_3DLUT_READ_WRITE_CONTROL, MPC_RMU_3DLUT_WRITE_EN_MASK, mask_sh),\
+       SF(MPC_RMU0_3DLUT_READ_WRITE_CONTROL, MPC_RMU_3DLUT_RAM_SEL, mask_sh),\
+       SF(MPC_RMU0_3DLUT_READ_WRITE_CONTROL, MPC_RMU_3DLUT_30BIT_EN, mask_sh),\
+       /*SF(MPC_RMU0_3DLUT_READ_WRITE_CONTROL, MPC_RMU_3DLUT_CONFIG_STATUS, mask_sh),*/\
+       SF(MPC_RMU0_3DLUT_READ_WRITE_CONTROL, MPC_RMU_3DLUT_READ_SEL, mask_sh),\
+       SF(MPC_RMU0_3DLUT_INDEX, MPC_RMU_3DLUT_INDEX, mask_sh),\
+       SF(MPC_RMU0_3DLUT_DATA, MPC_RMU_3DLUT_DATA0, mask_sh),\
+       SF(MPC_RMU0_3DLUT_DATA, MPC_RMU_3DLUT_DATA1, mask_sh),\
+       SF(MPC_RMU0_3DLUT_DATA_30BIT, MPC_RMU_3DLUT_DATA_30BIT, mask_sh),\
+       SF(MPC_RMU0_SHAPER_CONTROL, MPC_RMU_SHAPER_LUT_MODE, mask_sh),\
+       /*SF(MPC_RMU0_SHAPER_CONTROL, MPC_RMU_SHAPER_LUT_MODE_CURRENT, mask_sh),*/\
+       SF(MPC_RMU0_SHAPER_OFFSET_R, MPC_RMU_SHAPER_OFFSET_R, mask_sh),\
+       SF(MPC_RMU0_SHAPER_OFFSET_G, MPC_RMU_SHAPER_OFFSET_G, mask_sh),\
+       SF(MPC_RMU0_SHAPER_OFFSET_B, MPC_RMU_SHAPER_OFFSET_B, mask_sh),\
+       SF(MPC_RMU0_SHAPER_SCALE_R, MPC_RMU_SHAPER_SCALE_R, mask_sh),\
+       SF(MPC_RMU0_SHAPER_SCALE_G_B, MPC_RMU_SHAPER_SCALE_G, mask_sh),\
+       SF(MPC_RMU0_SHAPER_SCALE_G_B, MPC_RMU_SHAPER_SCALE_B, mask_sh),\
+       SF(MPC_RMU0_SHAPER_LUT_INDEX, MPC_RMU_SHAPER_LUT_INDEX, mask_sh),\
+       SF(MPC_RMU0_SHAPER_LUT_DATA, MPC_RMU_SHAPER_LUT_DATA, mask_sh),\
+       SF(MPC_RMU0_SHAPER_LUT_WRITE_EN_MASK, MPC_RMU_SHAPER_LUT_WRITE_EN_MASK, mask_sh),\
+       SF(MPC_RMU0_SHAPER_LUT_WRITE_EN_MASK, MPC_RMU_SHAPER_LUT_WRITE_SEL, mask_sh),\
+       /*SF(MPC_RMU0_SHAPER_LUT_WRITE_EN_MASK, MPC_RMU_SHAPER_CONFIG_STATUS, mask_sh),*/\
+       SF(MPC_RMU0_SHAPER_RAMA_START_CNTL_B, MPC_RMU_SHAPER_RAMA_EXP_REGION_START_B, mask_sh),\
+       SF(MPC_RMU0_SHAPER_RAMA_START_CNTL_B, MPC_RMU_SHAPER_RAMA_EXP_REGION_START_SEGMENT_B, mask_sh),\
+       SF(MPC_RMU0_SHAPER_RAMA_END_CNTL_B, MPC_RMU_SHAPER_RAMA_EXP_REGION_END_B, mask_sh),\
+       SF(MPC_RMU0_SHAPER_RAMA_END_CNTL_B, MPC_RMU_SHAPER_RAMA_EXP_REGION_END_BASE_B, mask_sh),\
+       SF(MPC_RMU0_SHAPER_RAMA_REGION_0_1, MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, mask_sh),\
+       SF(MPC_RMU0_SHAPER_RAMA_REGION_0_1, MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, mask_sh),\
+       SF(MPC_RMU0_SHAPER_RAMA_REGION_0_1, MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, mask_sh),\
+       SF(MPC_RMU0_SHAPER_RAMA_REGION_0_1, MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, mask_sh),\
+       SF(MPC_RMU_MEM_PWR_CTRL, MPC_RMU0_MEM_PWR_FORCE, mask_sh),\
+       SF(MPC_RMU_MEM_PWR_CTRL, MPC_RMU0_MEM_PWR_DIS, mask_sh),\
+       SF(MPC_RMU_MEM_PWR_CTRL, MPC_RMU0_SHAPER_MEM_PWR_STATE, mask_sh),\
+       SF(MPC_RMU_MEM_PWR_CTRL, MPC_RMU0_3DLUT_MEM_PWR_STATE, mask_sh),\
+       SF(MPC_RMU_MEM_PWR_CTRL, MPC_RMU0_MEM_LOW_PWR_MODE, mask_sh),\
+       SF(MPC_RMU_MEM_PWR_CTRL, MPC_RMU1_MEM_PWR_FORCE, mask_sh),\
+       SF(MPC_RMU_MEM_PWR_CTRL, MPC_RMU1_MEM_PWR_DIS, mask_sh),\
+       SF(MPC_RMU_MEM_PWR_CTRL, MPC_RMU1_SHAPER_MEM_PWR_STATE, mask_sh),\
+       SF(MPC_RMU_MEM_PWR_CTRL, MPC_RMU1_3DLUT_MEM_PWR_STATE, mask_sh),\
+       SF(MPC_RMU_MEM_PWR_CTRL, MPC_RMU1_MEM_LOW_PWR_MODE, mask_sh),\
+       SF(MPC_RMU0_SHAPER_CONTROL, MPC_RMU_SHAPER_MODE_CURRENT, mask_sh),\
+       SF(CUR_VUPDATE_LOCK_SET0, CUR_VUPDATE_LOCK_SET, mask_sh)
+
+
+#define MPC_REG_FIELD_LIST_DCN3_0(type) \
+       MPC_REG_FIELD_LIST_DCN2_0(type) \
+       type MPC_DWB0_MUX;\
+       type MPC_DWB0_MUX_STATUS;\
+       type MPC_OUT_RATE_CONTROL;\
+       type MPC_OUT_RATE_CONTROL_DISABLE;\
+       type MPC_OUT_FLOW_CONTROL_MODE;\
+       type MPC_OUT_FLOW_CONTROL_COUNT; \
+       type MPCC_GAMUT_REMAP_MODE; \
+       type MPCC_GAMUT_REMAP_MODE_CURRENT;\
+       type MPCC_GAMUT_REMAP_COEF_FORMAT; \
+       type MPCC_GAMUT_REMAP_C11_A; \
+       type MPCC_GAMUT_REMAP_C12_A; \
+       type MPC_RMU0_MUX; \
+       type MPC_RMU1_MUX; \
+       type MPC_RMU0_MUX_STATUS; \
+       type MPC_RMU1_MUX_STATUS; \
+       type MPC_RMU0_MEM_PWR_FORCE;\
+       type MPC_RMU0_MEM_PWR_DIS;\
+       type MPC_RMU0_MEM_LOW_PWR_MODE;\
+       type MPC_RMU0_SHAPER_MEM_PWR_STATE;\
+       type MPC_RMU0_3DLUT_MEM_PWR_STATE;\
+       type MPC_RMU1_MEM_PWR_FORCE;\
+       type MPC_RMU1_MEM_PWR_DIS;\
+       type MPC_RMU1_MEM_LOW_PWR_MODE;\
+       type MPC_RMU1_SHAPER_MEM_PWR_STATE;\
+       type MPC_RMU1_3DLUT_MEM_PWR_STATE;\
+       type MPCC_OGAM_RAMA_EXP_REGION_START_SLOPE_B; \
+       type MPCC_OGAM_RAMA_EXP_REGION_START_BASE_B;\
+       type MPCC_OGAM_RAMA_OFFSET_B;\
+       type MPCC_OGAM_RAMA_OFFSET_G;\
+       type MPCC_OGAM_RAMA_OFFSET_R;\
+       type MPCC_OGAM_SELECT; \
+       type MPCC_OGAM_PWL_DISABLE; \
+       type MPCC_OGAM_MODE_CURRENT; \
+       type MPCC_OGAM_SELECT_CURRENT; \
+       type MPCC_OGAM_LUT_WRITE_COLOR_MASK; \
+       type MPCC_OGAM_LUT_READ_COLOR_SEL; \
+       type MPCC_OGAM_LUT_READ_DBG; \
+       type MPCC_OGAM_LUT_HOST_SEL; \
+       type MPCC_OGAM_LUT_CONFIG_MODE; \
+       type MPCC_OGAM_LUT_STATUS; \
+       type MPCC_OGAM_RAMA_START_BASE_CNTL_B;\
+       type MPCC_OGAM_MEM_LOW_PWR_MODE;\
+       type MPCC_OGAM_MEM_PWR_STATE;\
+       type MPC_RMU_3DLUT_MODE; \
+       type MPC_RMU_3DLUT_SIZE; \
+       type MPC_RMU_3DLUT_MODE_CURRENT; \
+       type MPC_RMU_3DLUT_WRITE_EN_MASK;\
+       type MPC_RMU_3DLUT_RAM_SEL;\
+       type MPC_RMU_3DLUT_30BIT_EN;\
+       type MPC_RMU_3DLUT_CONFIG_STATUS;\
+       type MPC_RMU_3DLUT_READ_SEL;\
+       type MPC_RMU_3DLUT_INDEX;\
+       type MPC_RMU_3DLUT_DATA0;\
+       type MPC_RMU_3DLUT_DATA1;\
+       type MPC_RMU_3DLUT_DATA_30BIT;\
+       type MPC_RMU_SHAPER_LUT_MODE;\
+       type MPC_RMU_SHAPER_LUT_MODE_CURRENT;\
+       type MPC_RMU_SHAPER_OFFSET_R;\
+       type MPC_RMU_SHAPER_OFFSET_G;\
+       type MPC_RMU_SHAPER_OFFSET_B;\
+       type MPC_RMU_SHAPER_SCALE_R;\
+       type MPC_RMU_SHAPER_SCALE_G;\
+       type MPC_RMU_SHAPER_SCALE_B;\
+       type MPC_RMU_SHAPER_LUT_INDEX;\
+       type MPC_RMU_SHAPER_LUT_DATA;\
+       type MPC_RMU_SHAPER_LUT_WRITE_EN_MASK;\
+       type MPC_RMU_SHAPER_LUT_WRITE_SEL;\
+       type MPC_RMU_SHAPER_CONFIG_STATUS;\
+       type MPC_RMU_SHAPER_RAMA_EXP_REGION_START_B;\
+       type MPC_RMU_SHAPER_RAMA_EXP_REGION_START_SEGMENT_B;\
+       type MPC_RMU_SHAPER_RAMA_EXP_REGION_END_B;\
+       type MPC_RMU_SHAPER_RAMA_EXP_REGION_END_BASE_B;\
+       type MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET;\
+       type MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS;\
+       type MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET;\
+       type MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS;\
+       type MPC_RMU_SHAPER_MODE_CURRENT
+
+#define MPC_REG_FIELD_LIST_DCN32(type) \
+       type MPCC_MOVABLE_CM_LOCATION_CNTL;\
+       type MPCC_MOVABLE_CM_LOCATION_CNTL_CURRENT;\
+       type MPCC_MCM_SHAPER_MEM_PWR_FORCE;\
+       type MPCC_MCM_SHAPER_MEM_PWR_DIS;\
+       type MPCC_MCM_SHAPER_MEM_LOW_PWR_MODE;\
+       type MPCC_MCM_3DLUT_MEM_PWR_FORCE;\
+       type MPCC_MCM_3DLUT_MEM_PWR_DIS;\
+       type MPCC_MCM_3DLUT_MEM_LOW_PWR_MODE;\
+       type MPCC_MCM_1DLUT_MEM_PWR_FORCE;\
+       type MPCC_MCM_1DLUT_MEM_PWR_DIS;\
+       type MPCC_MCM_1DLUT_MEM_LOW_PWR_MODE;\
+       type MPCC_MCM_SHAPER_MEM_PWR_STATE;\
+       type MPCC_MCM_3DLUT_MEM_PWR_STATE;\
+       type MPCC_MCM_1DLUT_MEM_PWR_STATE;\
+       type MPCC_MCM_3DLUT_MODE; \
+       type MPCC_MCM_3DLUT_SIZE; \
+       type MPCC_MCM_3DLUT_MODE_CURRENT; \
+       type MPCC_MCM_3DLUT_WRITE_EN_MASK;\
+       type MPCC_MCM_3DLUT_RAM_SEL;\
+       type MPCC_MCM_3DLUT_30BIT_EN;\
+       type MPCC_MCM_3DLUT_CONFIG_STATUS;\
+       type MPCC_MCM_3DLUT_READ_SEL;\
+       type MPCC_MCM_3DLUT_INDEX;\
+       type MPCC_MCM_3DLUT_DATA0;\
+       type MPCC_MCM_3DLUT_DATA1;\
+       type MPCC_MCM_3DLUT_DATA_30BIT;\
+       type MPCC_MCM_SHAPER_LUT_MODE;\
+       type MPCC_MCM_SHAPER_MODE_CURRENT;\
+       type MPCC_MCM_SHAPER_OFFSET_R;\
+       type MPCC_MCM_SHAPER_OFFSET_G;\
+       type MPCC_MCM_SHAPER_OFFSET_B;\
+       type MPCC_MCM_SHAPER_SCALE_R;\
+       type MPCC_MCM_SHAPER_SCALE_G;\
+       type MPCC_MCM_SHAPER_SCALE_B;\
+       type MPCC_MCM_SHAPER_LUT_INDEX;\
+       type MPCC_MCM_SHAPER_LUT_DATA;\
+       type MPCC_MCM_SHAPER_LUT_WRITE_EN_MASK;\
+       type MPCC_MCM_SHAPER_LUT_WRITE_SEL;\
+       type MPCC_MCM_SHAPER_CONFIG_STATUS;\
+       type MPCC_MCM_SHAPER_RAMA_EXP_REGION_START_B;\
+       type MPCC_MCM_SHAPER_RAMA_EXP_REGION_START_SEGMENT_B;\
+       type MPCC_MCM_SHAPER_RAMA_EXP_REGION_END_B;\
+       type MPCC_MCM_SHAPER_RAMA_EXP_REGION_END_BASE_B;\
+       type MPCC_MCM_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET;\
+       type MPCC_MCM_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS;\
+       type MPCC_MCM_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET;\
+       type MPCC_MCM_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS; \
+       type MPCC_MCM_1DLUT_MODE;\
+       type MPCC_MCM_1DLUT_SELECT;\
+       type MPCC_MCM_1DLUT_PWL_DISABLE;\
+       type MPCC_MCM_1DLUT_MODE_CURRENT;\
+       type MPCC_MCM_1DLUT_SELECT_CURRENT;\
+       type MPCC_MCM_1DLUT_LUT_INDEX;\
+       type MPCC_MCM_1DLUT_LUT_DATA;\
+       type MPCC_MCM_1DLUT_LUT_WRITE_COLOR_MASK;\
+       type MPCC_MCM_1DLUT_LUT_READ_COLOR_SEL;\
+       type MPCC_MCM_1DLUT_LUT_HOST_SEL;\
+       type MPCC_MCM_1DLUT_LUT_CONFIG_MODE;\
+       type MPCC_MCM_1DLUT_RAMA_EXP_REGION_START_B;\
+       type MPCC_MCM_1DLUT_RAMA_EXP_REGION_START_SEGMENT_B;\
+       type MPCC_MCM_1DLUT_RAMA_EXP_REGION_START_SLOPE_B;\
+       type MPCC_MCM_1DLUT_RAMA_EXP_REGION_START_BASE_B;\
+       type MPCC_MCM_1DLUT_RAMA_EXP_REGION_END_BASE_B;\
+       type MPCC_MCM_1DLUT_RAMA_EXP_REGION_END_B;\
+       type MPCC_MCM_1DLUT_RAMA_EXP_REGION_END_SLOPE_B;\
+       type MPCC_MCM_1DLUT_RAMA_OFFSET_B;\
+       type MPCC_MCM_1DLUT_RAMA_OFFSET_G;\
+       type MPCC_MCM_1DLUT_RAMA_OFFSET_R;\
+       type MPCC_MCM_1DLUT_RAMA_EXP_REGION0_LUT_OFFSET;\
+       type MPCC_MCM_1DLUT_RAMA_EXP_REGION0_NUM_SEGMENTS;\
+       type MPCC_MCM_1DLUT_RAMA_EXP_REGION1_LUT_OFFSET;\
+       type MPCC_MCM_1DLUT_RAMA_EXP_REGION1_NUM_SEGMENTS
+
+
+#define MPC_COMMON_MASK_SH_LIST_DCN303(mask_sh) \
+       MPC_COMMON_MASK_SH_LIST_DCN1_0(mask_sh),\
+       SF(MPCC0_MPCC_CONTROL, MPCC_BG_BPC, mask_sh),\
+       SF(MPCC0_MPCC_CONTROL, MPCC_BOT_GAIN_MODE, mask_sh),\
+       SF(MPCC0_MPCC_TOP_GAIN, MPCC_TOP_GAIN, mask_sh),\
+       SF(MPCC0_MPCC_BOT_GAIN_INSIDE, MPCC_BOT_GAIN_INSIDE, mask_sh),\
+       SF(MPCC0_MPCC_BOT_GAIN_OUTSIDE, MPCC_BOT_GAIN_OUTSIDE, mask_sh),\
+       SF(MPC_OUT0_CSC_MODE, MPC_OCSC_MODE, mask_sh),\
+       SF(MPC_OUT0_CSC_C11_C12_A, MPC_OCSC_C11_A, mask_sh),\
+       SF(MPC_OUT0_CSC_C11_C12_A, MPC_OCSC_C12_A, mask_sh),\
+       SF(MPCC0_MPCC_STATUS, MPCC_DISABLED, mask_sh),\
+       SF(MPCC0_MPCC_MEM_PWR_CTRL, MPCC_OGAM_MEM_PWR_FORCE, mask_sh),\
+       SF(MPCC0_MPCC_MEM_PWR_CTRL, MPCC_OGAM_MEM_PWR_DIS, mask_sh),\
+       SF(MPCC0_MPCC_MEM_PWR_CTRL, MPCC_OGAM_MEM_LOW_PWR_MODE, mask_sh),\
+       SF(MPCC0_MPCC_MEM_PWR_CTRL, MPCC_OGAM_MEM_PWR_STATE, mask_sh),\
+       SF(MPC_OUT0_DENORM_CONTROL, MPC_OUT_DENORM_MODE, mask_sh),\
+       SF(MPC_OUT0_DENORM_CONTROL, MPC_OUT_DENORM_CLAMP_MAX_R_CR, mask_sh),\
+       SF(MPC_OUT0_DENORM_CONTROL, MPC_OUT_DENORM_CLAMP_MIN_R_CR, mask_sh),\
+       SF(MPC_OUT0_DENORM_CLAMP_G_Y, MPC_OUT_DENORM_CLAMP_MAX_G_Y, mask_sh),\
+       SF(MPC_OUT0_DENORM_CLAMP_G_Y, MPC_OUT_DENORM_CLAMP_MIN_G_Y, mask_sh),\
+       SF(MPC_OUT0_DENORM_CLAMP_B_CB, MPC_OUT_DENORM_CLAMP_MAX_B_CB, mask_sh),\
+       SF(MPC_OUT0_DENORM_CLAMP_B_CB, MPC_OUT_DENORM_CLAMP_MIN_B_CB, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_GAMUT_REMAP_MODE, MPCC_GAMUT_REMAP_MODE, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_GAMUT_REMAP_MODE, MPCC_GAMUT_REMAP_MODE_CURRENT, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_GAMUT_REMAP_COEF_FORMAT, MPCC_GAMUT_REMAP_COEF_FORMAT, mask_sh),\
+       SF(MPCC_OGAM0_MPC_GAMUT_REMAP_C11_C12_A, MPCC_GAMUT_REMAP_C11_A, mask_sh),\
+       SF(MPCC_OGAM0_MPC_GAMUT_REMAP_C11_C12_A, MPCC_GAMUT_REMAP_C12_A, mask_sh),\
+       SF(MPC_DWB0_MUX, MPC_DWB0_MUX, mask_sh),\
+       SF(MPC_DWB0_MUX, MPC_DWB0_MUX_STATUS, mask_sh),\
+       SF(MPC_OUT0_MUX, MPC_OUT_RATE_CONTROL, mask_sh),\
+       SF(MPC_OUT0_MUX, MPC_OUT_RATE_CONTROL_DISABLE, mask_sh),\
+       SF(MPC_OUT0_MUX, MPC_OUT_FLOW_CONTROL_MODE, mask_sh),\
+       SF(MPC_OUT0_MUX, MPC_OUT_FLOW_CONTROL_COUNT, mask_sh), \
+       SF(MPC_RMU_CONTROL, MPC_RMU0_MUX, mask_sh), \
+       SF(MPC_RMU_CONTROL, MPC_RMU0_MUX_STATUS, mask_sh), \
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_REGION_0_1, MPCC_OGAM_RAMA_EXP_REGION0_LUT_OFFSET, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_REGION_0_1, MPCC_OGAM_RAMA_EXP_REGION0_NUM_SEGMENTS, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_REGION_0_1, MPCC_OGAM_RAMA_EXP_REGION1_LUT_OFFSET, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_REGION_0_1, MPCC_OGAM_RAMA_EXP_REGION1_NUM_SEGMENTS, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_END_CNTL2_B, MPCC_OGAM_RAMA_EXP_REGION_END_SLOPE_B, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_END_CNTL2_B, MPCC_OGAM_RAMA_EXP_REGION_END_B, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_END_CNTL1_B, MPCC_OGAM_RAMA_EXP_REGION_END_BASE_B, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_START_SLOPE_CNTL_B, MPCC_OGAM_RAMA_EXP_REGION_START_SLOPE_B, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_START_BASE_CNTL_B, MPCC_OGAM_RAMA_EXP_REGION_START_BASE_B, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_START_CNTL_B, MPCC_OGAM_RAMA_EXP_REGION_START_B, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_START_CNTL_B, MPCC_OGAM_RAMA_EXP_REGION_START_SEGMENT_B, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_OFFSET_B, MPCC_OGAM_RAMA_OFFSET_B, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_OFFSET_G, MPCC_OGAM_RAMA_OFFSET_G, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_RAMA_OFFSET_R, MPCC_OGAM_RAMA_OFFSET_R, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_LUT_INDEX, MPCC_OGAM_LUT_INDEX, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_CONTROL, MPCC_OGAM_MODE, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_CONTROL, MPCC_OGAM_SELECT, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_CONTROL, MPCC_OGAM_PWL_DISABLE, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_CONTROL, MPCC_OGAM_MODE_CURRENT, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_CONTROL, MPCC_OGAM_SELECT_CURRENT, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_LUT_CONTROL, MPCC_OGAM_LUT_WRITE_COLOR_MASK, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_LUT_CONTROL, MPCC_OGAM_LUT_READ_COLOR_SEL, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_LUT_CONTROL, MPCC_OGAM_LUT_READ_DBG, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_LUT_CONTROL, MPCC_OGAM_LUT_HOST_SEL, mask_sh),\
+       SF(MPCC_OGAM0_MPCC_OGAM_LUT_CONTROL, MPCC_OGAM_LUT_CONFIG_MODE, mask_sh),\
+       /*SF(MPCC_OGAM0_MPCC_OGAM_LUT_CONTROL, MPCC_OGAM_LUT_STATUS, mask_sh),*/\
+       SF(MPCC_OGAM0_MPCC_OGAM_LUT_DATA, MPCC_OGAM_LUT_DATA, mask_sh),\
+       SF(MPC_RMU0_3DLUT_MODE, MPC_RMU_3DLUT_MODE, mask_sh),\
+       SF(MPC_RMU0_3DLUT_MODE, MPC_RMU_3DLUT_SIZE, mask_sh),\
+       /*SF(MPC_RMU0_3DLUT_MODE, MPC_RMU_3DLUT_MODE_CURRENT, mask_sh),*/\
+       SF(MPC_RMU0_3DLUT_READ_WRITE_CONTROL, MPC_RMU_3DLUT_WRITE_EN_MASK, mask_sh),\
+       SF(MPC_RMU0_3DLUT_READ_WRITE_CONTROL, MPC_RMU_3DLUT_RAM_SEL, mask_sh),\
+       SF(MPC_RMU0_3DLUT_READ_WRITE_CONTROL, MPC_RMU_3DLUT_30BIT_EN, mask_sh),\
+       /*SF(MPC_RMU0_3DLUT_READ_WRITE_CONTROL, MPC_RMU_3DLUT_CONFIG_STATUS, mask_sh),*/\
+       SF(MPC_RMU0_3DLUT_READ_WRITE_CONTROL, MPC_RMU_3DLUT_READ_SEL, mask_sh),\
+       SF(MPC_RMU0_3DLUT_INDEX, MPC_RMU_3DLUT_INDEX, mask_sh),\
+       SF(MPC_RMU0_3DLUT_DATA, MPC_RMU_3DLUT_DATA0, mask_sh),\
+       SF(MPC_RMU0_3DLUT_DATA, MPC_RMU_3DLUT_DATA1, mask_sh),\
+       SF(MPC_RMU0_3DLUT_DATA_30BIT, MPC_RMU_3DLUT_DATA_30BIT, mask_sh),\
+       SF(MPC_RMU0_SHAPER_CONTROL, MPC_RMU_SHAPER_LUT_MODE, mask_sh),\
+       /*SF(MPC_RMU0_SHAPER_CONTROL, MPC_RMU_SHAPER_LUT_MODE_CURRENT, mask_sh),*/\
+       SF(MPC_RMU0_SHAPER_OFFSET_R, MPC_RMU_SHAPER_OFFSET_R, mask_sh),\
+       SF(MPC_RMU0_SHAPER_OFFSET_G, MPC_RMU_SHAPER_OFFSET_G, mask_sh),\
+       SF(MPC_RMU0_SHAPER_OFFSET_B, MPC_RMU_SHAPER_OFFSET_B, mask_sh),\
+       SF(MPC_RMU0_SHAPER_SCALE_R, MPC_RMU_SHAPER_SCALE_R, mask_sh),\
+       SF(MPC_RMU0_SHAPER_SCALE_G_B, MPC_RMU_SHAPER_SCALE_G, mask_sh),\
+       SF(MPC_RMU0_SHAPER_SCALE_G_B, MPC_RMU_SHAPER_SCALE_B, mask_sh),\
+       SF(MPC_RMU0_SHAPER_LUT_INDEX, MPC_RMU_SHAPER_LUT_INDEX, mask_sh),\
+       SF(MPC_RMU0_SHAPER_LUT_DATA, MPC_RMU_SHAPER_LUT_DATA, mask_sh),\
+       SF(MPC_RMU0_SHAPER_LUT_WRITE_EN_MASK, MPC_RMU_SHAPER_LUT_WRITE_EN_MASK, mask_sh),\
+       SF(MPC_RMU0_SHAPER_LUT_WRITE_EN_MASK, MPC_RMU_SHAPER_LUT_WRITE_SEL, mask_sh),\
+       /*SF(MPC_RMU0_SHAPER_LUT_WRITE_EN_MASK, MPC_RMU_SHAPER_CONFIG_STATUS, mask_sh),*/\
+       SF(MPC_RMU0_SHAPER_RAMA_START_CNTL_B, MPC_RMU_SHAPER_RAMA_EXP_REGION_START_B, mask_sh),\
+       SF(MPC_RMU0_SHAPER_RAMA_START_CNTL_B, MPC_RMU_SHAPER_RAMA_EXP_REGION_START_SEGMENT_B, mask_sh),\
+       SF(MPC_RMU0_SHAPER_RAMA_END_CNTL_B, MPC_RMU_SHAPER_RAMA_EXP_REGION_END_B, mask_sh),\
+       SF(MPC_RMU0_SHAPER_RAMA_END_CNTL_B, MPC_RMU_SHAPER_RAMA_EXP_REGION_END_BASE_B, mask_sh),\
+       SF(MPC_RMU0_SHAPER_RAMA_REGION_0_1, MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET, mask_sh),\
+       SF(MPC_RMU0_SHAPER_RAMA_REGION_0_1, MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS, mask_sh),\
+       SF(MPC_RMU0_SHAPER_RAMA_REGION_0_1, MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET, mask_sh),\
+       SF(MPC_RMU0_SHAPER_RAMA_REGION_0_1, MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS, mask_sh),\
+       SF(MPC_RMU_MEM_PWR_CTRL, MPC_RMU0_MEM_PWR_FORCE, mask_sh),\
+       SF(MPC_RMU_MEM_PWR_CTRL, MPC_RMU0_MEM_PWR_DIS, mask_sh),\
+       SF(MPC_RMU_MEM_PWR_CTRL, MPC_RMU0_SHAPER_MEM_PWR_STATE, mask_sh),\
+       SF(MPC_RMU_MEM_PWR_CTRL, MPC_RMU0_3DLUT_MEM_PWR_STATE, mask_sh),\
+       SF(MPC_RMU_MEM_PWR_CTRL, MPC_RMU0_MEM_LOW_PWR_MODE, mask_sh),\
+       SF(MPC_RMU0_SHAPER_CONTROL, MPC_RMU_SHAPER_MODE_CURRENT, mask_sh),\
+       SF(CUR_VUPDATE_LOCK_SET0, CUR_VUPDATE_LOCK_SET, mask_sh)
+
+#define MPC_REG_FIELD_LIST_DCN3_03(type) \
+       MPC_REG_FIELD_LIST_DCN2_0(type) \
+       type MPC_DWB0_MUX;\
+       type MPC_DWB0_MUX_STATUS;\
+       type MPC_OUT_RATE_CONTROL;\
+       type MPC_OUT_RATE_CONTROL_DISABLE;\
+       type MPC_OUT_FLOW_CONTROL_MODE;\
+       type MPC_OUT_FLOW_CONTROL_COUNT; \
+       type MPCC_GAMUT_REMAP_MODE; \
+       type MPCC_GAMUT_REMAP_MODE_CURRENT;\
+       type MPCC_GAMUT_REMAP_COEF_FORMAT; \
+       type MPCC_GAMUT_REMAP_C11_A; \
+       type MPCC_GAMUT_REMAP_C12_A; \
+       type MPC_RMU0_MUX; \
+       type MPC_RMU0_MUX_STATUS; \
+       type MPC_RMU0_MEM_PWR_FORCE;\
+       type MPC_RMU0_MEM_PWR_DIS;\
+       type MPC_RMU0_MEM_LOW_PWR_MODE;\
+       type MPC_RMU0_SHAPER_MEM_PWR_STATE;\
+       type MPC_RMU0_3DLUT_MEM_PWR_STATE;\
+       type MPCC_OGAM_RAMA_EXP_REGION_START_SLOPE_B; \
+       type MPCC_OGAM_RAMA_EXP_REGION_START_BASE_B;\
+       type MPCC_OGAM_RAMA_OFFSET_B;\
+       type MPCC_OGAM_RAMA_OFFSET_G;\
+       type MPCC_OGAM_RAMA_OFFSET_R;\
+       type MPCC_OGAM_SELECT; \
+       type MPCC_OGAM_PWL_DISABLE; \
+       type MPCC_OGAM_MODE_CURRENT; \
+       type MPCC_OGAM_SELECT_CURRENT; \
+       type MPCC_OGAM_LUT_WRITE_COLOR_MASK; \
+       type MPCC_OGAM_LUT_READ_COLOR_SEL; \
+       type MPCC_OGAM_LUT_READ_DBG; \
+       type MPCC_OGAM_LUT_HOST_SEL; \
+       type MPCC_OGAM_LUT_CONFIG_MODE; \
+       type MPCC_OGAM_LUT_STATUS; \
+       type MPCC_OGAM_RAMA_START_BASE_CNTL_B;\
+       type MPCC_OGAM_MEM_LOW_PWR_MODE;\
+       type MPCC_OGAM_MEM_PWR_STATE;\
+       type MPC_RMU_3DLUT_MODE; \
+       type MPC_RMU_3DLUT_SIZE; \
+       type MPC_RMU_3DLUT_MODE_CURRENT; \
+       type MPC_RMU_3DLUT_WRITE_EN_MASK;\
+       type MPC_RMU_3DLUT_RAM_SEL;\
+       type MPC_RMU_3DLUT_30BIT_EN;\
+       type MPC_RMU_3DLUT_CONFIG_STATUS;\
+       type MPC_RMU_3DLUT_READ_SEL;\
+       type MPC_RMU_3DLUT_INDEX;\
+       type MPC_RMU_3DLUT_DATA0;\
+       type MPC_RMU_3DLUT_DATA1;\
+       type MPC_RMU_3DLUT_DATA_30BIT;\
+       type MPC_RMU_SHAPER_LUT_MODE;\
+       type MPC_RMU_SHAPER_LUT_MODE_CURRENT;\
+       type MPC_RMU_SHAPER_OFFSET_R;\
+       type MPC_RMU_SHAPER_OFFSET_G;\
+       type MPC_RMU_SHAPER_OFFSET_B;\
+       type MPC_RMU_SHAPER_SCALE_R;\
+       type MPC_RMU_SHAPER_SCALE_G;\
+       type MPC_RMU_SHAPER_SCALE_B;\
+       type MPC_RMU_SHAPER_LUT_INDEX;\
+       type MPC_RMU_SHAPER_LUT_DATA;\
+       type MPC_RMU_SHAPER_LUT_WRITE_EN_MASK;\
+       type MPC_RMU_SHAPER_LUT_WRITE_SEL;\
+       type MPC_RMU_SHAPER_CONFIG_STATUS;\
+       type MPC_RMU_SHAPER_RAMA_EXP_REGION_START_B;\
+       type MPC_RMU_SHAPER_RAMA_EXP_REGION_START_SEGMENT_B;\
+       type MPC_RMU_SHAPER_RAMA_EXP_REGION_END_B;\
+       type MPC_RMU_SHAPER_RAMA_EXP_REGION_END_BASE_B;\
+       type MPC_RMU_SHAPER_RAMA_EXP_REGION0_LUT_OFFSET;\
+       type MPC_RMU_SHAPER_RAMA_EXP_REGION0_NUM_SEGMENTS;\
+       type MPC_RMU_SHAPER_RAMA_EXP_REGION1_LUT_OFFSET;\
+       type MPC_RMU_SHAPER_RAMA_EXP_REGION1_NUM_SEGMENTS;\
+       type MPC_RMU_SHAPER_MODE_CURRENT
+
+struct dcn30_mpc_registers {
+       MPC_REG_VARIABLE_LIST_DCN3_0;
+       MPC_REG_VARIABLE_LIST_DCN32;
+};
+
+struct dcn30_mpc_shift {
+       MPC_REG_FIELD_LIST_DCN3_0(uint8_t);
+       MPC_REG_FIELD_LIST_DCN32(uint8_t);
+};
+
+struct dcn30_mpc_mask {
+       MPC_REG_FIELD_LIST_DCN3_0(uint32_t);
+       MPC_REG_FIELD_LIST_DCN32(uint32_t);
+};
+
+struct dcn30_mpc {
+       struct mpc base;
+
+       int mpcc_in_use_mask;
+       int num_mpcc;
+       const struct dcn30_mpc_registers *mpc_regs;
+       const struct dcn30_mpc_shift *mpc_shift;
+       const struct dcn30_mpc_mask *mpc_mask;
+       int num_rmu;
+};
+
+void dcn30_mpc_construct(struct dcn30_mpc *mpc30,
+       struct dc_context *ctx,
+       const struct dcn30_mpc_registers *mpc_regs,
+       const struct dcn30_mpc_shift *mpc_shift,
+       const struct dcn30_mpc_mask *mpc_mask,
+       int num_mpcc,
+       int num_rmu);
+
+void mpc3_mpc_init(
+       struct mpc *mpc);
+
+void mpc3_mpc_init_single_inst(
+       struct mpc *mpc,
+       unsigned int mpcc_id);
+
+bool mpc3_program_shaper(
+               struct mpc *mpc,
+               const struct pwl_params *params,
+               uint32_t rmu_idx);
+
+bool mpc3_program_3dlut(
+               struct mpc *mpc,
+               const struct tetrahedral_params *params,
+               int rmu_idx);
+
+uint32_t mpcc3_acquire_rmu(struct mpc *mpc,
+               int mpcc_id, int rmu_idx);
+
+void mpc3_set_denorm(
+       struct mpc *mpc,
+       int opp_id,
+       enum dc_color_depth output_depth);
+
+void mpc3_set_denorm_clamp(
+       struct mpc *mpc,
+       int opp_id,
+       struct mpc_denorm_clamp denorm_clamp);
+
+void mpc3_set_output_csc(
+       struct mpc *mpc,
+       int opp_id,
+       const uint16_t *regval,
+       enum mpc_output_csc_mode ocsc_mode);
+
+void mpc3_set_ocsc_default(
+       struct mpc *mpc,
+       int opp_id,
+       enum dc_color_space color_space,
+       enum mpc_output_csc_mode ocsc_mode);
+
+void mpc3_set_output_gamma(
+       struct mpc *mpc,
+       int mpcc_id,
+       const struct pwl_params *params);
+
+uint32_t mpc3_get_rmu_mux_status(
+       struct mpc *mpc,
+       int rmu_idx);
+
+void mpc3_set_gamut_remap(
+       struct mpc *mpc,
+       int mpcc_id,
+       const struct mpc_grph_gamut_adjustment *adjust);
+
+void mpc3_get_gamut_remap(struct mpc *mpc,
+                         int mpcc_id,
+                         struct mpc_grph_gamut_adjustment *adjust);
+
+void mpc3_set_rmu_mux(
+       struct mpc *mpc,
+       int rmu_idx,
+       int value);
+
+void mpc3_set_dwb_mux(
+       struct mpc *mpc,
+       int dwb_id,
+       int mpcc_id);
+
+void mpc3_disable_dwb_mux(
+       struct mpc *mpc,
+       int dwb_id);
+
+bool mpc3_is_dwb_idle(
+       struct mpc *mpc,
+       int dwb_id);
+
+void mpc3_power_on_ogam_lut(
+       struct mpc *mpc, int mpcc_id,
+       bool power_on);
+
+void mpc3_init_mpcc(struct mpcc *mpcc, int mpcc_inst);
+
+enum dc_lut_mode mpc3_get_ogam_current(
+       struct mpc *mpc,
+       int mpcc_id);
+
+#endif