Correctly handle remapping of array dereferences if ->var is a variable.
authorEric Anholt <eric@anholt.net>
Mon, 26 Apr 2010 22:01:50 +0000 (15:01 -0700)
committerIan Romanick <ian.d.romanick@intel.com>
Thu, 29 Apr 2010 01:22:54 +0000 (18:22 -0700)
ir_function_inlining.cpp

index ba556a84992c482a7dd5eb8b63552d9b00044687..5b1b3cb8b0b7fa13797636299fd82b12cbf71d78 100644 (file)
@@ -184,34 +184,25 @@ ir_function_cloning_visitor::visit(ir_swizzle *ir)
 void
 ir_function_cloning_visitor::visit(ir_dereference *ir)
 {
-   if (ir->mode == ir_dereference::ir_reference_variable) {
-      ir_variable *old_var = ir->var->as_variable();
-
-      /* If it's a deref of a real variable, then we need to remap it if
-       * it was local to the function.
-       */
-      if (old_var) {
-        ir_variable *new_var;
-
-        new_var = this->get_remapped_variable(old_var);
+   ir_variable *old_var = ir->var->as_variable();
+   ir_instruction *var;
 
-        this->result = new ir_dereference(new_var);
-      } else {
-        ir->var->accept(this);
+   if (old_var)
+      var = this->get_remapped_variable(old_var);
+   else {
+      ir->var->accept(this);
+      var = this->result;
+   }
 
-        this->result = new ir_dereference(this->result);
-      }
+   if (ir->mode == ir_dereference::ir_reference_variable) {
+      this->result = new ir_dereference(var);
    } else if (ir->mode == ir_dereference::ir_reference_array) {
-      ir_instruction *variable;
       ir_rvalue *index;
 
-      ir->var->accept(this);
-      variable = this->result;
-
       ir->selector.array_index->accept(this);
       index = this->result->as_rvalue();
 
-      this->result = new ir_dereference(variable, index);
+      this->result = new ir_dereference(var, index);
    } else {
       assert(ir->mode == ir_dereference::ir_reference_record);
       /* FINISHME: inlining of structure references */