| Index: src/hydrogen-instructions.h
|
| diff --git a/src/hydrogen-instructions.h b/src/hydrogen-instructions.h
|
| index f01ea65cf9e96012d50e6ed3c76db7e0f74330df..03e7bc8f697bd00fb3b4896a437c9818c593a9c0 100644
|
| --- a/src/hydrogen-instructions.h
|
| +++ b/src/hydrogen-instructions.h
|
| @@ -2041,7 +2041,11 @@ class HCompare: public HBinaryOperation {
|
| }
|
|
|
| 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_;
|
| }
|
| @@ -2079,7 +2083,10 @@ class HCompareJSObjectEq: public HBinaryOperation {
|
| 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();
|
| }
|
| @@ -2098,7 +2105,11 @@ class HUnaryPredicate: public HUnaryOperation {
|
| 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();
|
| }
|
| @@ -2237,7 +2248,9 @@ class HInstanceOf: public HBinaryOperation {
|
| SetAllSideEffects();
|
| }
|
|
|
| - 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();
|
|
|