Commit a7d67a64 authored by svenpanne's avatar svenpanne Committed by Commit bot

Fixed Hydrogen environment handling for mul-i on ARM and ARM64.

The whole logic in DoMul makes me cry, so I made only the minimal
change to fix the issue...

BUG=v8:451322
LOG=y

Review URL: https://codereview.chromium.org/873703002

Cr-Commit-Position: refs/heads/master@{#26261}
parent 431a0834
...@@ -1508,9 +1508,10 @@ LInstruction* LChunkBuilder::DoMul(HMul* instr) { ...@@ -1508,9 +1508,10 @@ LInstruction* LChunkBuilder::DoMul(HMul* instr) {
bool can_overflow = instr->CheckFlag(HValue::kCanOverflow); bool can_overflow = instr->CheckFlag(HValue::kCanOverflow);
bool bailout_on_minus_zero = instr->CheckFlag(HValue::kBailoutOnMinusZero); bool bailout_on_minus_zero = instr->CheckFlag(HValue::kBailoutOnMinusZero);
int32_t constant_value = 0;
if (right->IsConstant()) { if (right->IsConstant()) {
HConstant* constant = HConstant::cast(right); HConstant* constant = HConstant::cast(right);
int32_t constant_value = constant->Integer32Value(); constant_value = constant->Integer32Value();
// Constants -1, 0 and 1 can be optimized if the result can overflow. // Constants -1, 0 and 1 can be optimized if the result can overflow.
// For other constants, it can be optimized only without overflow. // For other constants, it can be optimized only without overflow.
if (!can_overflow || ((constant_value >= -1) && (constant_value <= 1))) { if (!can_overflow || ((constant_value >= -1) && (constant_value <= 1))) {
...@@ -1533,7 +1534,10 @@ LInstruction* LChunkBuilder::DoMul(HMul* instr) { ...@@ -1533,7 +1534,10 @@ LInstruction* LChunkBuilder::DoMul(HMul* instr) {
right_op = UseRegister(right); right_op = UseRegister(right);
} }
LMulI* mul = new(zone()) LMulI(left_op, right_op); LMulI* mul = new(zone()) LMulI(left_op, right_op);
if (can_overflow || bailout_on_minus_zero) { if (right_op->IsConstantOperand()
? ((can_overflow && constant_value == -1) ||
(bailout_on_minus_zero && constant_value <= 0))
: (can_overflow || bailout_on_minus_zero)) {
AssignEnvironment(mul); AssignEnvironment(mul);
} }
return DefineAsRegister(mul); return DefineAsRegister(mul);
......
...@@ -1963,7 +1963,9 @@ LInstruction* LChunkBuilder::DoMul(HMul* instr) { ...@@ -1963,7 +1963,9 @@ LInstruction* LChunkBuilder::DoMul(HMul* instr) {
: UseRegisterAtStart(least_const); : UseRegisterAtStart(least_const);
LInstruction* result = LInstruction* result =
DefineAsRegister(new(zone()) LMulConstIS(left, right)); DefineAsRegister(new(zone()) LMulConstIS(left, right));
if ((bailout_on_minus_zero && constant <= 0) || can_overflow) { if ((bailout_on_minus_zero && constant <= 0) ||
(can_overflow && constant != 1 &&
base::bits::IsPowerOfTwo32(constant_abs))) {
result = AssignEnvironment(result); result = AssignEnvironment(result);
} }
return result; return result;
......
// Copyright 2015 the V8 project authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
// Flags: --allow-natives-syntax
var foo = 0;
function bar() {
var baz = 0 - {};
if (foo > 24) return baz * 0;
}
bar();
bar();
%OptimizeFunctionOnNextCall(bar);
bar();
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment