mirror of
https://gitlab.freedesktop.org/mesa/mesa.git
synced 2026-05-05 13:58:04 +02:00
radv: add radv_cmd_set_stencil_write_mask()
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:
parent
97d6b4e398
commit
a3e828fe99
1 changed files with 24 additions and 10 deletions
|
|
@ -352,6 +352,19 @@ radv_cmd_set_stencil_compare_mask(struct radv_cmd_buffer *cmd_buffer, VkStencilF
|
|||
state->dirty_dynamic |= RADV_DYNAMIC_STENCIL_COMPARE_MASK;
|
||||
}
|
||||
|
||||
ALWAYS_INLINE static void
|
||||
radv_cmd_set_stencil_write_mask(struct radv_cmd_buffer *cmd_buffer, VkStencilFaceFlags face_mask, uint32_t write_mask)
|
||||
{
|
||||
struct radv_cmd_state *state = &cmd_buffer->state;
|
||||
|
||||
if (face_mask & VK_STENCIL_FACE_FRONT_BIT)
|
||||
state->dynamic.vk.ds.stencil.front.write_mask = write_mask;
|
||||
if (face_mask & VK_STENCIL_FACE_BACK_BIT)
|
||||
state->dynamic.vk.ds.stencil.back.write_mask = write_mask;
|
||||
|
||||
state->dirty_dynamic |= RADV_DYNAMIC_STENCIL_WRITE_MASK;
|
||||
}
|
||||
|
||||
static void
|
||||
radv_bind_dynamic_state(struct radv_cmd_buffer *cmd_buffer, const struct radv_dynamic_state *src)
|
||||
{
|
||||
|
|
@ -641,8 +654,16 @@ radv_bind_dynamic_state(struct radv_cmd_buffer *cmd_buffer, const struct radv_dy
|
|||
}
|
||||
}
|
||||
|
||||
RADV_CMP_COPY(vk.ds.stencil.front.write_mask, RADV_DYNAMIC_STENCIL_WRITE_MASK);
|
||||
RADV_CMP_COPY(vk.ds.stencil.back.write_mask, RADV_DYNAMIC_STENCIL_WRITE_MASK);
|
||||
if (copy_mask & RADV_DYNAMIC_STENCIL_WRITE_MASK) {
|
||||
if (dest->vk.ds.stencil.front.write_mask != src->vk.ds.stencil.front.write_mask) {
|
||||
radv_cmd_set_stencil_write_mask(cmd_buffer, VK_STENCIL_FACE_FRONT_BIT, src->vk.ds.stencil.front.write_mask);
|
||||
}
|
||||
|
||||
if (dest->vk.ds.stencil.back.write_mask != src->vk.ds.stencil.back.write_mask) {
|
||||
radv_cmd_set_stencil_write_mask(cmd_buffer, VK_STENCIL_FACE_BACK_BIT, src->vk.ds.stencil.back.write_mask);
|
||||
}
|
||||
}
|
||||
|
||||
RADV_CMP_COPY(vk.ds.stencil.front.reference, RADV_DYNAMIC_STENCIL_REFERENCE);
|
||||
RADV_CMP_COPY(vk.ds.stencil.back.reference, RADV_DYNAMIC_STENCIL_REFERENCE);
|
||||
RADV_CMP_COPY(vk.ds.depth.test_enable, RADV_DYNAMIC_DEPTH_TEST_ENABLE);
|
||||
|
|
@ -8331,14 +8352,7 @@ VKAPI_ATTR void VKAPI_CALL
|
|||
radv_CmdSetStencilWriteMask(VkCommandBuffer commandBuffer, VkStencilFaceFlags faceMask, uint32_t writeMask)
|
||||
{
|
||||
VK_FROM_HANDLE(radv_cmd_buffer, cmd_buffer, commandBuffer);
|
||||
struct radv_cmd_state *state = &cmd_buffer->state;
|
||||
|
||||
if (faceMask & VK_STENCIL_FACE_FRONT_BIT)
|
||||
state->dynamic.vk.ds.stencil.front.write_mask = writeMask;
|
||||
if (faceMask & VK_STENCIL_FACE_BACK_BIT)
|
||||
state->dynamic.vk.ds.stencil.back.write_mask = writeMask;
|
||||
|
||||
state->dirty_dynamic |= RADV_DYNAMIC_STENCIL_WRITE_MASK;
|
||||
radv_cmd_set_stencil_write_mask(cmd_buffer, faceMask, writeMask);
|
||||
}
|
||||
|
||||
VKAPI_ATTR void VKAPI_CALL
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue