[Mesa-dev] [PATCH 1/2] radv: precalculate some vertex info in the binding. (v2)
Bas Nieuwenhuizen
bas at basnieuwenhuizen.nl
Thu Jan 18 12:12:34 UTC 2018
On Thu, Jan 18, 2018 at 3:04 AM, Dave Airlie <airlied at gmail.com> wrote:
> From: Dave Airlie <airlied at redhat.com>
>
> This just moves some calcs from the emission to the binding.
>
> Probably won't affect much, just reduced some time spent in binding
>
> v2: Precalculate size as well, to avoid accessing ->buffer
> at all in the hw writes. (Bas)
> ---
> src/amd/vulkan/radv_cmd_buffer.c | 19 ++++++++++---------
> src/amd/vulkan/radv_private.h | 2 ++
> 2 files changed, 12 insertions(+), 9 deletions(-)
>
> diff --git a/src/amd/vulkan/radv_cmd_buffer.c b/src/amd/vulkan/radv_cmd_buffer.c
> index 172f95e7c99..ab81ed457f7 100644
> --- a/src/amd/vulkan/radv_cmd_buffer.c
> +++ b/src/amd/vulkan/radv_cmd_buffer.c
> @@ -1871,19 +1871,17 @@ radv_cmd_buffer_update_vertex_descriptors(struct radv_cmd_buffer *cmd_buffer, bo
> uint32_t *desc = &((uint32_t *)vb_ptr)[i * 4];
> uint32_t offset;
> int vb = velems->binding[i];
> - struct radv_buffer *buffer = cmd_buffer->vertex_bindings[vb].buffer;
> uint32_t stride = cmd_buffer->state.pipeline->binding_stride[vb];
> -
> - va = radv_buffer_get_va(buffer->bo);
> -
> + VkDeviceSize size = cmd_buffer->vertex_bindings[vb].size;
> + va = cmd_buffer->vertex_bindings[vb].va;
> offset = cmd_buffer->vertex_bindings[vb].offset + velems->offset[i];
> - va += offset + buffer->offset;
> + va += velems->offset[i];
> desc[0] = va;
> desc[1] = S_008F04_BASE_ADDRESS_HI(va >> 32) | S_008F04_STRIDE(stride);
> if (cmd_buffer->device->physical_device->rad_info.chip_class <= CIK && stride)
> - desc[2] = (buffer->size - offset - velems->format_size[i]) / stride + 1;
> + desc[2] = (size - offset - velems->format_size[i]) / stride + 1;
> else
> - desc[2] = buffer->size - offset;
> + desc[2] = size - offset;
> desc[3] = velems->rsrc_word3[i];
> }
>
> @@ -2372,15 +2370,18 @@ void radv_CmdBindVertexBuffers(
> assert(firstBinding + bindingCount <= MAX_VBS);
> for (uint32_t i = 0; i < bindingCount; i++) {
> uint32_t idx = firstBinding + i;
> + struct radv_buffer *buffer = radv_buffer_from_handle(pBuffers[i]);
>
> if (!changed &&
> - (vb[idx].buffer != radv_buffer_from_handle(pBuffers[i]) ||
> + (vb[idx].buffer != buffer ||
We can remove buffer entirely, and just compare va and size here?
> vb[idx].offset != pOffsets[i])) {
> changed = true;
> }
>
> - vb[idx].buffer = radv_buffer_from_handle(pBuffers[i]);
> + vb[idx].buffer = buffer;
> vb[idx].offset = pOffsets[i];
> + vb[idx].va = radv_buffer_get_va(buffer->bo) + buffer->offset + pOffsets[i];
> + vb[idx].size = buffer->size;
>
> radv_cs_add_buffer(cmd_buffer->device->ws, cmd_buffer->cs,
> vb[idx].buffer->bo, 8);
> diff --git a/src/amd/vulkan/radv_private.h b/src/amd/vulkan/radv_private.h
> index d51a669b383..e3f69fa7766 100644
> --- a/src/amd/vulkan/radv_private.h
> +++ b/src/amd/vulkan/radv_private.h
> @@ -797,6 +797,8 @@ enum radv_cmd_flush_bits {
> struct radv_vertex_binding {
> struct radv_buffer * buffer;
> VkDeviceSize offset;
> + VkDeviceSize size;
> + uint64_t va;
> };
>
> struct radv_viewport_state {
> --
> 2.14.3
>
> _______________________________________________
> mesa-dev mailing list
> mesa-dev at lists.freedesktop.org
> https://lists.freedesktop.org/mailman/listinfo/mesa-dev
More information about the mesa-dev
mailing list