Commit aef6a7ee authored by Joonyoung Shim's avatar Joonyoung Shim Committed by Dave Airlie

drm: fix page_flip error handling

Free event and restore event_space only when page_flip->flags has
DRM_MODE_PAGE_FLIP_EVENT if page_flip() is failed.
Signed-off-by: default avatarJoonyoung Shim <jy0922.shim@samsung.com>
Signed-off-by: default avatarKyungmin Park <kyungmin.park@samsung.com>
Reviewed-by: default avatarMichel Dänzer <michel.daenzer@amd.com>
Signed-off-by: default avatarDave Airlie <airlied@redhat.com>
parent d6b83952
...@@ -3335,10 +3335,12 @@ int drm_mode_page_flip_ioctl(struct drm_device *dev, ...@@ -3335,10 +3335,12 @@ int drm_mode_page_flip_ioctl(struct drm_device *dev,
ret = crtc->funcs->page_flip(crtc, fb, e); ret = crtc->funcs->page_flip(crtc, fb, e);
if (ret) { if (ret) {
spin_lock_irqsave(&dev->event_lock, flags); if (page_flip->flags & DRM_MODE_PAGE_FLIP_EVENT) {
file_priv->event_space += sizeof e->event; spin_lock_irqsave(&dev->event_lock, flags);
spin_unlock_irqrestore(&dev->event_lock, flags); file_priv->event_space += sizeof e->event;
kfree(e); spin_unlock_irqrestore(&dev->event_lock, flags);
kfree(e);
}
} }
out: out:
......
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