Commit a0e4e575 authored by Daniel Vetter's avatar Daniel Vetter Committed by Rodrigo Siqueira

drm/vkms: Use spin_lock_irq in process context

The worker is always in process context, no need for the _irqsafe
version. Same for the set_source callback, that's only called from the
debugfs handler in a syscall.

Cc: Shayenne Moura <shayenneluzmoura@gmail.com>
Cc: Rodrigo Siqueira <rodrigosiqueiramelo@gmail.com>
Cc: Haneen Mohammed <hamohammed.sa@gmail.com>
Cc: Daniel Vetter <daniel@ffwll.ch>
Signed-off-by: default avatarDaniel Vetter <daniel.vetter@intel.com>
Reviewed-by: default avatarRodrigo Siqueira <rodrigosiqueiramelo@gmail.com>
Tested-by: default avatarRodrigo Siqueira <rodrigosiqueiramelo@gmail.com>
Signed-off-by: default avatarRodrigo Siqueira <rodrigosiqueiramelo@gmail.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20190606222751.32567-3-daniel.vetter@ffwll.ch
parent 18d0952a
...@@ -167,16 +167,15 @@ void vkms_crc_work_handle(struct work_struct *work) ...@@ -167,16 +167,15 @@ void vkms_crc_work_handle(struct work_struct *work)
u32 crc32 = 0; u32 crc32 = 0;
u64 frame_start, frame_end; u64 frame_start, frame_end;
bool crc_pending; bool crc_pending;
unsigned long flags;
spin_lock_irqsave(&out->state_lock, flags); spin_lock_irq(&out->state_lock);
frame_start = crtc_state->frame_start; frame_start = crtc_state->frame_start;
frame_end = crtc_state->frame_end; frame_end = crtc_state->frame_end;
crc_pending = crtc_state->crc_pending; crc_pending = crtc_state->crc_pending;
crtc_state->frame_start = 0; crtc_state->frame_start = 0;
crtc_state->frame_end = 0; crtc_state->frame_end = 0;
crtc_state->crc_pending = false; crtc_state->crc_pending = false;
spin_unlock_irqrestore(&out->state_lock, flags); spin_unlock_irq(&out->state_lock);
/* /*
* We raced with the vblank hrtimer and previous work already computed * We raced with the vblank hrtimer and previous work already computed
...@@ -255,7 +254,6 @@ int vkms_set_crc_source(struct drm_crtc *crtc, const char *src_name) ...@@ -255,7 +254,6 @@ int vkms_set_crc_source(struct drm_crtc *crtc, const char *src_name)
{ {
struct vkms_output *out = drm_crtc_to_vkms_output(crtc); struct vkms_output *out = drm_crtc_to_vkms_output(crtc);
bool enabled = false; bool enabled = false;
unsigned long flags;
int ret = 0; int ret = 0;
ret = vkms_crc_parse_source(src_name, &enabled); ret = vkms_crc_parse_source(src_name, &enabled);
...@@ -263,9 +261,9 @@ int vkms_set_crc_source(struct drm_crtc *crtc, const char *src_name) ...@@ -263,9 +261,9 @@ int vkms_set_crc_source(struct drm_crtc *crtc, const char *src_name)
/* make sure nothing is scheduled on crtc workq */ /* make sure nothing is scheduled on crtc workq */
flush_workqueue(out->crc_workq); flush_workqueue(out->crc_workq);
spin_lock_irqsave(&out->lock, flags); spin_lock_irq(&out->lock);
out->crc_enabled = enabled; out->crc_enabled = enabled;
spin_unlock_irqrestore(&out->lock, flags); spin_unlock_irq(&out->lock);
return ret; return ret;
} }
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment