From: Samuel Pitoiset Date: Mon, 4 May 2020 14:03:35 +0000 (+0200) Subject: aco: prevent invalid loads/stores vectorization if robustness is enabled X-Git-Url: https://git.libre-soc.org/?p=mesa.git;a=commitdiff_plain;h=266978f7cabe2c09e5538ef1b79efdd96b2cba00 aco: prevent invalid loads/stores vectorization if robustness is enabled Only UBO, SSBO, global and push constants accesses should matter. This fixes a bunch of new robustness2 failures. Note that RADV/LLVM isn't affected because it relies on LLVM for loads/stores vectorization and LLVM doesn't vectorize in this situation as well. Signed-off-by: Samuel Pitoiset Reviewed-by: Rhys Perry Part-of: --- diff --git a/src/amd/compiler/aco_instruction_selection_setup.cpp b/src/amd/compiler/aco_instruction_selection_setup.cpp index f1fde789e7b..44659b46229 100644 --- a/src/amd/compiler/aco_instruction_selection_setup.cpp +++ b/src/amd/compiler/aco_instruction_selection_setup.cpp @@ -994,12 +994,20 @@ setup_nir(isel_context *ctx, nir_shader *nir) bool lower_to_scalar = false; bool lower_pack = false; + nir_variable_mode robust_modes = (nir_variable_mode)0; + + if (ctx->options->robust_buffer_access) { + robust_modes = (nir_variable_mode)(nir_var_mem_ubo | + nir_var_mem_ssbo | + nir_var_mem_global | + nir_var_mem_push_const); + } + if (nir_opt_load_store_vectorize(nir, (nir_variable_mode)(nir_var_mem_ssbo | nir_var_mem_ubo | nir_var_mem_push_const | nir_var_mem_shared | nir_var_mem_global), - mem_vectorize_callback, - (nir_variable_mode)0)) { + mem_vectorize_callback, robust_modes)) { lower_to_scalar = true; lower_pack = true; }