radeonsi: use staging buffer uploads for most VRAM buffers

Reviewed-by: Pierre-Eric Pelloux-Prayer <pierre-eric.pelloux-prayer@amd.com>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/6948>
This commit is contained in:
Marek Olšák
2020-09-27 13:26:01 -04:00
committed by Marge Bot
parent 701f7ae9d2
commit fd6bbdcf59

View File

@@ -203,8 +203,18 @@ void si_init_resource_fields(struct si_screen *sscreen, struct si_resource *res,
if (res->domains & RADEON_DOMAIN_VRAM) {
res->vram_usage = size;
/* We don't want to evict buffers from VRAM by mapping them for CPU access,
* because they might never be moved back again. If a buffer is large enough,
* upload data by copying from a temporary GTT buffer. 8K might not seem much,
* but there can be 100000 buffers.
*
* This tweak improves performance for viewperf.
*/
const unsigned min_size = 8196; /* tuned to minimize mapped VRAM */
const unsigned max_staging_uploads = 1; /* number of uploads before mapping directly */
res->max_forced_staging_uploads = res->b.max_forced_staging_uploads =
sscreen->info.has_dedicated_vram && size >= sscreen->info.vram_vis_size / 4 ? 1 : 0;
sscreen->info.has_dedicated_vram && size >= min_size ? max_staging_uploads : 0;
} else if (res->domains & RADEON_DOMAIN_GTT) {
res->gart_usage = size;
}