diff options
author | Marek Olšák <[email protected]> | 2013-07-01 02:29:50 +0200 |
---|---|---|
committer | Marek Olšák <[email protected]> | 2013-07-08 20:25:18 +0200 |
commit | b1a061b81ed78cd3c71304e122374ae970d04908 (patch) | |
tree | 38d8e9b4cb48852dc937faea55b59afd1c83abc2 /src/gallium/drivers/r600 | |
parent | 87669c3654fa22491fed68781d31cdec75c2a96c (diff) |
r600g: enable fast MSAA color clear for array/3D/cube textures
Reviewed-by: Alex Deucher <[email protected]>
Diffstat (limited to 'src/gallium/drivers/r600')
-rw-r--r-- | src/gallium/drivers/r600/r600_blit.c | 7 |
1 files changed, 3 insertions, 4 deletions
diff --git a/src/gallium/drivers/r600/r600_blit.c b/src/gallium/drivers/r600/r600_blit.c index 3b8a28b7fe8..7a0e2561b85 100644 --- a/src/gallium/drivers/r600/r600_blit.c +++ b/src/gallium/drivers/r600/r600_blit.c @@ -447,7 +447,6 @@ static bool can_fast_clear_color(struct pipe_context *ctx) for (i = 0; i < fb->nr_cbufs; i++) { struct r600_texture *tex = (struct r600_texture *)fb->cbufs[i]->texture; - int target = fb->cbufs[i]->texture->target; if (tex->cmask_size == 0) { return false; @@ -458,9 +457,9 @@ static bool can_fast_clear_color(struct pipe_context *ctx) return false; } - /* textures with multiple images are not supported */ - if (target != PIPE_TEXTURE_2D && target != PIPE_TEXTURE_RECT && - target != PIPE_TEXTURE_1D) { + /* the clear is allowed if all layers are bound */ + if (fb->cbufs[i]->u.tex.first_layer != 0 || + fb->cbufs[i]->u.tex.last_layer != util_max_layer(&tex->resource.b.b, 0)) { return false; } } |