nvk: Don't clobber vb0 after repeated blits
If a program does two blits in a row, we internally do a sequence of operations that involves binding vb0. Previously, the vb0 state after each operation would look something like: | operation | cmd->state.gfx.vb0 | hardware | save->vb0 | | ---------------------------- | ------------------ | --------- | --------- | | | user | user | | | nvk_meta_begin() | user | user | user | | BindVertexBuffers(internal0) | internal0 | internal0 | user | | nvk_meta_end() | internal0 | user | | | nvk_meta_begin() | internal0 | user | internal0 | | BindVertexBuffers(internal1) | internal1 | internal1 | internal0 | | nvk_meta_end() | internal1 | internal0 | | That is, CmdBindVertexBuffers() would update cmd->state.gfx.vb0, but nvk_meta_end() would not. This meant that the last operation would bind a driver-internal buffer instead of the original value that the user set. This change fixes the issue by tracking cmd->state.gfx.vb0 in nvk_cmd_bind_vertex_buffer(), which both CmdBindVertexBuffers() and nvk_meta_end() call into. After this commit, the state looks like: | operation | cmd->state.gfx.vb0 | hardware | save->vb0 | | ---------------------------- | ------------------ | --------- | --------- | | | user | user | | | nvk_meta_begin() | user | user | user | | BindVertexBuffers(internal0) | internal0 | internal0 | user | | nvk_meta_end() | user | user | | | nvk_meta_begin() | user | user | user | | BindVertexBuffers(internal1) | internal1 | internal1 | user | | nvk_meta_end() | user | user | | To test this commit, build gtk4 commit 87b66de1, run: GSK_RENDERER=vulkan gtk4-demo --run=image_scaling then select trilinear filtering in the dropdown and check for rendering artifacts. Fixes:e1c66501
("nvk: Use vk_meta for CmdClearAttachments") Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/27559> (cherry picked from commitd98ff2cc4a
)
This commit is contained in:

committed by
Eric Engestrom

parent
73a46e084d
commit
41f8ef617c
@@ -1914,7 +1914,7 @@
|
||||
"description": "nvk: Don't clobber vb0 after repeated blits",
|
||||
"nominated": true,
|
||||
"nomination_type": 1,
|
||||
"resolution": 0,
|
||||
"resolution": 1,
|
||||
"main_sha": null,
|
||||
"because_sha": "e1c665013b14d63ccf4be265c5ec59914e5a5748",
|
||||
"notes": null
|
||||
|
@@ -1678,6 +1678,10 @@ void
|
||||
nvk_cmd_bind_vertex_buffer(struct nvk_cmd_buffer *cmd, uint32_t vb_idx,
|
||||
struct nvk_addr_range addr_range)
|
||||
{
|
||||
/* Used for meta save/restore */
|
||||
if (vb_idx == 0)
|
||||
cmd->state.gfx.vb0 = addr_range;
|
||||
|
||||
struct nv_push *p = nvk_cmd_buffer_push(cmd, 6);
|
||||
|
||||
P_MTHD(p, NV9097, SET_VERTEX_STREAM_A_LOCATION_A(vb_idx));
|
||||
@@ -1722,10 +1726,6 @@ nvk_CmdBindVertexBuffers2(VkCommandBuffer commandBuffer,
|
||||
const struct nvk_addr_range addr_range =
|
||||
nvk_buffer_addr_range(buffer, pOffsets[i], size);
|
||||
|
||||
/* Used for meta save/restore */
|
||||
if (idx == 0)
|
||||
cmd->state.gfx.vb0 = addr_range;
|
||||
|
||||
nvk_cmd_bind_vertex_buffer(cmd, idx, addr_range);
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user