From: Jason Ekstrand Date: Sat, 7 Dec 2019 00:11:14 +0000 (-0600) Subject: anv: Re-capture all batch and state buffers X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=bce1c3c668223254c4cb4ba4e83aed8c3e22b469;p=mesa.git anv: Re-capture all batch and state buffers When we moved from allocating BOs directly to using the BO cache, we lost the EXEC_OBJECT_CAPTURE flag on all our state buffers. Fixes: 3119b96bdf57 "anv: Allocate block pool BOs from the cache" Fixes: ee77938733cd "anv: Allocate batch and fence buffers from..." Reviewed-by: Caio Marcelo de Oliveira Filho --- diff --git a/src/intel/vulkan/anv_allocator.c b/src/intel/vulkan/anv_allocator.c index 6e75904ab1c..82fec5262c3 100644 --- a/src/intel/vulkan/anv_allocator.c +++ b/src/intel/vulkan/anv_allocator.c @@ -487,14 +487,10 @@ anv_block_pool_expand_range(struct anv_block_pool *pool, * hard work for us. When using softpin, we're in control and the fixed * addresses we choose are fine for base addresses. */ - enum anv_bo_alloc_flags bo_alloc_flags = 0; + enum anv_bo_alloc_flags bo_alloc_flags = ANV_BO_ALLOC_CAPTURE; if (!pool->use_softpin) bo_alloc_flags |= ANV_BO_ALLOC_32BIT_ADDRESS; - uint64_t bo_flags = 0; - if (pool->device->instance->physicalDevice.has_exec_capture) - bo_flags |= EXEC_OBJECT_CAPTURE; - if (pool->use_softpin) { uint32_t new_bo_size = size - pool->size; struct anv_bo *new_bo; @@ -1315,7 +1311,8 @@ anv_bo_pool_alloc(struct anv_bo_pool *pool, uint32_t size, VkResult result = anv_device_alloc_bo(pool->device, pow2_size, ANV_BO_ALLOC_MAPPED | - ANV_BO_ALLOC_SNOOPED, + ANV_BO_ALLOC_SNOOPED | + ANV_BO_ALLOC_CAPTURE, 0 /* explicit_address */, &bo); if (result != VK_SUCCESS)