提交 e7c31f6f 编写于 作者: R Robert Foss 提交者: Eric Anholt

drm/vc4: Return -EBUSY if there's already a pending flip event.

As per the documentation in drm_crtc.h, atomic_commit should return
-EBUSY if an asynchronous update is requested and there is an earlier
update pending.

v2: Rebase on the s/async/nonblock/ change.
Signed-off-by: NRobert Foss <robert.foss@collabora.com>
Reviewed-by: NEric Anholt <eric@anholt.net>
上级 ee7c10e1
...@@ -117,10 +117,18 @@ static int vc4_atomic_commit(struct drm_device *dev, ...@@ -117,10 +117,18 @@ static int vc4_atomic_commit(struct drm_device *dev,
return -ENOMEM; return -ENOMEM;
/* Make sure that any outstanding modesets have finished. */ /* Make sure that any outstanding modesets have finished. */
ret = down_interruptible(&vc4->async_modeset); if (nonblock) {
if (ret) { ret = down_trylock(&vc4->async_modeset);
kfree(c); if (ret) {
return ret; kfree(c);
return -EBUSY;
}
} else {
ret = down_interruptible(&vc4->async_modeset);
if (ret) {
kfree(c);
return ret;
}
} }
ret = drm_atomic_helper_prepare_planes(dev, state); ret = drm_atomic_helper_prepare_planes(dev, state);
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册