radv: handle NULL vertex bindings
With VK_EXT_robustness2, an element of pBuffers can be NULL. Signed-off-by: Samuel Pitoiset <samuel.pitoiset@gmail.com> Reviewed-by: Bas Nieuwenhuizen <bas@basnieuwenhuizen.nl> Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/4775>
This commit is contained in:

committed by
Marge Bot

parent
c1ef225d18
commit
0f1ead7b53
@@ -3453,19 +3453,22 @@ void radv_CmdBindVertexBuffers(
|
||||
|
||||
assert(firstBinding + bindingCount <= MAX_VBS);
|
||||
for (uint32_t i = 0; i < bindingCount; i++) {
|
||||
RADV_FROM_HANDLE(radv_buffer, buffer, pBuffers[i]);
|
||||
uint32_t idx = firstBinding + i;
|
||||
|
||||
if (!changed &&
|
||||
(vb[idx].buffer != radv_buffer_from_handle(pBuffers[i]) ||
|
||||
(vb[idx].buffer != buffer ||
|
||||
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];
|
||||
|
||||
radv_cs_add_buffer(cmd_buffer->device->ws, cmd_buffer->cs,
|
||||
vb[idx].buffer->bo);
|
||||
if (buffer) {
|
||||
radv_cs_add_buffer(cmd_buffer->device->ws,
|
||||
cmd_buffer->cs, vb[idx].buffer->bo);
|
||||
}
|
||||
}
|
||||
|
||||
if (!changed) {
|
||||
|
Reference in New Issue
Block a user