radv: add vertex_robustness1 to radv_shader_stage_key

Signed-off-by: Samuel Pitoiset <samuel.pitoiset@gmail.com>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/27007>
This commit is contained in:
Samuel Pitoiset 2024-01-11 16:50:23 +01:00 committed by Marge Bot
parent f2f87d0872
commit b888677dcf
3 changed files with 5 additions and 6 deletions

View file

@ -206,7 +206,7 @@ radv_generate_pipeline_key(const struct radv_device *device, const VkPipelineSha
if (uniform_robustness >= RADV_BUFFER_ROBUSTNESS_2)
key.stage_info[stage].uniform_robustness2 = 1;
if (stage == MESA_SHADER_VERTEX && vertex_robustness >= RADV_BUFFER_ROBUSTNESS_1)
key.vertex_robustness1 = 1u;
key.stage_info[stage].vertex_robustness1 = 1u;
}
key.keep_statistic_info = radv_pipeline_capture_shader_stats(device, flags);

View file

@ -92,6 +92,7 @@ struct radv_shader_stage_key {
uint8_t storage_robustness2 : 1;
uint8_t uniform_robustness2 : 1;
uint8_t vertex_robustness1 : 1;
uint8_t optimisations_disabled : 1;
};
@ -125,8 +126,6 @@ struct radv_pipeline_key {
uint32_t enable_remove_point_size : 1;
uint32_t unknown_rast_prim : 1;
uint32_t vertex_robustness1 : 1;
uint32_t keep_statistic_info : 1;
/* Pipeline shader version (up to 8) to force re-compilation when RADV_BUILD_ID_OVERRIDE is enabled. */

View file

@ -417,7 +417,7 @@ gather_info_input_decl_vs(const nir_shader *nir, unsigned location, const struct
static void
gather_shader_info_vs(struct radv_device *device, const nir_shader *nir, const struct radv_pipeline_key *pipeline_key,
struct radv_shader_info *info)
const struct radv_shader_stage_key *stage_key, struct radv_shader_info *info)
{
if (pipeline_key->vs.has_prolog && nir->info.inputs_read) {
info->vs.has_prolog = true;
@ -425,7 +425,7 @@ gather_shader_info_vs(struct radv_device *device, const nir_shader *nir, const s
}
/* Use per-attribute vertex descriptors to prevent faults and for correct bounds checking. */
info->vs.use_per_attribute_vb_descs = pipeline_key->vertex_robustness1 || info->vs.dynamic_inputs;
info->vs.use_per_attribute_vb_descs = stage_key->vertex_robustness1 || info->vs.dynamic_inputs;
/* We have to ensure consistent input register assignments between the main shader and the
* prolog.
@ -1211,7 +1211,7 @@ radv_nir_shader_info_pass(struct radv_device *device, const struct nir_shader *n
gather_shader_info_tcs(device, nir, pipeline_key, info);
break;
case MESA_SHADER_VERTEX:
gather_shader_info_vs(device, nir, pipeline_key, info);
gather_shader_info_vs(device, nir, pipeline_key, stage_key, info);
break;
case MESA_SHADER_MESH:
gather_shader_info_mesh(device, nir, pipeline_key, info);