On 01/23/2018 03:11 AM, Gert Wollny wrote:
Don't allocate a zero-sized array, when no texture offsets are given.

Reviewed-by: Nicolai Hähnle <nicolai.haeh...@amd.com>
Signed-off-by: Gert Wollny <gw.foss...@gmail.com>
---
  .../tests/test_glsl_to_tgsi_lifetime.cpp           | 23 +++++++++++++++-------
  1 file changed, 16 insertions(+), 7 deletions(-)

diff --git a/src/mesa/state_tracker/tests/test_glsl_to_tgsi_lifetime.cpp 
b/src/mesa/state_tracker/tests/test_glsl_to_tgsi_lifetime.cpp
index 93f4020ebf..d0ac8b1020 100644
--- a/src/mesa/state_tracker/tests/test_glsl_to_tgsi_lifetime.cpp
+++ b/src/mesa/state_tracker/tests/test_glsl_to_tgsi_lifetime.cpp
@@ -1374,10 +1374,14 @@ MockShader::MockShader(const 
vector<MockCodelineWithSwizzle>& source):
           next_instr->dst[k] = create_dst_register(i.dst[k].first, 
i.dst[k].second);
        }
        next_instr->tex_offset_num_offset = i.tex_offsets.size();
-      next_instr->tex_offsets = new st_src_reg[i.tex_offsets.size()];
-      for (unsigned k = 0; k < i.tex_offsets.size(); ++k) {
-         next_instr->tex_offsets[k] = 
create_src_register(i.tex_offsets[k].first,
-                                                          
i.tex_offsets[k].second);
+      if (next_instr->tex_offset_num_offset > 0) {
+         next_instr->tex_offsets = new st_src_reg[i.tex_offsets.size()];
+         for (unsigned k = 0; k < i.tex_offsets.size(); ++k) {
+            next_instr->tex_offsets[k] = 
create_src_register(i.tex_offsets[k].first,
+                                                             
i.tex_offsets[k].second);
+         }
+      } else {
+         next_instr->tex_offsets = nullptr;
        }
        program->push_tail(next_instr);
     }
@@ -1407,10 +1411,15 @@ MockShader::MockShader(const vector<MockCodeline>& 
source):
           next_instr->dst[k] = create_dst_register(i.dst[k]);
        }
        next_instr->tex_offset_num_offset = i.tex_offsets.size();
-      next_instr->tex_offsets = new st_src_reg[i.tex_offsets.size()];
-      for (unsigned k = 0; k < i.tex_offsets.size(); ++k) {
-         next_instr->tex_offsets[k] = create_src_register(i.tex_offsets[k]);
+      if (next_instr->tex_offset_num_offset > 0) {
+         next_instr->tex_offsets = new st_src_reg[i.tex_offsets.size()];
+         for (unsigned k = 0; k < i.tex_offsets.size(); ++k) {
+            next_instr->tex_offsets[k] = create_src_register(i.tex_offsets[k]);
+         }
+      } else {
+         next_instr->tex_offsets = nullptr;
        }
+

Stray whitespace change?

        program->push_tail(next_instr);
     }
     ++num_temps;


Could you repost all the patches in the final series?

Otherwise, for 1,2,3,6: Reviewed-by: Brian Paul <bri...@vmware.com>


-Brian
_______________________________________________
mesa-dev mailing list
mesa-dev@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/mesa-dev

Reply via email to