radv: add radv_cmd_set_depth_write_enable()

Signed-off-by: Samuel Pitoiset <samuel.pitoiset@gmail.com>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/36979>
This commit is contained in:
Samuel Pitoiset
2025-08-22 17:25:01 +02:00
committed by Marge Bot
parent d2aa54c76f
commit e2145bd0c6
+17 -6
View File
@@ -505,6 +505,16 @@ radv_cmd_set_depth_test_enable(struct radv_cmd_buffer *cmd_buffer, bool depth_te
state->dirty_dynamic |= RADV_DYNAMIC_DEPTH_TEST_ENABLE;
}
ALWAYS_INLINE static void
radv_cmd_set_depth_write_enable(struct radv_cmd_buffer *cmd_buffer, bool depth_write_enable)
{
struct radv_cmd_state *state = &cmd_buffer->state;
state->dynamic.vk.ds.depth.write_enable = depth_write_enable;
state->dirty_dynamic |= RADV_DYNAMIC_DEPTH_WRITE_ENABLE;
}
static void
radv_bind_dynamic_state(struct radv_cmd_buffer *cmd_buffer, const struct radv_dynamic_state *src)
{
@@ -822,7 +832,12 @@ radv_bind_dynamic_state(struct radv_cmd_buffer *cmd_buffer, const struct radv_dy
}
}
RADV_CMP_COPY(vk.ds.depth.write_enable, RADV_DYNAMIC_DEPTH_WRITE_ENABLE);
if (copy_mask & RADV_DYNAMIC_DEPTH_WRITE_ENABLE) {
if (dest->vk.ds.depth.write_enable != src->vk.ds.depth.write_enable) {
radv_cmd_set_depth_write_enable(cmd_buffer, src->vk.ds.depth.write_enable);
}
}
RADV_CMP_COPY(vk.ds.depth.compare_op, RADV_DYNAMIC_DEPTH_COMPARE_OP);
RADV_CMP_COPY(vk.ds.depth.bounds_test.enable, RADV_DYNAMIC_DEPTH_BOUNDS_TEST_ENABLE);
RADV_CMP_COPY(vk.ds.stencil.test_enable, RADV_DYNAMIC_STENCIL_TEST_ENABLE);
@@ -8639,11 +8654,7 @@ VKAPI_ATTR void VKAPI_CALL
radv_CmdSetDepthWriteEnable(VkCommandBuffer commandBuffer, VkBool32 depthWriteEnable)
{
VK_FROM_HANDLE(radv_cmd_buffer, cmd_buffer, commandBuffer);
struct radv_cmd_state *state = &cmd_buffer->state;
state->dynamic.vk.ds.depth.write_enable = depthWriteEnable;
state->dirty_dynamic |= RADV_DYNAMIC_DEPTH_WRITE_ENABLE;
radv_cmd_set_depth_write_enable(cmd_buffer, depthWriteEnable);
}
VKAPI_ATTR void VKAPI_CALL