Mesa (master): aco: prevent invalid loads/stores vectorization if robustness is enabled
GitLab Mirror
gitlab-mirror at kemper.freedesktop.org
Mon May 11 07:47:30 UTC 2020
Module: Mesa
Branch: master
Commit: 266978f7cabe2c09e5538ef1b79efdd96b2cba00
URL: http://cgit.freedesktop.org/mesa/mesa/commit/?id=266978f7cabe2c09e5538ef1b79efdd96b2cba00
Author: Samuel Pitoiset <samuel.pitoiset at gmail.com>
Date: Mon May 4 16:03:35 2020 +0200
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 <samuel.pitoiset at gmail.com>
Reviewed-by: Rhys Perry <pendingchaos02 at gmail.com>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/4881>
---
src/amd/compiler/aco_instruction_selection_setup.cpp | 12 ++++++++++--
1 file changed, 10 insertions(+), 2 deletions(-)
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;
}
More information about the mesa-commit
mailing list