Fix unsigned comparisons.
Instead of marking the comparison instruction itself as Uint32, we look at its arguments. This is more consistent what HChange does. BUG=v8:3380 TEST=mjsunit/regress/regress-3380 LOG=y R=jkummerow@chromium.org Review URL: https://codereview.chromium.org/325133004 git-svn-id: https://v8.googlecode.com/svn/branches/bleeding_edge@21762 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
This commit is contained in:
parent
05216fdd56
commit
2931f09144
@ -2371,7 +2371,9 @@ Condition LCodeGen::TokenToCondition(Token::Value op, bool is_unsigned) {
|
||||
void LCodeGen::DoCompareNumericAndBranch(LCompareNumericAndBranch* instr) {
|
||||
LOperand* left = instr->left();
|
||||
LOperand* right = instr->right();
|
||||
bool is_unsigned = instr->hydrogen()->CheckFlag(HInstruction::kUint32);
|
||||
bool is_unsigned =
|
||||
instr->hydrogen()->left()->CheckFlag(HInstruction::kUint32) ||
|
||||
instr->hydrogen()->right()->CheckFlag(HInstruction::kUint32);
|
||||
Condition cond = TokenToCondition(instr->op(), is_unsigned);
|
||||
|
||||
if (left->IsConstantOperand() && right->IsConstantOperand()) {
|
||||
|
@ -2470,7 +2470,9 @@ void LCodeGen::DoCompareMinusZeroAndBranch(LCompareMinusZeroAndBranch* instr) {
|
||||
void LCodeGen::DoCompareNumericAndBranch(LCompareNumericAndBranch* instr) {
|
||||
LOperand* left = instr->left();
|
||||
LOperand* right = instr->right();
|
||||
bool is_unsigned = instr->hydrogen()->CheckFlag(HInstruction::kUint32);
|
||||
bool is_unsigned =
|
||||
instr->hydrogen()->left()->CheckFlag(HInstruction::kUint32) ||
|
||||
instr->hydrogen()->right()->CheckFlag(HInstruction::kUint32);
|
||||
Condition cond = TokenToCondition(instr->op(), is_unsigned);
|
||||
|
||||
if (left->IsConstantOperand() && right->IsConstantOperand()) {
|
||||
|
@ -62,7 +62,6 @@ bool HUint32AnalysisPhase::IsSafeUint32Use(HValue* val, HValue* use) {
|
||||
}
|
||||
}
|
||||
} else if (use->IsCompareNumericAndBranch()) {
|
||||
return false; // TODO(svenpanne/3380): Fix and re-enable!
|
||||
HCompareNumericAndBranch* c = HCompareNumericAndBranch::cast(use);
|
||||
return IsUint32Operation(c->left()) && IsUint32Operation(c->right());
|
||||
}
|
||||
|
@ -2247,7 +2247,9 @@ void LCodeGen::DoCompareNumericAndBranch(LCompareNumericAndBranch* instr) {
|
||||
LOperand* left = instr->left();
|
||||
LOperand* right = instr->right();
|
||||
bool is_unsigned =
|
||||
instr->is_double() || instr->hydrogen()->CheckFlag(HInstruction::kUint32);
|
||||
instr->is_double() ||
|
||||
instr->hydrogen()->left()->CheckFlag(HInstruction::kUint32) ||
|
||||
instr->hydrogen()->right()->CheckFlag(HInstruction::kUint32);
|
||||
Condition cc = TokenToCondition(instr->op(), is_unsigned);
|
||||
|
||||
if (left->IsConstantOperand() && right->IsConstantOperand()) {
|
||||
|
@ -2279,7 +2279,9 @@ Condition LCodeGen::TokenToCondition(Token::Value op, bool is_unsigned) {
|
||||
void LCodeGen::DoCompareNumericAndBranch(LCompareNumericAndBranch* instr) {
|
||||
LOperand* left = instr->left();
|
||||
LOperand* right = instr->right();
|
||||
bool is_unsigned = instr->hydrogen()->CheckFlag(HInstruction::kUint32);
|
||||
bool is_unsigned =
|
||||
instr->hydrogen()->left()->CheckFlag(HInstruction::kUint32) ||
|
||||
instr->hydrogen()->right()->CheckFlag(HInstruction::kUint32);
|
||||
Condition cond = TokenToCondition(instr->op(), is_unsigned);
|
||||
|
||||
if (left->IsConstantOperand() && right->IsConstantOperand()) {
|
||||
|
@ -2238,7 +2238,9 @@ void LCodeGen::DoCompareNumericAndBranch(LCompareNumericAndBranch* instr) {
|
||||
LOperand* left = instr->left();
|
||||
LOperand* right = instr->right();
|
||||
bool is_unsigned =
|
||||
instr->is_double() || instr->hydrogen()->CheckFlag(HInstruction::kUint32);
|
||||
instr->is_double() ||
|
||||
instr->hydrogen()->left()->CheckFlag(HInstruction::kUint32) ||
|
||||
instr->hydrogen()->right()->CheckFlag(HInstruction::kUint32);
|
||||
Condition cc = TokenToCondition(instr->op(), is_unsigned);
|
||||
|
||||
if (left->IsConstantOperand() && right->IsConstantOperand()) {
|
||||
|
@ -2380,7 +2380,9 @@ void LCodeGen::DoCompareNumericAndBranch(LCompareNumericAndBranch* instr) {
|
||||
LOperand* left = instr->left();
|
||||
LOperand* right = instr->right();
|
||||
bool is_unsigned =
|
||||
instr->is_double() || instr->hydrogen()->CheckFlag(HInstruction::kUint32);
|
||||
instr->is_double() ||
|
||||
instr->hydrogen()->left()->CheckFlag(HInstruction::kUint32) ||
|
||||
instr->hydrogen()->right()->CheckFlag(HInstruction::kUint32);
|
||||
Condition cc = TokenToCondition(instr->op(), is_unsigned);
|
||||
|
||||
if (left->IsConstantOperand() && right->IsConstantOperand()) {
|
||||
|
16
test/mjsunit/regress/regress-3380.js
Normal file
16
test/mjsunit/regress/regress-3380.js
Normal file
@ -0,0 +1,16 @@
|
||||
// Copyright 2014 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
|
||||
|
||||
function foo(a) {
|
||||
return (a[0] >>> 0) > 0;
|
||||
}
|
||||
|
||||
var a = new Uint32Array([4]);
|
||||
var b = new Uint32Array([0x80000000]);
|
||||
assertTrue(foo(a));
|
||||
assertTrue(foo(a));
|
||||
%OptimizeFunctionOnNextCall(foo);
|
||||
assertTrue(foo(b))
|
Loading…
Reference in New Issue
Block a user