diff options
author | Christian König <christian.koenig@amd.com> | 2013-05-08 17:03:01 +0200 |
---|---|---|
committer | Christian König <christian.koenig@amd.com> | 2013-05-14 15:16:15 +0200 |
commit | e195d301aeb50a33cc20b208900164a97524bef4 (patch) | |
tree | c74727d0ecacb1289fb00b934b482c4f24d46949 /src/gallium/state_trackers/vdpau/presentation.c | |
parent | 176ad54c04f5b945e47b61a3cad4b6c87d883a41 (diff) | |
download | external_mesa3d-e195d301aeb50a33cc20b208900164a97524bef4.zip external_mesa3d-e195d301aeb50a33cc20b208900164a97524bef4.tar.gz external_mesa3d-e195d301aeb50a33cc20b208900164a97524bef4.tar.bz2 |
vl/vdpau: fix PresentationQueueQuerySurfaceStatus
The last queued surface always keeps displaying.
Fixing a problem with XBMC.
Signed-off-by: Christian König <christian.koenig@amd.com>
Diffstat (limited to 'src/gallium/state_trackers/vdpau/presentation.c')
-rw-r--r-- | src/gallium/state_trackers/vdpau/presentation.c | 8 |
1 files changed, 5 insertions, 3 deletions
diff --git a/src/gallium/state_trackers/vdpau/presentation.c b/src/gallium/state_trackers/vdpau/presentation.c index a5466cd..c9f8ea7 100644 --- a/src/gallium/state_trackers/vdpau/presentation.c +++ b/src/gallium/state_trackers/vdpau/presentation.c @@ -238,8 +238,6 @@ vlVdpPresentationQueueDisplay(VdpPresentationQueue presentation_queue, surf_templ.format = tex->format; surf_draw = pipe->create_surface(pipe, tex, &surf_templ); - surf->timestamp = (vlVdpTime)earliest_presentation_time; - dst_clip.x0 = 0; dst_clip.y0 = 0; dst_clip.x1 = clip_width ? clip_width : surf_draw->width; @@ -276,6 +274,7 @@ vlVdpPresentationQueueDisplay(VdpPresentationQueue presentation_queue, pipe->screen->fence_reference(pipe->screen, &surf->fence, NULL); pipe->flush(pipe, &surf->fence, 0); + pq->last_surf = surf; if (dump_window == -1) { dump_window = debug_get_num_option("VDPAU_DUMP", 0); @@ -360,7 +359,10 @@ vlVdpPresentationQueueQuerySurfaceStatus(VdpPresentationQueue presentation_queue *first_presentation_time = 0; if (!surf->fence) { - *status = VDP_PRESENTATION_QUEUE_STATUS_IDLE; + if (pq->last_surf == surf) + *status = VDP_PRESENTATION_QUEUE_STATUS_VISIBLE; + else + *status = VDP_PRESENTATION_QUEUE_STATUS_IDLE; } else { pipe_mutex_lock(pq->device->mutex); screen = pq->device->vscreen->pscreen; |