radv: update configuring DB states on GFX12
Signed-off-by: Samuel Pitoiset <samuel.pitoiset@gmail.com> Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/29417>
This commit is contained in:

committed by
Marge Bot

parent
f12c236625
commit
0c019ff028
@@ -3118,25 +3118,48 @@ radv_emit_blend_constants(struct radv_cmd_buffer *cmd_buffer)
|
||||
static void
|
||||
radv_emit_stencil(struct radv_cmd_buffer *cmd_buffer)
|
||||
{
|
||||
const struct radv_device *device = radv_cmd_buffer_device(cmd_buffer);
|
||||
const struct radv_physical_device *pdev = radv_device_physical(device);
|
||||
const struct radv_dynamic_state *d = &cmd_buffer->state.dynamic;
|
||||
|
||||
radeon_set_context_reg_seq(cmd_buffer->cs, R_028430_DB_STENCILREFMASK, 2);
|
||||
radeon_emit(cmd_buffer->cs, S_028430_STENCILTESTVAL(d->vk.ds.stencil.front.reference) |
|
||||
S_028430_STENCILMASK(d->vk.ds.stencil.front.compare_mask) |
|
||||
S_028430_STENCILWRITEMASK(d->vk.ds.stencil.front.write_mask) |
|
||||
S_028430_STENCILOPVAL(1));
|
||||
radeon_emit(cmd_buffer->cs, S_028434_STENCILTESTVAL_BF(d->vk.ds.stencil.back.reference) |
|
||||
S_028434_STENCILMASK_BF(d->vk.ds.stencil.back.compare_mask) |
|
||||
S_028434_STENCILWRITEMASK_BF(d->vk.ds.stencil.back.write_mask) |
|
||||
S_028434_STENCILOPVAL_BF(1));
|
||||
if (pdev->info.gfx_level >= GFX12) {
|
||||
radeon_set_context_reg(
|
||||
cmd_buffer->cs, R_028088_DB_STENCIL_REF,
|
||||
S_028088_TESTVAL(d->vk.ds.stencil.front.reference) | S_028088_TESTVAL_BF(d->vk.ds.stencil.back.reference));
|
||||
|
||||
radeon_set_context_reg(cmd_buffer->cs, R_028090_DB_STENCIL_READ_MASK,
|
||||
S_028090_TESTMASK(d->vk.ds.stencil.front.compare_mask) |
|
||||
S_028090_TESTMASK_BF(d->vk.ds.stencil.back.compare_mask));
|
||||
|
||||
radeon_set_context_reg(cmd_buffer->cs, R_028094_DB_STENCIL_WRITE_MASK,
|
||||
S_028094_WRITEMASK(d->vk.ds.stencil.front.write_mask) |
|
||||
S_028094_WRITEMASK_BF(d->vk.ds.stencil.back.write_mask));
|
||||
} else {
|
||||
radeon_set_context_reg_seq(cmd_buffer->cs, R_028430_DB_STENCILREFMASK, 2);
|
||||
radeon_emit(cmd_buffer->cs, S_028430_STENCILTESTVAL(d->vk.ds.stencil.front.reference) |
|
||||
S_028430_STENCILMASK(d->vk.ds.stencil.front.compare_mask) |
|
||||
S_028430_STENCILWRITEMASK(d->vk.ds.stencil.front.write_mask) |
|
||||
S_028430_STENCILOPVAL(1));
|
||||
radeon_emit(cmd_buffer->cs, S_028434_STENCILTESTVAL_BF(d->vk.ds.stencil.back.reference) |
|
||||
S_028434_STENCILMASK_BF(d->vk.ds.stencil.back.compare_mask) |
|
||||
S_028434_STENCILWRITEMASK_BF(d->vk.ds.stencil.back.write_mask) |
|
||||
S_028434_STENCILOPVAL_BF(1));
|
||||
}
|
||||
}
|
||||
|
||||
static void
|
||||
radv_emit_depth_bounds(struct radv_cmd_buffer *cmd_buffer)
|
||||
{
|
||||
const struct radv_device *device = radv_cmd_buffer_device(cmd_buffer);
|
||||
const struct radv_physical_device *pdev = radv_device_physical(device);
|
||||
const struct radv_dynamic_state *d = &cmd_buffer->state.dynamic;
|
||||
|
||||
radeon_set_context_reg_seq(cmd_buffer->cs, R_028020_DB_DEPTH_BOUNDS_MIN, 2);
|
||||
if (pdev->info.gfx_level >= GFX12) {
|
||||
radeon_set_context_reg_seq(cmd_buffer->cs, R_028050_DB_DEPTH_BOUNDS_MIN, 2);
|
||||
} else {
|
||||
radeon_set_context_reg_seq(cmd_buffer->cs, R_028020_DB_DEPTH_BOUNDS_MIN, 2);
|
||||
}
|
||||
|
||||
radeon_emit(cmd_buffer->cs, fui(d->vk.ds.depth.bounds_test.min));
|
||||
radeon_emit(cmd_buffer->cs, fui(d->vk.ds.depth.bounds_test.max));
|
||||
}
|
||||
@@ -3286,33 +3309,46 @@ radv_emit_primitive_topology(struct radv_cmd_buffer *cmd_buffer)
|
||||
static void
|
||||
radv_emit_depth_control(struct radv_cmd_buffer *cmd_buffer)
|
||||
{
|
||||
const struct radv_device *device = radv_cmd_buffer_device(cmd_buffer);
|
||||
const struct radv_physical_device *pdev = radv_device_physical(device);
|
||||
const struct radv_rendering_state *render = &cmd_buffer->state.render;
|
||||
const struct radv_dynamic_state *d = &cmd_buffer->state.dynamic;
|
||||
const bool stencil_test_enable =
|
||||
d->vk.ds.stencil.test_enable && (render->ds_att_aspects & VK_IMAGE_ASPECT_STENCIL_BIT);
|
||||
|
||||
radeon_set_context_reg(
|
||||
cmd_buffer->cs, R_028800_DB_DEPTH_CONTROL,
|
||||
const uint32_t db_depth_control =
|
||||
S_028800_Z_ENABLE(d->vk.ds.depth.test_enable ? 1 : 0) |
|
||||
S_028800_Z_WRITE_ENABLE(d->vk.ds.depth.write_enable ? 1 : 0) | S_028800_ZFUNC(d->vk.ds.depth.compare_op) |
|
||||
S_028800_DEPTH_BOUNDS_ENABLE(d->vk.ds.depth.bounds_test.enable ? 1 : 0) |
|
||||
S_028800_STENCIL_ENABLE(stencil_test_enable) | S_028800_BACKFACE_ENABLE(stencil_test_enable) |
|
||||
S_028800_STENCILFUNC(d->vk.ds.stencil.front.op.compare) |
|
||||
S_028800_STENCILFUNC_BF(d->vk.ds.stencil.back.op.compare));
|
||||
S_028800_Z_WRITE_ENABLE(d->vk.ds.depth.write_enable ? 1 : 0) | S_028800_ZFUNC(d->vk.ds.depth.compare_op) |
|
||||
S_028800_DEPTH_BOUNDS_ENABLE(d->vk.ds.depth.bounds_test.enable ? 1 : 0) |
|
||||
S_028800_STENCIL_ENABLE(stencil_test_enable) | S_028800_BACKFACE_ENABLE(stencil_test_enable) |
|
||||
S_028800_STENCILFUNC(d->vk.ds.stencil.front.op.compare) |
|
||||
S_028800_STENCILFUNC_BF(d->vk.ds.stencil.back.op.compare);
|
||||
|
||||
if (pdev->info.gfx_level >= GFX12) {
|
||||
radeon_set_context_reg(cmd_buffer->cs, R_028070_DB_DEPTH_CONTROL, db_depth_control);
|
||||
} else {
|
||||
radeon_set_context_reg(cmd_buffer->cs, R_028800_DB_DEPTH_CONTROL, db_depth_control);
|
||||
}
|
||||
}
|
||||
|
||||
static void
|
||||
radv_emit_stencil_control(struct radv_cmd_buffer *cmd_buffer)
|
||||
{
|
||||
const struct radv_device *device = radv_cmd_buffer_device(cmd_buffer);
|
||||
const struct radv_physical_device *pdev = radv_device_physical(device);
|
||||
const struct radv_dynamic_state *d = &cmd_buffer->state.dynamic;
|
||||
const uint32_t db_stencil_control =
|
||||
S_02842C_STENCILFAIL(radv_translate_stencil_op(d->vk.ds.stencil.front.op.fail)) |
|
||||
S_02842C_STENCILZPASS(radv_translate_stencil_op(d->vk.ds.stencil.front.op.pass)) |
|
||||
S_02842C_STENCILZFAIL(radv_translate_stencil_op(d->vk.ds.stencil.front.op.depth_fail)) |
|
||||
S_02842C_STENCILFAIL_BF(radv_translate_stencil_op(d->vk.ds.stencil.back.op.fail)) |
|
||||
S_02842C_STENCILZPASS_BF(radv_translate_stencil_op(d->vk.ds.stencil.back.op.pass)) |
|
||||
S_02842C_STENCILZFAIL_BF(radv_translate_stencil_op(d->vk.ds.stencil.back.op.depth_fail));
|
||||
|
||||
radeon_set_context_reg(cmd_buffer->cs, R_02842C_DB_STENCIL_CONTROL,
|
||||
S_02842C_STENCILFAIL(radv_translate_stencil_op(d->vk.ds.stencil.front.op.fail)) |
|
||||
S_02842C_STENCILZPASS(radv_translate_stencil_op(d->vk.ds.stencil.front.op.pass)) |
|
||||
S_02842C_STENCILZFAIL(radv_translate_stencil_op(d->vk.ds.stencil.front.op.depth_fail)) |
|
||||
S_02842C_STENCILFAIL_BF(radv_translate_stencil_op(d->vk.ds.stencil.back.op.fail)) |
|
||||
S_02842C_STENCILZPASS_BF(radv_translate_stencil_op(d->vk.ds.stencil.back.op.pass)) |
|
||||
S_02842C_STENCILZFAIL_BF(radv_translate_stencil_op(d->vk.ds.stencil.back.op.depth_fail)));
|
||||
if (pdev->info.gfx_level >= GFX12) {
|
||||
radeon_set_context_reg(cmd_buffer->cs, R_028074_DB_STENCIL_CONTROL, db_stencil_control);
|
||||
} else {
|
||||
radeon_set_context_reg(cmd_buffer->cs, R_02842C_DB_STENCIL_CONTROL, db_stencil_control);
|
||||
}
|
||||
}
|
||||
|
||||
static bool
|
||||
@@ -5182,7 +5218,11 @@ radv_emit_alpha_to_coverage_enable(struct radv_cmd_buffer *cmd_buffer)
|
||||
|
||||
db_alpha_to_mask |= S_028B70_ALPHA_TO_MASK_ENABLE(d->vk.ms.alpha_to_coverage_enable);
|
||||
|
||||
radeon_set_context_reg(cmd_buffer->cs, R_028B70_DB_ALPHA_TO_MASK, db_alpha_to_mask);
|
||||
if (pdev->info.gfx_level >= GFX12) {
|
||||
radeon_set_context_reg(cmd_buffer->cs, R_02807C_DB_ALPHA_TO_MASK, db_alpha_to_mask);
|
||||
} else {
|
||||
radeon_set_context_reg(cmd_buffer->cs, R_028B70_DB_ALPHA_TO_MASK, db_alpha_to_mask);
|
||||
}
|
||||
}
|
||||
|
||||
static void
|
||||
@@ -10342,8 +10382,13 @@ radv_emit_db_shader_control(struct radv_cmd_buffer *cmd_buffer)
|
||||
}
|
||||
}
|
||||
|
||||
radeon_opt_set_context_reg(cmd_buffer, R_02880C_DB_SHADER_CONTROL, RADV_TRACKED_DB_SHADER_CONTROL,
|
||||
db_shader_control);
|
||||
if (pdev->info.gfx_level >= GFX12) {
|
||||
radeon_opt_set_context_reg(cmd_buffer, R_02806C_DB_SHADER_CONTROL, RADV_TRACKED_DB_SHADER_CONTROL,
|
||||
db_shader_control);
|
||||
} else {
|
||||
radeon_opt_set_context_reg(cmd_buffer, R_02880C_DB_SHADER_CONTROL, RADV_TRACKED_DB_SHADER_CONTROL,
|
||||
db_shader_control);
|
||||
}
|
||||
|
||||
cmd_buffer->state.dirty &= ~RADV_CMD_DIRTY_DB_SHADER_CONTROL;
|
||||
}
|
||||
|
Reference in New Issue
Block a user