Commit 10b15ba8 authored by Yu Yin's avatar Yu Yin Committed by Commit Bot

[mips64] Do not use optimized word32 compare on simulator.

Change-Id: I2453256c192a5b58f241c4c73a32e8d41cf55a0e
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1657973
Auto-Submit: Yu Yin <xwafish@gmail.com>
Reviewed-by: 's avatarBill Budge <bbudge@chromium.org>
Commit-Queue: Yu Yin <xwafish@gmail.com>
Cr-Commit-Position: refs/heads/master@{#62160}
parent 18268d6f
...@@ -1946,7 +1946,17 @@ void VisitWord32Compare(InstructionSelector* selector, Node* node, ...@@ -1946,7 +1946,17 @@ void VisitWord32Compare(InstructionSelector* selector, Node* node,
// in those cases. Unfortunately, the solution is not complete because // in those cases. Unfortunately, the solution is not complete because
// it might skip cases where Word32 full compare is needed, so // it might skip cases where Word32 full compare is needed, so
// basically it is a hack. // basically it is a hack.
// When call to a host function in simulator, if the function return a
// int32 value, the simulator do not sign-extended to int64 because in
// simulator we do not know the function whether return a int32 or int64.
// so we need do a full word32 compare in this case.
#ifndef USE_SIMULATOR
if (IsNodeUnsigned(node->InputAt(0)) != IsNodeUnsigned(node->InputAt(1))) { if (IsNodeUnsigned(node->InputAt(0)) != IsNodeUnsigned(node->InputAt(1))) {
#else
if (IsNodeUnsigned(node->InputAt(0)) != IsNodeUnsigned(node->InputAt(1)) ||
node->InputAt(0)->opcode() == IrOpcode::kCall ||
node->InputAt(1)->opcode() == IrOpcode::kCall ) {
#endif
VisitFullWord32Compare(selector, node, kMips64Cmp, cont); VisitFullWord32Compare(selector, node, kMips64Cmp, cont);
} else { } else {
VisitOptimizedWord32Compare(selector, node, kMips64Cmp, cont); VisitOptimizedWord32Compare(selector, node, kMips64Cmp, cont);
......
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