Revision: 6742
Author: [email protected]
Date: Fri Feb 11 02:17:52 2011
Log: Prohibit moving instructions with side effects via 'EmitAtUses'.

It's not generally safe to decide to delay the evaluation of an expression
with side effects until it is used.

BUG=v8:1138

Review URL: http://codereview.chromium.org/6474035
http://code.google.com/p/v8/source/detail?r=6742

Modified:
 /branches/bleeding_edge/src/hydrogen-instructions.h

=======================================
--- /branches/bleeding_edge/src/hydrogen-instructions.h Thu Feb 10 04:02:36 2011 +++ /branches/bleeding_edge/src/hydrogen-instructions.h Fri Feb 11 02:17:52 2011
@@ -2208,7 +2208,11 @@
   }

   void SetInputRepresentation(Representation r);
-  virtual bool EmitAtUses() const { return uses()->length() <= 1; }
+
+  virtual bool EmitAtUses() const {
+    return !HasSideEffects() && (uses()->length() <= 1);
+  }
+
   virtual Representation RequiredInputRepresentation(int index) const {
     return input_representation_;
   }
@@ -2246,7 +2250,10 @@
     SetFlag(kUseGVN);
   }

-  virtual bool EmitAtUses() const { return uses()->length() <= 1; }
+  virtual bool EmitAtUses() const {
+    return !HasSideEffects() && (uses()->length() <= 1);
+  }
+
   virtual Representation RequiredInputRepresentation(int index) const {
     return Representation::Tagged();
   }
@@ -2265,7 +2272,11 @@
     set_representation(Representation::Tagged());
     SetFlag(kUseGVN);
   }
-  virtual bool EmitAtUses() const { return uses()->length() <= 1; }
+
+  virtual bool EmitAtUses() const {
+    return !HasSideEffects() && (uses()->length() <= 1);
+  }
+
   virtual Representation RequiredInputRepresentation(int index) const {
     return Representation::Tagged();
   }
@@ -2322,7 +2333,9 @@
     SetFlag(kUseGVN);
   }

-  virtual bool EmitAtUses() const { return uses()->length() <= 1; }
+  virtual bool EmitAtUses() const {
+    return !HasSideEffects() && (uses()->length() <= 1);
+  }

   DECLARE_CONCRETE_INSTRUCTION(IsConstructCall, "is_construct_call")

@@ -2427,7 +2440,9 @@
   HValue* left() const { return operands_[1]; }
   HValue* right() const { return operands_[2]; }

-  virtual bool EmitAtUses() const { return uses()->length() <= 1; }
+  virtual bool EmitAtUses() const {
+    return !HasSideEffects() && (uses()->length() <= 1);
+  }

   virtual Representation RequiredInputRepresentation(int index) const {
     return Representation::Tagged();

--
v8-dev mailing list
[email protected]
http://groups.google.com/group/v8-dev

Reply via email to