Index: src/compiler/mips/instruction-selector-mips.cc |
diff --git a/src/compiler/mips/instruction-selector-mips.cc b/src/compiler/mips/instruction-selector-mips.cc |
index 274de03389e408f508e1085cbc5faf12d7bd447e..f8ecf90203c47343b42897b1cb8ffa5ff615bdcd 100644 |
--- a/src/compiler/mips/instruction-selector-mips.cc |
+++ b/src/compiler/mips/instruction-selector-mips.cc |
@@ -1274,6 +1274,9 @@ void VisitWordCompareZero(InstructionSelector* selector, Node* user, |
case IrOpcode::kInt32SubWithOverflow: |
cont->OverwriteAndNegateIfEqual(kOverflow); |
return VisitBinop(selector, node, kMipsSubOvf, cont); |
+ case IrOpcode::kInt32MulWithOverflow: |
+ cont->OverwriteAndNegateIfEqual(kOverflow); |
+ return VisitBinop(selector, node, kMipsMulOvf, cont); |
default: |
break; |
} |
@@ -1408,6 +1411,14 @@ void InstructionSelector::VisitInt32SubWithOverflow(Node* node) { |
VisitBinop(this, node, kMipsSubOvf, &cont); |
} |
+void InstructionSelector::VisitInt32MulWithOverflow(Node* node) { |
+ if (Node* ovf = NodeProperties::FindProjection(node, 1)) { |
+ FlagsContinuation cont = FlagsContinuation::ForSet(kOverflow, ovf); |
+ return VisitBinop(this, node, kMipsMulOvf, &cont); |
+ } |
+ FlagsContinuation cont; |
+ VisitBinop(this, node, kMipsMulOvf, &cont); |
+} |
void InstructionSelector::VisitFloat32Equal(Node* node) { |
FlagsContinuation cont = FlagsContinuation::ForSet(kEqual, node); |