diff options
author | Marek Olšák <maraeo@gmail.com> | 2012-03-05 14:13:19 +0100 |
---|---|---|
committer | Marek Olšák <maraeo@gmail.com> | 2012-03-05 14:55:46 +0100 |
commit | 0d91ddf1d4be712377e80d330480ff560d449c6f (patch) | |
tree | 8019993178b97f21a6d64843317f799cf7f388b0 | |
parent | 29e55bc5f1b6d7375b6a86e24ca4ae58e399011e (diff) |
r600g: don't enable tiling for STAGING and STREAM usage cases
Reviewed by: Christian König <christian.koenig@amd.com>
-rw-r--r-- | src/gallium/drivers/r600/r600_texture.c | 13 |
1 files changed, 7 insertions, 6 deletions
diff --git a/src/gallium/drivers/r600/r600_texture.c b/src/gallium/drivers/r600/r600_texture.c index 6222410f6c..e55e0d215a 100644 --- a/src/gallium/drivers/r600/r600_texture.c +++ b/src/gallium/drivers/r600/r600_texture.c @@ -623,12 +623,13 @@ struct pipe_resource *r600_texture_create(struct pipe_screen *screen, unsigned array_mode = 0; int r; - if (!(templ->flags & R600_RESOURCE_FLAG_TRANSFER) && - !(templ->bind & PIPE_BIND_SCANOUT)) { - if (rscreen->use_surface_alloc) { - if (permit_hardware_blit(screen, templ)) { - array_mode = V_038000_ARRAY_2D_TILED_THIN1; - } + if (!(templ->flags & R600_RESOURCE_FLAG_TRANSFER)) { + if (rscreen->use_surface_alloc && + !(templ->bind & PIPE_BIND_SCANOUT) && + templ->usage != PIPE_USAGE_STAGING && + templ->usage != PIPE_USAGE_STREAM && + permit_hardware_blit(screen, templ)) { + array_mode = V_038000_ARRAY_2D_TILED_THIN1; } else if (util_format_is_compressed(templ->format)) { array_mode = V_038000_ARRAY_1D_TILED_THIN1; } |