From: Rob Clark Date: Sat, 11 Jun 2016 13:21:10 +0000 (-0400) Subject: gallium/util: make util_copy_framebuffer_state(src=NULL) work X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=def044376a6d15d992fd8e0d9a63c40a9f509c78;p=mesa.git gallium/util: make util_copy_framebuffer_state(src=NULL) work Be more consistent with the other u_inlines util_copy_xyz_state() helpers and support NULL src. Signed-off-by: Rob Clark Reviewed-by: Marek Olšák --- diff --git a/src/gallium/auxiliary/util/u_framebuffer.c b/src/gallium/auxiliary/util/u_framebuffer.c index f2108a15fa1..c2948a5cfb3 100644 --- a/src/gallium/auxiliary/util/u_framebuffer.c +++ b/src/gallium/auxiliary/util/u_framebuffer.c @@ -86,22 +86,37 @@ util_copy_framebuffer_state(struct pipe_framebuffer_state *dst, { unsigned i; - dst->width = src->width; - dst->height = src->height; + if (src) { + dst->width = src->width; + dst->height = src->height; - dst->samples = src->samples; - dst->layers = src->layers; + dst->samples = src->samples; + dst->layers = src->layers; - for (i = 0; i < src->nr_cbufs; i++) - pipe_surface_reference(&dst->cbufs[i], src->cbufs[i]); + for (i = 0; i < src->nr_cbufs; i++) + pipe_surface_reference(&dst->cbufs[i], src->cbufs[i]); - /* Set remaining dest cbuf pointers to NULL */ - for ( ; i < ARRAY_SIZE(dst->cbufs); i++) - pipe_surface_reference(&dst->cbufs[i], NULL); + /* Set remaining dest cbuf pointers to NULL */ + for ( ; i < ARRAY_SIZE(dst->cbufs); i++) + pipe_surface_reference(&dst->cbufs[i], NULL); - dst->nr_cbufs = src->nr_cbufs; + dst->nr_cbufs = src->nr_cbufs; - pipe_surface_reference(&dst->zsbuf, src->zsbuf); + pipe_surface_reference(&dst->zsbuf, src->zsbuf); + } else { + dst->width = 0; + dst->height = 0; + + dst->samples = 0; + dst->layers = 0; + + for (i = 0 ; i < ARRAY_SIZE(dst->cbufs); i++) + pipe_surface_reference(&dst->cbufs[i], NULL); + + dst->nr_cbufs = 0; + + pipe_surface_reference(&dst->zsbuf, NULL); + } }