.has_idle_pc = true,
 };
 
-static struct dpu_mdp_cfg sdm845_mdp[] = {
+static const struct dpu_mdp_cfg sdm845_mdp[] = {
        {
        .name = "top_0", .id = MDP_TOP,
        .base = 0x0, .len = 0x45C,
 /*************************************************************
  * CTL sub blocks config
  *************************************************************/
-static struct dpu_ctl_cfg sdm845_ctl[] = {
+static const struct dpu_ctl_cfg sdm845_ctl[] = {
        {
        .name = "ctl_0", .id = CTL_0,
        .base = 0x1000, .len = 0xE4,
        .clk_ctrl = _clkctrl \
        }
 
-static struct dpu_sspp_cfg sdm845_sspp[] = {
+static const struct dpu_sspp_cfg sdm845_sspp[] = {
        SSPP_BLK("sspp_0", SSPP_VIG0, 0x4000, VIG_SDM845_MASK,
                sdm845_vig_sblk_0, 0,  SSPP_TYPE_VIG, DPU_CLK_CTRL_VIG0),
        SSPP_BLK("sspp_1", SSPP_VIG1, 0x6000, VIG_SDM845_MASK,
        .lm_pair_mask = (1 << _lmpair) \
        }
 
-static struct dpu_lm_cfg sdm845_lm[] = {
+static const struct dpu_lm_cfg sdm845_lm[] = {
        LM_BLK("lm_0", LM_0, 0x44000, PINGPONG_0, LM_1),
        LM_BLK("lm_1", LM_1, 0x45000, PINGPONG_1, LM_0),
        LM_BLK("lm_2", LM_2, 0x46000, PINGPONG_2, LM_5),
        .sblk = &sdm845_pp_sblk \
        }
 
-static struct dpu_pingpong_cfg sdm845_pp[] = {
+static const struct dpu_pingpong_cfg sdm845_pp[] = {
        PP_BLK_TE("pingpong_0", PINGPONG_0, 0x70000),
        PP_BLK_TE("pingpong_1", PINGPONG_1, 0x70800),
        PP_BLK("pingpong_2", PINGPONG_2, 0x71000),
        .prog_fetch_lines_worst_case = 24 \
        }
 
-static struct dpu_intf_cfg sdm845_intf[] = {
+static const struct dpu_intf_cfg sdm845_intf[] = {
        INTF_BLK("intf_0", INTF_0, 0x6A000, INTF_DP, 0),
        INTF_BLK("intf_1", INTF_1, 0x6A800, INTF_DSI, 0),
        INTF_BLK("intf_2", INTF_2, 0x6B000, INTF_DSI, 1),
  * VBIF sub blocks config
  *************************************************************/
 /* VBIF QOS remap */
-static u32 sdm845_rt_pri_lvl[] = {3, 3, 4, 4, 5, 5, 6, 6};
-static u32 sdm845_nrt_pri_lvl[] = {3, 3, 3, 3, 3, 3, 3, 3};
+static const u32 sdm845_rt_pri_lvl[] = {3, 3, 4, 4, 5, 5, 6, 6};
+static const u32 sdm845_nrt_pri_lvl[] = {3, 3, 3, 3, 3, 3, 3, 3};
 
-static struct dpu_vbif_cfg sdm845_vbif[] = {
+static const struct dpu_vbif_cfg sdm845_vbif[] = {
        {
        .name = "vbif_0", .id = VBIF_0,
        .base = 0, .len = 0x1040,
        },
 };
 
-static struct dpu_reg_dma_cfg sdm845_regdma = {
+static const struct dpu_reg_dma_cfg sdm845_regdma = {
        .base = 0x0, .version = 0x1, .trigger_sel_off = 0x119c
 };
 
  *************************************************************/
 
 /* SSPP QOS LUTs */
-static struct dpu_qos_lut_entry sdm845_qos_linear[] = {
+static const struct dpu_qos_lut_entry sdm845_qos_linear[] = {
        {.fl = 4, .lut = 0x357},
        {.fl = 5, .lut = 0x3357},
        {.fl = 6, .lut = 0x23357},
        {.fl = 0, .lut = 0x11222222223357}
 };
 
-static struct dpu_qos_lut_entry sdm845_qos_macrotile[] = {
+static const struct dpu_qos_lut_entry sdm845_qos_macrotile[] = {
        {.fl = 10, .lut = 0x344556677},
        {.fl = 11, .lut = 0x3344556677},
        {.fl = 12, .lut = 0x23344556677},
        {.fl = 0, .lut = 0x112233344556677},
 };
 
-static struct dpu_qos_lut_entry sdm845_qos_nrt[] = {
+static const struct dpu_qos_lut_entry sdm845_qos_nrt[] = {
        {.fl = 0, .lut = 0x0},
 };
 
-static struct dpu_perf_cfg sdm845_perf_data = {
+static const struct dpu_perf_cfg sdm845_perf_data = {
        .max_bw_low = 6800000,
        .max_bw_high = 6800000,
        .min_core_ib = 2400000,
        };
 }
 
-static struct dpu_mdss_hw_cfg_handler cfg_handler[] = {
+static const struct dpu_mdss_hw_cfg_handler cfg_handler[] = {
        { .hw_rev = DPU_HW_VER_400, .cfg_init = sdm845_cfg_init},
        { .hw_rev = DPU_HW_VER_401, .cfg_init = sdm845_cfg_init},
 };
 
  */
 struct dpu_qos_lut_tbl {
        u32 nentry;
-       struct dpu_qos_lut_entry *entries;
+       const struct dpu_qos_lut_entry *entries;
 };
 
 /**
  */
 struct dpu_vbif_dynamic_ot_tbl {
        u32 count;
-       struct dpu_vbif_dynamic_ot_cfg *cfg;
+       const struct dpu_vbif_dynamic_ot_cfg *cfg;
 };
 
 /**
  */
 struct dpu_vbif_qos_tbl {
        u32 npriority_lvl;
-       u32 *priority_lvl;
+       const u32 *priority_lvl;
 };
 
 /**
        const struct dpu_caps *caps;
 
        u32 mdp_count;
-       struct dpu_mdp_cfg *mdp;
+       const struct dpu_mdp_cfg *mdp;
 
        u32 ctl_count;
-       struct dpu_ctl_cfg *ctl;
+       const struct dpu_ctl_cfg *ctl;
 
        u32 sspp_count;
-       struct dpu_sspp_cfg *sspp;
+       const struct dpu_sspp_cfg *sspp;
 
        u32 mixer_count;
-       struct dpu_lm_cfg *mixer;
+       const struct dpu_lm_cfg *mixer;
 
        u32 pingpong_count;
-       struct dpu_pingpong_cfg *pingpong;
+       const struct dpu_pingpong_cfg *pingpong;
 
        u32 intf_count;
-       struct dpu_intf_cfg *intf;
+       const struct dpu_intf_cfg *intf;
 
        u32 vbif_count;
-       struct dpu_vbif_cfg *vbif;
+       const struct dpu_vbif_cfg *vbif;
 
        u32 reg_dma_count;
        struct dpu_reg_dma_cfg dma_cfg;
        /* Add additional block data structures here */
 
        struct dpu_perf_cfg perf;
-       struct dpu_format_extended *dma_formats;
-       struct dpu_format_extended *cursor_formats;
-       struct dpu_format_extended *vig_formats;
+       const struct dpu_format_extended *dma_formats;
+       const struct dpu_format_extended *cursor_formats;
+       const struct dpu_format_extended *vig_formats;
 };
 
 struct dpu_mdss_hw_cfg_handler {
 
 
 #define DPU_REG_RESET_TIMEOUT_US        2000
 
-static struct dpu_ctl_cfg *_ctl_offset(enum dpu_ctl ctl,
-               struct dpu_mdss_cfg *m,
+static const struct dpu_ctl_cfg *_ctl_offset(enum dpu_ctl ctl,
+               const struct dpu_mdss_cfg *m,
                void __iomem *addr,
                struct dpu_hw_blk_reg_map *b)
 {
 
 struct dpu_hw_ctl *dpu_hw_ctl_init(enum dpu_ctl idx,
                void __iomem *addr,
-               struct dpu_mdss_cfg *m)
+               const struct dpu_mdss_cfg *m)
 {
        struct dpu_hw_ctl *c;
-       struct dpu_ctl_cfg *cfg;
+       const struct dpu_ctl_cfg *cfg;
 
        c = kzalloc(sizeof(*c), GFP_KERNEL);
        if (!c)
 
  */
 struct dpu_hw_ctl *dpu_hw_ctl_init(enum dpu_ctl idx,
                void __iomem *addr,
-               struct dpu_mdss_cfg *m);
+               const struct dpu_mdss_cfg *m);
 
 /**
  * dpu_hw_ctl_destroy(): Destroys ctl driver context
 
 #define   INTF_FRAME_COUNT              0x0AC
 #define   INTF_LINE_COUNT               0x0B0
 
-static struct dpu_intf_cfg *_intf_offset(enum dpu_intf intf,
-               struct dpu_mdss_cfg *m,
+static const struct dpu_intf_cfg *_intf_offset(enum dpu_intf intf,
+               const struct dpu_mdss_cfg *m,
                void __iomem *addr,
                struct dpu_hw_blk_reg_map *b)
 {
 
 struct dpu_hw_intf *dpu_hw_intf_init(enum dpu_intf idx,
                void __iomem *addr,
-               struct dpu_mdss_cfg *m)
+               const struct dpu_mdss_cfg *m)
 {
        struct dpu_hw_intf *c;
-       struct dpu_intf_cfg *cfg;
+       const struct dpu_intf_cfg *cfg;
 
        c = kzalloc(sizeof(*c), GFP_KERNEL);
        if (!c)
 
  */
 struct dpu_hw_intf *dpu_hw_intf_init(enum dpu_intf idx,
                void __iomem *addr,
-               struct dpu_mdss_cfg *m);
+               const struct dpu_mdss_cfg *m);
 
 /**
  * dpu_hw_intf_destroy(): Destroys INTF driver context
 
 #define LM_BLEND0_FG_ALPHA               0x04
 #define LM_BLEND0_BG_ALPHA               0x08
 
-static struct dpu_lm_cfg *_lm_offset(enum dpu_lm mixer,
-               struct dpu_mdss_cfg *m,
+static const struct dpu_lm_cfg *_lm_offset(enum dpu_lm mixer,
+               const struct dpu_mdss_cfg *m,
                void __iomem *addr,
                struct dpu_hw_blk_reg_map *b)
 {
        DPU_REG_WRITE(c, LM_OP_MODE, op_mode);
 }
 
-static void _setup_mixer_ops(struct dpu_mdss_cfg *m,
+static void _setup_mixer_ops(const struct dpu_mdss_cfg *m,
                struct dpu_hw_lm_ops *ops,
                unsigned long features)
 {
 
 struct dpu_hw_mixer *dpu_hw_lm_init(enum dpu_lm idx,
                void __iomem *addr,
-               struct dpu_mdss_cfg *m)
+               const struct dpu_mdss_cfg *m)
 {
        struct dpu_hw_mixer *c;
-       struct dpu_lm_cfg *cfg;
+       const struct dpu_lm_cfg *cfg;
 
        c = kzalloc(sizeof(*c), GFP_KERNEL);
        if (!c)
 
  */
 struct dpu_hw_mixer *dpu_hw_lm_init(enum dpu_lm idx,
                void __iomem *addr,
-               struct dpu_mdss_cfg *m);
+               const struct dpu_mdss_cfg *m);
 
 /**
  * dpu_hw_lm_destroy(): Destroys layer mixer driver context
 
 #define PP_FBC_BUDGET_CTL               0x038
 #define PP_FBC_LOSSY_MODE               0x03C
 
-static struct dpu_pingpong_cfg *_pingpong_offset(enum dpu_pingpong pp,
-               struct dpu_mdss_cfg *m,
+static const struct dpu_pingpong_cfg *_pingpong_offset(enum dpu_pingpong pp,
+               const struct dpu_mdss_cfg *m,
                void __iomem *addr,
                struct dpu_hw_blk_reg_map *b)
 {
 
 struct dpu_hw_pingpong *dpu_hw_pingpong_init(enum dpu_pingpong idx,
                void __iomem *addr,
-               struct dpu_mdss_cfg *m)
+               const struct dpu_mdss_cfg *m)
 {
        struct dpu_hw_pingpong *c;
-       struct dpu_pingpong_cfg *cfg;
+       const struct dpu_pingpong_cfg *cfg;
 
        c = kzalloc(sizeof(*c), GFP_KERNEL);
        if (!c)
 
  */
 struct dpu_hw_pingpong *dpu_hw_pingpong_init(enum dpu_pingpong idx,
                void __iomem *addr,
-               struct dpu_mdss_cfg *m);
+               const struct dpu_mdss_cfg *m);
 
 /**
  * dpu_hw_pingpong_destroy - destroys pingpong driver context
 
                c->ops.setup_cdp = dpu_hw_sspp_setup_cdp;
 }
 
-static struct dpu_sspp_cfg *_sspp_offset(enum dpu_sspp sspp,
+static const struct dpu_sspp_cfg *_sspp_offset(enum dpu_sspp sspp,
                void __iomem *addr,
                struct dpu_mdss_cfg *catalog,
                struct dpu_hw_blk_reg_map *b)
                bool is_virtual_pipe)
 {
        struct dpu_hw_pipe *hw_pipe;
-       struct dpu_sspp_cfg *cfg;
+       const struct dpu_sspp_cfg *cfg;
 
        if (!addr || !catalog)
                return ERR_PTR(-EINVAL);
 
        struct dpu_hw_blk base;
        struct dpu_hw_blk_reg_map hw;
        struct dpu_mdss_cfg *catalog;
-       struct dpu_mdp_cfg *mdp;
+       const struct dpu_mdp_cfg *mdp;
 
        /* Pipe */
        enum dpu_sspp idx;
 
 
 static int _dpu_rm_hw_blk_create(
                struct dpu_rm *rm,
-               struct dpu_mdss_cfg *cat,
+               const struct dpu_mdss_cfg *cat,
                void __iomem *mmio,
                enum dpu_hw_blk_type type,
                uint32_t id,
-               void *hw_catalog_info)
+               const void *hw_catalog_info)
 {
        struct dpu_rm_hw_blk *blk;
        void *hw;
 
        /* Interrogate HW catalog and create tracking items for hw blocks */
        for (i = 0; i < cat->mixer_count; i++) {
-               struct dpu_lm_cfg *lm = &cat->mixer[i];
+               const struct dpu_lm_cfg *lm = &cat->mixer[i];
 
                if (lm->pingpong == PINGPONG_MAX) {
                        DPU_DEBUG("skip mixer %d without pingpong\n", lm->id);
 
        entry = debugfs_create_dir("vbif", debugfs_root);
 
        for (i = 0; i < dpu_kms->catalog->vbif_count; i++) {
-               struct dpu_vbif_cfg *vbif = &dpu_kms->catalog->vbif[i];
+               const struct dpu_vbif_cfg *vbif = &dpu_kms->catalog->vbif[i];
 
                snprintf(vbif_name, sizeof(vbif_name), "%d", vbif->id);
 
                        (u32 *)&vbif->default_ot_wr_limit);
 
                for (j = 0; j < vbif->dynamic_ot_rd_tbl.count; j++) {
-                       struct dpu_vbif_dynamic_ot_cfg *cfg =
+                       const struct dpu_vbif_dynamic_ot_cfg *cfg =
                                        &vbif->dynamic_ot_rd_tbl.cfg[j];
 
                        snprintf(vbif_name, sizeof(vbif_name),
                }
 
                for (j = 0; j < vbif->dynamic_ot_wr_tbl.count; j++) {
-                       struct dpu_vbif_dynamic_ot_cfg *cfg =
+                       const struct dpu_vbif_dynamic_ot_cfg *cfg =
                                        &vbif->dynamic_ot_wr_tbl.cfg[j];
 
                        snprintf(vbif_name, sizeof(vbif_name),