struct amdgpu_crtc *acrtc = to_amdgpu_crtc(crtc);
 
        spin_lock_irq(&drm_dev->event_lock);
-       acrtc->dm_irq_params.window_param.roi.x_start = 0;
-       acrtc->dm_irq_params.window_param.roi.y_start = 0;
-       acrtc->dm_irq_params.window_param.roi.x_end = 0;
-       acrtc->dm_irq_params.window_param.roi.y_end = 0;
+       acrtc->dm_irq_params.window_param.x_start = 0;
+       acrtc->dm_irq_params.window_param.y_start = 0;
+       acrtc->dm_irq_params.window_param.x_end = 0;
+       acrtc->dm_irq_params.window_param.y_end = 0;
        acrtc->dm_irq_params.window_param.activated = false;
        acrtc->dm_irq_params.window_param.update_win = false;
        acrtc->dm_irq_params.window_param.skip_frame_cnt = 0;
        dm = crc_fw_wrk->dm;
 
        mutex_lock(&dm->dc_lock);
-       dc_stream_forward_crc_window(dm->dc, &crc_fw_wrk->roi, crc_fw_wrk->stream, crc_fw_wrk->is_stop_cmd);
+       dc_stream_forward_crc_window(dm->dc, &crc_fw_wrk->rect, crc_fw_wrk->stream, crc_fw_wrk->is_stop_cmd);
        mutex_unlock(&dm->dc_lock);
 
        kfree(crc_fw_wrk);
                INIT_WORK(&crc_fw_wrk->forward_roi_work, amdgpu_dm_forward_crc_window);
                crc_fw_wrk->dm = &adev->dm;
                crc_fw_wrk->stream = stream_state;
-               crc_fw_wrk->roi.x_start = acrtc->dm_irq_params.window_param.roi.x_start;
-               crc_fw_wrk->roi.y_start = acrtc->dm_irq_params.window_param.roi.y_start;
-               crc_fw_wrk->roi.x_end = acrtc->dm_irq_params.window_param.roi.x_end;
-               crc_fw_wrk->roi.y_end = acrtc->dm_irq_params.window_param.roi.y_end;
+               crc_fw_wrk->rect.x = acrtc->dm_irq_params.window_param.x_start;
+               crc_fw_wrk->rect.y = acrtc->dm_irq_params.window_param.y_start;
+               crc_fw_wrk->rect.width = acrtc->dm_irq_params.window_param.x_end -
+                                                               acrtc->dm_irq_params.window_param.x_start;
+               crc_fw_wrk->rect.height = acrtc->dm_irq_params.window_param.y_end -
+                                                               acrtc->dm_irq_params.window_param.y_start;
                schedule_work(&crc_fw_wrk->forward_roi_work);
 
                acrtc->dm_irq_params.window_param.update_win = false;
 
 
 #ifdef CONFIG_DRM_AMD_SECURE_DISPLAY
 struct crc_window_param {
-       struct crc_region roi;
+       uint16_t x_start;
+       uint16_t y_start;
+       uint16_t x_end;
+       uint16_t y_end;
        /* CRC windwo is activated or not*/
        bool activated;
        /* Update crc window during vertical blank or not */
        struct work_struct forward_roi_work;
        struct amdgpu_display_manager *dm;
        struct dc_stream_state *stream;
-       struct crc_region roi;
+       struct rect rect;
        bool is_stop_cmd;
 };
 #endif
 
        struct amdgpu_crtc *acrtc = to_amdgpu_crtc(crtc);
 
        spin_lock_irq(&drm_dev->event_lock);
-       acrtc->dm_irq_params.window_param.roi.x_start = (uint16_t) val;
+       acrtc->dm_irq_params.window_param.x_start = (uint16_t) val;
        acrtc->dm_irq_params.window_param.update_win = false;
        spin_unlock_irq(&drm_dev->event_lock);
 
        struct amdgpu_crtc *acrtc = to_amdgpu_crtc(crtc);
 
        spin_lock_irq(&drm_dev->event_lock);
-       *val = acrtc->dm_irq_params.window_param.roi.x_start;
+       *val = acrtc->dm_irq_params.window_param.x_start;
        spin_unlock_irq(&drm_dev->event_lock);
 
        return 0;
        struct amdgpu_crtc *acrtc = to_amdgpu_crtc(crtc);
 
        spin_lock_irq(&drm_dev->event_lock);
-       acrtc->dm_irq_params.window_param.roi.y_start = (uint16_t) val;
+       acrtc->dm_irq_params.window_param.y_start = (uint16_t) val;
        acrtc->dm_irq_params.window_param.update_win = false;
        spin_unlock_irq(&drm_dev->event_lock);
 
        struct amdgpu_crtc *acrtc = to_amdgpu_crtc(crtc);
 
        spin_lock_irq(&drm_dev->event_lock);
-       *val = acrtc->dm_irq_params.window_param.roi.y_start;
+       *val = acrtc->dm_irq_params.window_param.y_start;
        spin_unlock_irq(&drm_dev->event_lock);
 
        return 0;
        struct amdgpu_crtc *acrtc = to_amdgpu_crtc(crtc);
 
        spin_lock_irq(&drm_dev->event_lock);
-       acrtc->dm_irq_params.window_param.roi.x_end = (uint16_t) val;
+       acrtc->dm_irq_params.window_param.x_end = (uint16_t) val;
        acrtc->dm_irq_params.window_param.update_win = false;
        spin_unlock_irq(&drm_dev->event_lock);
 
        struct amdgpu_crtc *acrtc = to_amdgpu_crtc(crtc);
 
        spin_lock_irq(&drm_dev->event_lock);
-       *val = acrtc->dm_irq_params.window_param.roi.x_end;
+       *val = acrtc->dm_irq_params.window_param.x_end;
        spin_unlock_irq(&drm_dev->event_lock);
 
        return 0;
        struct amdgpu_crtc *acrtc = to_amdgpu_crtc(crtc);
 
        spin_lock_irq(&drm_dev->event_lock);
-       acrtc->dm_irq_params.window_param.roi.y_end = (uint16_t) val;
+       acrtc->dm_irq_params.window_param.y_end = (uint16_t) val;
        acrtc->dm_irq_params.window_param.update_win = false;
        spin_unlock_irq(&drm_dev->event_lock);
 
        struct amdgpu_crtc *acrtc = to_amdgpu_crtc(crtc);
 
        spin_lock_irq(&drm_dev->event_lock);
-       *val = acrtc->dm_irq_params.window_param.roi.y_end;
+       *val = acrtc->dm_irq_params.window_param.y_end;
        spin_unlock_irq(&drm_dev->event_lock);
 
        return 0;
 
 #if defined(CONFIG_DRM_AMD_SECURE_DISPLAY)
 static inline void
 dc_stream_forward_dmub_crc_window(struct dc_dmub_srv *dmub_srv,
-               struct crc_region *roi, struct otg_phy_mux *mux_mapping, bool is_stop)
+               struct rect *rect, struct otg_phy_mux *mux_mapping, bool is_stop)
 {
        union dmub_rb_cmd cmd = {0};
 
        } else {
                cmd.secure_display.header.type = DMUB_CMD__SECURE_DISPLAY;
                cmd.secure_display.header.sub_type = DMUB_CMD__SECURE_DISPLAY_CRC_WIN_NOTIFY;
-               cmd.secure_display.roi_info.x_start = roi->x_start;
-               cmd.secure_display.roi_info.y_start = roi->y_start;
-               cmd.secure_display.roi_info.x_end = roi->x_end;
-               cmd.secure_display.roi_info.y_end = roi->y_end;
+               cmd.secure_display.roi_info.x_start = rect->x;
+               cmd.secure_display.roi_info.y_start = rect->y;
+               cmd.secure_display.roi_info.x_end = rect->x + rect->width;
+               cmd.secure_display.roi_info.y_end = rect->y + rect->height;
        }
 
        dc_dmub_srv_cmd_queue(dmub_srv, &cmd);
 
 static inline void
 dc_stream_forward_dmcu_crc_window(struct dmcu *dmcu,
-               struct crc_region *roi, struct otg_phy_mux *mux_mapping, bool is_stop)
+               struct rect *rect, struct otg_phy_mux *mux_mapping, bool is_stop)
 {
        if (is_stop)
                dmcu->funcs->stop_crc_win_update(dmcu, mux_mapping);
        else
-               dmcu->funcs->forward_crc_window(dmcu, roi, mux_mapping);
+               dmcu->funcs->forward_crc_window(dmcu, rect, mux_mapping);
 }
 
 bool
 dc_stream_forward_crc_window(struct dc *dc,
-               struct crc_region *roi, struct dc_stream_state *stream, bool is_stop)
+               struct rect *rect, struct dc_stream_state *stream, bool is_stop)
 {
        struct dmcu *dmcu;
        struct dc_dmub_srv *dmub_srv;
 
        /* forward to dmub */
        if (dmub_srv)
-               dc_stream_forward_dmub_crc_window(dmub_srv, roi, &mux_mapping, is_stop);
+               dc_stream_forward_dmub_crc_window(dmub_srv, rect, &mux_mapping, is_stop);
        /* forward to dmcu */
        else if (dmcu && dmcu->funcs->is_dmcu_initialized(dmcu))
-               dc_stream_forward_dmcu_crc_window(dmcu, roi, &mux_mapping, is_stop);
+               dc_stream_forward_dmcu_crc_window(dmcu, rect, &mux_mapping, is_stop);
        else
                return false;
 
 
 
 #if defined(CONFIG_DRM_AMD_SECURE_DISPLAY)
 bool dc_stream_forward_crc_window(struct dc *dc,
-               struct crc_region *roi,
+               struct rect *rect,
                struct dc_stream_state *stream,
                bool is_stop);
 #endif
 
 };
 
 #if defined(CONFIG_DRM_AMD_SECURE_DISPLAY)
-struct crc_region {
-       uint16_t x_start;
-       uint16_t y_start;
-       uint16_t x_end;
-       uint16_t y_end;
-};
-
 struct otg_phy_mux {
        uint8_t phy_output_num;
        uint8_t otg_output_num;
 
 
 #if defined(CONFIG_DRM_AMD_SECURE_DISPLAY)
 static void dcn10_forward_crc_window(struct dmcu *dmcu,
-                                       struct crc_region *crc_win,
+                                       struct rect *rect,
                                        struct otg_phy_mux *mux_mapping)
 {
        struct dce_dmcu *dmcu_dce = TO_DCE_DMCU(dmcu);
        unsigned int dmcu_max_retry_on_wait_reg_ready = 801;
        unsigned int dmcu_wait_reg_ready_interval = 100;
        unsigned int crc_start = 0, crc_end = 0, otg_phy_mux = 0;
+       int x_start, y_start, x_end, y_end;
 
        /* If microcontroller is not running, do nothing */
        if (dmcu->dmcu_state != DMCU_RUNNING)
                return;
 
-       if (!crc_win)
+       if (!rect)
                return;
 
        /* waitDMCUReadyForCmd */
                                dmcu_wait_reg_ready_interval,
                                dmcu_max_retry_on_wait_reg_ready);
 
+       x_start = rect->x;
+       y_start = rect->y;
+       x_end = x_start + rect->width;
+       y_end = y_start + rect->height;
+
        /* build up nitification data */
-       crc_start = (((unsigned int) crc_win->x_start) << 16) | crc_win->y_start;
-       crc_end = (((unsigned int) crc_win->x_end) << 16) | crc_win->y_end;
+       crc_start = (((unsigned int) x_start) << 16) | y_start;
+       crc_end = (((unsigned int) x_end) << 16) | y_end;
        otg_phy_mux =
                (((unsigned int) mux_mapping->otg_output_num) << 16) | mux_mapping->phy_output_num;
 
 
        bool (*recv_edid_cea_ack)(struct dmcu *dmcu, int *offset);
 #if defined(CONFIG_DRM_AMD_SECURE_DISPLAY)
        void (*forward_crc_window)(struct dmcu *dmcu,
-                       struct crc_region *crc_win,
+                       struct rect *rect,
                        struct otg_phy_mux *mux_mapping);
        void (*stop_crc_win_update)(struct dmcu *dmcu,
                        struct otg_phy_mux *mux_mapping);