radv: only initialize non-zero values for the default dynamic state

This avoids a big memcpy and cut the function time by 2x.

Signed-off-by: Samuel Pitoiset <samuel.pitoiset@gmail.com>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/20960>
This commit is contained in:
Samuel Pitoiset
2023-01-27 18:34:48 +01:00
committed by Marge Bot
parent 912a19e630
commit 2f93398047
3 changed files with 12 additions and 97 deletions

View File

@@ -65,98 +65,6 @@ static void radv_handle_image_transition(struct radv_cmd_buffer *cmd_buffer,
static void radv_set_rt_stack_size(struct radv_cmd_buffer *cmd_buffer, uint32_t size); static void radv_set_rt_stack_size(struct radv_cmd_buffer *cmd_buffer, uint32_t size);
const struct radv_dynamic_state default_dynamic_state = {
.vk =
{
.ia =
{
.primitive_topology = 0u,
.primitive_restart_enable = 0u,
},
.vp =
{
.depth_clip_negative_one_to_one = 0u,
.viewport_count = 0,
.scissor_count = 0,
},
.ts =
{
.patch_control_points = 0,
.domain_origin = VK_TESSELLATION_DOMAIN_ORIGIN_UPPER_LEFT,
},
.rs =
{
.rasterizer_discard_enable = 0u,
.depth_clamp_enable = 0u,
.depth_clip_enable = 0u,
.depth_bias =
{
.enable = 0,
.constant = 0.0f,
.clamp = 0.0f,
.slope = 0.0f,
},
.polygon_mode = 0,
.cull_mode = 0,
.front_face = 0u,
.conservative_mode = VK_CONSERVATIVE_RASTERIZATION_MODE_DISABLED_EXT,
.provoking_vertex = VK_PROVOKING_VERTEX_MODE_FIRST_VERTEX_EXT,
.line =
{
.width = 1.0f,
.mode = VK_LINE_RASTERIZATION_MODE_DEFAULT_EXT,
.stipple =
{
.enable = 0u,
.factor = 0u,
.pattern = 0u,
},
},
},
.fsr =
{
.fragment_size = {1u, 1u},
.combiner_ops = {VK_FRAGMENT_SHADING_RATE_COMBINER_OP_KEEP_KHR,
VK_FRAGMENT_SHADING_RATE_COMBINER_OP_KEEP_KHR},
},
.ds =
{
.depth =
{
.bounds_test =
{
.min = 0.0f,
.max = 1.0f,
},
},
.stencil =
{
.front =
{
.reference = 0u,
.compare_mask = ~0,
.write_mask = ~0,
},
.back =
{
.reference = 0u,
.compare_mask = ~0,
.write_mask = ~0,
},
},
},
.ms = {
.rasterization_samples = VK_SAMPLE_COUNT_1_BIT,
.alpha_to_coverage_enable = 0u,
.sample_mask = 0u,
},
.cb = {
.logic_op_enable = 0u,
.blend_constants = {0.0f, 0.0f, 0.0f, 0.0f},
},
},
};
static void static void
radv_bind_dynamic_state(struct radv_cmd_buffer *cmd_buffer, const struct radv_dynamic_state *src) radv_bind_dynamic_state(struct radv_cmd_buffer *cmd_buffer, const struct radv_dynamic_state *src)
{ {

View File

@@ -1040,15 +1040,24 @@ radv_pipeline_init_dynamic_state(struct radv_graphics_pipeline *pipeline,
const struct vk_graphics_pipeline_state *state) const struct vk_graphics_pipeline_state *state)
{ {
uint64_t needed_states = radv_pipeline_needed_dynamic_state(pipeline, state); uint64_t needed_states = radv_pipeline_needed_dynamic_state(pipeline, state);
struct radv_dynamic_state *dynamic = &pipeline->dynamic_state;
uint64_t states = needed_states; uint64_t states = needed_states;
pipeline->dynamic_state = default_dynamic_state; /* Initialize non-zero values for default dynamic state. */
dynamic->vk.rs.line.width = 1.0f;
dynamic->vk.fsr.fragment_size.width = 1u;
dynamic->vk.fsr.fragment_size.height = 1u;
dynamic->vk.ds.depth.bounds_test.max = 1.0f;
dynamic->vk.ds.stencil.front.compare_mask = ~0;
dynamic->vk.ds.stencil.front.write_mask = ~0;
dynamic->vk.ds.stencil.back.compare_mask = ~0;
dynamic->vk.ds.stencil.back.write_mask = ~0;
dynamic->vk.ms.rasterization_samples = VK_SAMPLE_COUNT_1_BIT;
pipeline->needed_dynamic_state = needed_states; pipeline->needed_dynamic_state = needed_states;
states &= ~pipeline->dynamic_states; states &= ~pipeline->dynamic_states;
struct radv_dynamic_state *dynamic = &pipeline->dynamic_state;
/* Input assembly. */ /* Input assembly. */
if (states & RADV_DYNAMIC_PRIMITIVE_TOPOLOGY) { if (states & RADV_DYNAMIC_PRIMITIVE_TOPOLOGY) {
dynamic->vk.ia.primitive_topology = si_translate_prim(state->ia->primitive_topology); dynamic->vk.ia.primitive_topology = si_translate_prim(state->ia->primitive_topology);

View File

@@ -1362,8 +1362,6 @@ struct radv_dynamic_state {
struct radv_sample_locations_state sample_location; struct radv_sample_locations_state sample_location;
}; };
extern const struct radv_dynamic_state default_dynamic_state;
const char *radv_get_debug_option_name(int id); const char *radv_get_debug_option_name(int id);
const char *radv_get_perftest_option_name(int id); const char *radv_get_perftest_option_name(int id);