Commit fd29e246 authored by Georg Neis's avatar Georg Neis Committed by Commit Bot

[compiler] Fix bug in RepresentationChanger::GetWord32RepresentationFor

We have to respect the TypeCheckKind.

Bug: chromium:1195777
Change-Id: If1eed719fef79b7c61d99c29ba869ddd7985c413
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2817791
Commit-Queue: Georg Neis <neis@chromium.org>
Reviewed-by: 's avatarNico Hartmann <nicohartmann@chromium.org>
Cr-Commit-Position: refs/heads/master@{#73909}
parent f87baad0
...@@ -949,10 +949,10 @@ Node* RepresentationChanger::GetWord32RepresentationFor( ...@@ -949,10 +949,10 @@ Node* RepresentationChanger::GetWord32RepresentationFor(
return node; return node;
} else if (output_rep == MachineRepresentation::kWord64) { } else if (output_rep == MachineRepresentation::kWord64) {
if (output_type.Is(Type::Signed32()) || if (output_type.Is(Type::Signed32()) ||
output_type.Is(Type::Unsigned32())) { (output_type.Is(Type::Unsigned32()) &&
op = machine()->TruncateInt64ToInt32(); use_info.type_check() == TypeCheckKind::kNone) ||
} else if (output_type.Is(cache_->kSafeInteger) && (output_type.Is(cache_->kSafeInteger) &&
use_info.truncation().IsUsedAsWord32()) { use_info.truncation().IsUsedAsWord32())) {
op = machine()->TruncateInt64ToInt32(); op = machine()->TruncateInt64ToInt32();
} else if (use_info.type_check() == TypeCheckKind::kSignedSmall || } else if (use_info.type_check() == TypeCheckKind::kSignedSmall ||
use_info.type_check() == TypeCheckKind::kSigned32 || use_info.type_check() == TypeCheckKind::kSigned32 ||
......
// Copyright 2021 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() {
function foo(b) {
let y = (new Date(42)).getMilliseconds();
let x = -1;
if (b) x = 0xFFFF_FFFF;
return y < Math.max(1 << y, x, 1 + y);
}
assertTrue(foo(true));
%PrepareFunctionForOptimization(foo);
assertTrue(foo(false));
%OptimizeFunctionOnNextCall(foo);
assertTrue(foo(true));
})();
(function() {
function foo(b) {
let x = 0;
if (b) x = -1;
return x == Math.max(-1, x >>> Infinity);
}
assertFalse(foo(true));
%PrepareFunctionForOptimization(foo);
assertTrue(foo(false));
%OptimizeFunctionOnNextCall(foo);
assertFalse(foo(true));
})();
(function() {
function foo(b) {
let x = -1;
if (b) x = 0xFFFF_FFFF;
return -1 < Math.max(0, x, -1);
}
assertTrue(foo(true));
%PrepareFunctionForOptimization(foo);
assertTrue(foo(false));
%OptimizeFunctionOnNextCall(foo);
assertTrue(foo(true));
})();
(function() {
function foo(b) {
let x = 0x7FFF_FFFF;
if (b) x = 0;
return 0 < (Math.max(-5 >>> x, -5) % -5);
}
assertTrue(foo(true));
%PrepareFunctionForOptimization(foo);
assertTrue(foo(false));
%OptimizeFunctionOnNextCall(foo);
assertTrue(foo(true));
})();
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