Mesa (master): st/vdpau: Output surfaces that are too large to fit into the display target will be clipped
Christian König
deathsimple at kemper.freedesktop.org
Wed Sep 14 14:07:51 UTC 2011
Module: Mesa
Branch: master
Commit: 6cf0581159a33f3dc10be38cdc7ab94d9cbacc1e
URL: http://cgit.freedesktop.org/mesa/mesa/commit/?id=6cf0581159a33f3dc10be38cdc7ab94d9cbacc1e
Author: Emeric Grange <emeric.grange at gmail.com>
Date: Mon Sep 12 23:39:32 2011 +0200
st/vdpau: Output surfaces that are too large to fit into the display target will be clipped
Signed-off-by: Emeric Grange <emeric.grange at gmail.com>
Reviewed-by: Christian König <deathsimple at vodafone.de>
---
src/gallium/state_trackers/vdpau/presentation.c | 8 +++++++-
1 files changed, 7 insertions(+), 1 deletions(-)
diff --git a/src/gallium/state_trackers/vdpau/presentation.c b/src/gallium/state_trackers/vdpau/presentation.c
index b3b543b..d83dde6 100644
--- a/src/gallium/state_trackers/vdpau/presentation.c
+++ b/src/gallium/state_trackers/vdpau/presentation.c
@@ -185,6 +185,7 @@ vlVdpPresentationQueueDisplay(VdpPresentationQueue presentation_queue,
vlVdpPresentationQueue *pq;
vlVdpOutputSurface *surf;
struct pipe_surface *drawable_surface;
+ struct pipe_video_rect vo_rect;
pq = vlGetDataHTAB(presentation_queue);
if (!pq)
@@ -198,9 +199,14 @@ vlVdpPresentationQueueDisplay(VdpPresentationQueue presentation_queue,
if (!surf)
return VDP_STATUS_INVALID_HANDLE;
+ vo_rect.x = 0;
+ vo_rect.y = 0;
+ vo_rect.w = clip_width;
+ vo_rect.h = clip_height;
+
vl_compositor_clear_layers(&pq->compositor);
vl_compositor_set_rgba_layer(&pq->compositor, 0, surf->sampler_view, NULL, NULL);
- vl_compositor_render(&pq->compositor, drawable_surface, NULL, NULL, true);
+ vl_compositor_render(&pq->compositor, drawable_surface, NULL, &vo_rect, true);
pq->device->context->pipe->screen->flush_frontbuffer
(
More information about the mesa-commit
mailing list