[PATCH 2/5] drm: use page-flip for sprites, in case no vblank event
David Herrmann
dh.herrmann at googlemail.com
Mon Mar 12 02:11:38 PDT 2012
Hi Rob
On Mon, Mar 12, 2012 at 1:48 AM, Rob Clark <rob.clark at linaro.org> wrote:
> From: Rob Clark <rob at ti.com>
>
> If the output does not support vblank events (possibly the case with
> USB or DSI command mode displays which do not have a traditional
> vsync), use instead the page_flip handler to know when the display
> is finished scanning out a sprite.
> ---
> src/compositor-drm.c | 17 +++++++++++++++--
> 1 files changed, 15 insertions(+), 2 deletions(-)
>
> diff --git a/src/compositor-drm.c b/src/compositor-drm.c
> index 67fa500..500ec15 100644
> --- a/src/compositor-drm.c
> +++ b/src/compositor-drm.c
> @@ -117,6 +117,12 @@ struct drm_sprite {
> uint32_t dest_x, dest_y;
> uint32_t dest_w, dest_h;
>
> + /*
> + * for displays that don't have a vblank (dsi command-mode displays,
> + * usb displays, etc), it can be simulated from the page-flip event
> + */
> + int simulate_vblank;
> +
> uint32_t formats[];
> };
>
> @@ -286,8 +292,7 @@ drm_output_repaint(struct weston_output *output_base,
> vbl.request.signal = (unsigned long)s;
> ret = drmWaitVBlank(compositor->drm.fd, &vbl);
> if (ret) {
> - fprintf(stderr, "vblank event request failed: %d: %s\n",
> - ret, strerror(errno));
> + s->simulate_vblank = 1;
> }
Doesn't it make sense to add an:
if (!s->simulate_vblank)
around this drmWaitVBlank call? Otherwise we try it at every repaint
and it will fail everytime.
Regards
David
> }
>
> @@ -327,6 +332,7 @@ page_flip_handler(int fd, unsigned int frame,
> struct drm_output *output = (struct drm_output *) data;
> struct drm_compositor *c =
> (struct drm_compositor *) output->base.compositor;
> + struct drm_sprite *s;
> uint32_t msecs;
>
> if (output->scanout_buffer) {
> @@ -349,6 +355,13 @@ page_flip_handler(int fd, unsigned int frame,
>
> msecs = sec * 1000 + usec / 1000;
> weston_output_finish_frame(&output->base, msecs);
> +
> + wl_list_for_each(s, &c->sprite_list, link) {
> + if (s->simulate_vblank) {
> + vblank_handler(fd, frame, sec, usec, s);
> + s->simulate_vblank = 0;
> + }
> + }
> }
>
> static int
> --
> 1.7.5.4
>
> _______________________________________________
> wayland-devel mailing list
> wayland-devel at lists.freedesktop.org
> http://lists.freedesktop.org/mailman/listinfo/wayland-devel
More information about the wayland-devel
mailing list