state->abm_level = cur->abm_level;
        state->vrr_supported = cur->vrr_supported;
        state->freesync_config = cur->freesync_config;
-       state->crc_src = cur->crc_src;
        state->cm_has_degamma = cur->cm_has_degamma;
        state->cm_is_degamma_srgb = cur->cm_is_degamma_srgb;
 
         */
        for_each_oldnew_crtc_in_state(state, crtc, old_crtc_state, new_crtc_state, i) {
                struct amdgpu_crtc *acrtc = to_amdgpu_crtc(crtc);
+#ifdef CONFIG_DEBUG_FS
+               enum amdgpu_dm_pipe_crc_source cur_crc_src;
+#endif
 
                dm_new_crtc_state = to_dm_crtc_state(new_crtc_state);
 
                         * settings for the stream.
                         */
                        dm_new_crtc_state = to_dm_crtc_state(new_crtc_state);
+                       spin_lock_irqsave(&adev_to_drm(adev)->event_lock, flags);
+                       cur_crc_src = acrtc->dm_irq_params.crc_src;
+                       spin_unlock_irqrestore(&adev_to_drm(adev)->event_lock, flags);
 
-                       if (amdgpu_dm_is_valid_crc_source(dm_new_crtc_state->crc_src)) {
+                       if (amdgpu_dm_is_valid_crc_source(cur_crc_src)) {
                                amdgpu_dm_crtc_configure_crc_source(
                                        crtc, dm_new_crtc_state,
-                                       dm_new_crtc_state->crc_src);
+                                       cur_crc_src);
                        }
 #endif
                }
 
 int amdgpu_dm_crtc_set_crc_source(struct drm_crtc *crtc, const char *src_name)
 {
        enum amdgpu_dm_pipe_crc_source source = dm_parse_crc_source(src_name);
+       enum amdgpu_dm_pipe_crc_source cur_crc_src;
        struct drm_crtc_commit *commit;
        struct dm_crtc_state *crtc_state;
+       struct drm_device *drm_dev = crtc->dev;
+       struct amdgpu_crtc *acrtc = to_amdgpu_crtc(crtc);
        struct drm_dp_aux *aux = NULL;
        bool enable = false;
        bool enabled = false;
 
        enable = amdgpu_dm_is_valid_crc_source(source);
        crtc_state = to_dm_crtc_state(crtc->state);
+       spin_lock_irq(&drm_dev->event_lock);
+       cur_crc_src = acrtc->dm_irq_params.crc_src;
+       spin_unlock_irq(&drm_dev->event_lock);
 
        /*
         * USER REQ SRC | CURRENT SRC | BEHAVIOR
         */
        if (dm_is_crc_source_dprx(source) ||
            (source == AMDGPU_DM_PIPE_CRC_SOURCE_NONE &&
-            dm_is_crc_source_dprx(crtc_state->crc_src))) {
+            dm_is_crc_source_dprx(cur_crc_src))) {
                struct amdgpu_dm_connector *aconn = NULL;
                struct drm_connector *connector;
                struct drm_connector_list_iter conn_iter;
         * Reading the CRC requires the vblank interrupt handler to be
         * enabled. Keep a reference until CRC capture stops.
         */
-       enabled = amdgpu_dm_is_valid_crc_source(crtc_state->crc_src);
+       enabled = amdgpu_dm_is_valid_crc_source(cur_crc_src);
        if (!enabled && enable) {
                ret = drm_crtc_vblank_get(crtc);
                if (ret)
                }
        }
 
-       crtc_state->crc_src = source;
+       spin_lock_irq(&drm_dev->event_lock);
+       acrtc->dm_irq_params.crc_src = source;
+       spin_unlock_irq(&drm_dev->event_lock);
 
        /* Reset crc_skipped on dm state */
        crtc_state->crc_skip_count = 0;
 {
        struct dm_crtc_state *crtc_state;
        struct dc_stream_state *stream_state;
+       struct drm_device *drm_dev = NULL;
+       enum amdgpu_dm_pipe_crc_source cur_crc_src;
+       struct amdgpu_crtc *acrtc = NULL;
        uint32_t crcs[3];
+       unsigned long flags;
 
        if (crtc == NULL)
                return;
 
        crtc_state = to_dm_crtc_state(crtc->state);
        stream_state = crtc_state->stream;
+       acrtc = to_amdgpu_crtc(crtc);
+       drm_dev = crtc->dev;
+
+       spin_lock_irqsave(&drm_dev->event_lock, flags);
+       cur_crc_src = acrtc->dm_irq_params.crc_src;
+       spin_unlock_irqrestore(&drm_dev->event_lock, flags);
 
        /* Early return if CRC capture is not enabled. */
-       if (!amdgpu_dm_is_valid_crc_source(crtc_state->crc_src))
+       if (!amdgpu_dm_is_valid_crc_source(cur_crc_src))
                return;
 
        /*
                return;
        }
 
-       if (dm_is_crc_source_crtc(crtc_state->crc_src)) {
+       if (dm_is_crc_source_crtc(cur_crc_src)) {
                if (!dc_stream_get_crc(stream_state->ctx->dc, stream_state,
                                       &crcs[0], &crcs[1], &crcs[2]))
                        return;