[Mesa-dev] [PATCH v2 2/5] anv/descriptor_set: Use anv_multialloc for descriptor set layouts
Chris Wilson
chris at chris-wilson.co.uk
Fri Apr 7 08:14:06 UTC 2017
On Thu, Apr 06, 2017 at 10:53:07PM -0700, Jason Ekstrand wrote:
> ---
> src/intel/vulkan/anv_descriptor_set.c | 22 +++++++++++-----------
> 1 file changed, 11 insertions(+), 11 deletions(-)
>
> diff --git a/src/intel/vulkan/anv_descriptor_set.c b/src/intel/vulkan/anv_descriptor_set.c
> index 56a08ce..6f2280d 100644
> --- a/src/intel/vulkan/anv_descriptor_set.c
> +++ b/src/intel/vulkan/anv_descriptor_set.c
> @@ -42,7 +42,6 @@ VkResult anv_CreateDescriptorSetLayout(
> VkDescriptorSetLayout* pSetLayout)
> {
> ANV_FROM_HANDLE(anv_device, device, _device);
> - struct anv_descriptor_set_layout *set_layout;
>
> assert(pCreateInfo->sType == VK_STRUCTURE_TYPE_DESCRIPTOR_SET_LAYOUT_CREATE_INFO);
>
> @@ -54,18 +53,19 @@ VkResult anv_CreateDescriptorSetLayout(
> immutable_sampler_count += pCreateInfo->pBindings[j].descriptorCount;
> }
>
> - size_t size = sizeof(struct anv_descriptor_set_layout) +
> - (max_binding + 1) * sizeof(set_layout->binding[0]) +
> - immutable_sampler_count * sizeof(struct anv_sampler *);
> + struct anv_descriptor_set_layout *set_layout;
> + struct anv_descriptor_set_binding_layout *bindings;
> + struct anv_sampler **samplers;
>
> - set_layout = vk_alloc2(&device->alloc, pAllocator, size, 8,
> - VK_SYSTEM_ALLOCATION_SCOPE_OBJECT);
> - if (!set_layout)
> - return vk_error(VK_ERROR_OUT_OF_HOST_MEMORY);
> + struct anv_multialloc ma;
> + anv_multialloc_init2(&ma, &device->alloc, pAllocator,
> + VK_SYSTEM_ALLOCATION_SCOPE_OBJECT);
> + anv_multialloc_add(&ma, &set_layout, 1);
> + anv_multialloc_add(&ma, &bindings, max_binding + 1);
> + anv_multialloc_add(&ma, &samplers, immutable_sampler_count);
>
> - /* We just allocate all the samplers at the end of the struct */
> - struct anv_sampler **samplers =
> - (struct anv_sampler **)&set_layout->binding[max_binding + 1];
> + if (!anv_multialloc_finish(&ma))
> + return vk_error(VK_ERROR_OUT_OF_HOST_MEMORY);
As the outside observer, I suggest that using finish here is confusing.
Something like.
ANV_MULTIALLOC(ma);
anv_multialloc_add(&ma, &set_layout, 1);
anv_multialloc_add(&ma, &bindings, max_binding + 1);
anv_multialloc_add(&ma, &samplers, immutable_sampler_count);
if (!anv_multialloc_alloc(&ma,
&device->alloc ?: pAllocator,
VK_SYSTEM_ALLOCATION_SCOPE_OBJECT))
return vk_error(VK_ERROR_OUT_OF_HOST_MEMORY);
fits your current vk_alloc pattern better?
-Chris
--
Chris Wilson, Intel Open Source Technology Centre
More information about the mesa-dev
mailing list