From: Christian König Date: Sat, 9 Jun 2012 13:33:28 +0000 (+0200) Subject: st/vdpau: clear Cb&Cr with 0.5f X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=d37c3c6ebecfe404d2341b897ac9b81adce5f4d7;p=mesa.git st/vdpau: clear Cb&Cr with 0.5f That makes the output black in case of decoding errors. Signed-off-by: Christian König --- diff --git a/src/gallium/state_trackers/vdpau/surface.c b/src/gallium/state_trackers/vdpau/surface.c index fde2336ca11..cc866a6ca0d 100644 --- a/src/gallium/state_trackers/vdpau/surface.c +++ b/src/gallium/state_trackers/vdpau/surface.c @@ -355,12 +355,15 @@ vlVdpVideoSurfaceClear(vlVdpSurface *vlsurf) surfaces = vlsurf->video_buffer->get_surfaces(vlsurf->video_buffer); for (i = 0; i < VL_MAX_SURFACES; ++i) { - union pipe_color_union black = {}; + union pipe_color_union c = {}; if (!surfaces[i]) continue; - pipe->clear_render_target(pipe, surfaces[i], &black, 0, 0, + if (i > !!vlsurf->templat.interlaced) + c.f[0] = c.f[1] = c.f[2] = c.f[3] = 0.5f; + + pipe->clear_render_target(pipe, surfaces[i], &c, 0, 0, surfaces[i]->width, surfaces[i]->height); } pipe->flush(pipe, NULL);