0cbfcede6d
Bug: v8:12781 Change-Id: I1b0be6803d6a9f4ab7071bc3ae5abeb8f29ce9c9 Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/3829753 Commit-Queue: Emanuel Ziegler <ecmziegler@chromium.org> Reviewed-by: Emanuel Ziegler <ecmziegler@chromium.org> Cr-Commit-Position: refs/heads/main@{#82680}
144 lines
5.5 KiB
C++
144 lines
5.5 KiB
C++
// Copyright 2022 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.
|
|
|
|
#include "test/common/flag-utils.h"
|
|
#include "test/common/node-observer-tester.h"
|
|
#include "test/unittests/test-utils.h"
|
|
#include "testing/gtest/include/gtest/gtest.h"
|
|
|
|
namespace v8 {
|
|
namespace internal {
|
|
namespace compiler {
|
|
|
|
using SloppyEqualityTest = TestWithContextAndZone;
|
|
|
|
struct TestCase {
|
|
TestCase(const char* l, const char* r, NodeObserver* observer)
|
|
: warmup{std::make_pair(l, r)}, observer(observer) {
|
|
DCHECK_NOT_NULL(observer);
|
|
}
|
|
std::vector<std::pair<const char*, const char*>> warmup;
|
|
NodeObserver* observer;
|
|
};
|
|
|
|
class TestSloppyEqualityFactory {
|
|
public:
|
|
explicit TestSloppyEqualityFactory(Zone* zone) : zone_(zone) {}
|
|
|
|
NodeObserver* SpeculativeNumberEqual(NumberOperationHint hint) {
|
|
return zone_->New<CreationObserver>([hint](const Node* node) {
|
|
EXPECT_EQ(IrOpcode::kSpeculativeNumberEqual, node->opcode());
|
|
EXPECT_EQ(hint, NumberOperationHintOf(node->op()));
|
|
});
|
|
}
|
|
|
|
NodeObserver* JSEqual(CompareOperationHint /*hint*/) {
|
|
return zone_->New<CreationObserver>([](const Node* node) {
|
|
EXPECT_EQ(IrOpcode::kJSEqual, node->opcode());
|
|
// TODO(paolosev): compare hint
|
|
});
|
|
}
|
|
|
|
NodeObserver* OperatorChange(IrOpcode::Value created_op,
|
|
IrOpcode::Value modified_op) {
|
|
return zone_->New<ModificationObserver>(
|
|
[created_op](const Node* node) {
|
|
EXPECT_EQ(created_op, node->opcode());
|
|
},
|
|
[modified_op](const Node* node, const ObservableNodeState& old_state)
|
|
-> NodeObserver::Observation {
|
|
if (old_state.opcode() != node->opcode()) {
|
|
EXPECT_EQ(modified_op, node->opcode());
|
|
return NodeObserver::Observation::kStop;
|
|
}
|
|
return NodeObserver::Observation::kContinue;
|
|
});
|
|
}
|
|
|
|
private:
|
|
Zone* zone_;
|
|
};
|
|
|
|
TEST_F(SloppyEqualityTest, SloppyEqualityTest) {
|
|
FlagScope<bool> allow_natives_syntax(&i::FLAG_allow_natives_syntax, true);
|
|
FlagScope<bool> always_turbofan(&i::FLAG_always_turbofan, false);
|
|
TestSloppyEqualityFactory f(zone());
|
|
// TODO(nicohartmann@, v8:5660): Collect more precise feedback for some useful
|
|
// cases.
|
|
TestCase cases[] = {
|
|
{"3", "8", f.SpeculativeNumberEqual(NumberOperationHint::kSignedSmall)},
|
|
//{"3", "null",
|
|
// f.SpeculativeNumberEqual(NumberOperationHint::kNumberOrOddball)},
|
|
//{"3", "undefined",
|
|
// f.SpeculativeNumberEqual(NumberOperationHint::kNumberOrOddball)},
|
|
//{"3", "true",
|
|
// f.SpeculativeNumberEqual(NumberOperationHint::kNumberOrOddball)},
|
|
{"3", "\"abc\"", f.JSEqual(CompareOperationHint::kAny)},
|
|
{"3.14", "3", f.SpeculativeNumberEqual(NumberOperationHint::kNumber)},
|
|
//{"3.14", "null",
|
|
// f.SpeculativeNumberEqual(NumberOperationHint::kNumberOrOddball)},
|
|
//{"3.14", "undefined",
|
|
// f.SpeculativeNumberEqual(NumberOperationHint::kNumberOrOddball)},
|
|
//{"3.14", "true",
|
|
// f.SpeculativeNumberEqual(NumberOperationHint::kNumberOrOddball)},
|
|
{"3.14", "\"abc\"", f.JSEqual(CompareOperationHint::kAny)},
|
|
{"\"abc\"", "3", f.JSEqual(CompareOperationHint::kAny)},
|
|
{"\"abc\"", "null", f.JSEqual(CompareOperationHint::kAny)},
|
|
{"\"abc\"", "undefined", f.JSEqual(CompareOperationHint::kAny)},
|
|
{"\"abc\"", "true", f.JSEqual(CompareOperationHint::kAny)},
|
|
{"\"abc\"", "\"xy\"",
|
|
f.JSEqual(CompareOperationHint::kInternalizedString)},
|
|
//{"true", "3",
|
|
// f.SpeculativeNumberEqual(NumberOperationHint::kNumberOrOddball)},
|
|
//{"true", "null",
|
|
// f.SpeculativeNumberEqual(NumberOperationHint::kNumberOrOddball)},
|
|
//{"true", "undefined",
|
|
// f.SpeculativeNumberEqual(NumberOperationHint::kNumberOrOddball)},
|
|
//{"true", "true",
|
|
// f.SpeculativeNumberEqual(NumberOperationHint::kNumberOrOddball)},
|
|
{"true", "\"abc\"", f.JSEqual(CompareOperationHint::kAny)},
|
|
//{"undefined", "3",
|
|
// f.SpeculativeNumberEqual(NumberOperationHint::kNumberOrOddball)},
|
|
{"undefined", "null",
|
|
f.JSEqual(CompareOperationHint::kReceiverOrNullOrUndefined)},
|
|
{"undefined", "undefined",
|
|
f.JSEqual(CompareOperationHint::kReceiverOrNullOrUndefined)},
|
|
//{"undefined", "true",
|
|
// f.SpeculativeNumberEqual(NumberOperationHint::kNumberOrOddball)},
|
|
{"undefined", "\"abc\"", f.JSEqual(CompareOperationHint::kAny)},
|
|
{"{}", "3", f.JSEqual(CompareOperationHint::kAny)},
|
|
{"{}", "null",
|
|
f.JSEqual(CompareOperationHint::kReceiverOrNullOrUndefined)},
|
|
{"{}", "undefined",
|
|
f.JSEqual(CompareOperationHint::kReceiverOrNullOrUndefined)},
|
|
{"{}", "true", f.JSEqual(CompareOperationHint::kAny)},
|
|
{"{}", "\"abc\"", f.JSEqual(CompareOperationHint::kAny)},
|
|
|
|
{"3.14", "3",
|
|
f.OperatorChange(IrOpcode::kSpeculativeNumberEqual,
|
|
IrOpcode::kFloat64Equal)}};
|
|
|
|
for (const auto& c : cases) {
|
|
std::ostringstream src;
|
|
src << "function test(a, b) {\n"
|
|
<< " return %ObserveNode(a == b);\n"
|
|
<< "}\n"
|
|
<< "%PrepareFunctionForOptimization(test);\n";
|
|
for (const auto& args : c.warmup) {
|
|
src << "test(" << args.first << ", " << args.second << ");\n"
|
|
<< "%OptimizeFunctionOnNextCall(test);"
|
|
<< "test(" << args.first << ", " << args.second << ");\n";
|
|
}
|
|
|
|
{
|
|
compiler::ObserveNodeScope scope(i_isolate(), c.observer);
|
|
TryRunJS(src.str().c_str());
|
|
}
|
|
}
|
|
}
|
|
|
|
} // namespace compiler
|
|
} // namespace internal
|
|
} // namespace v8
|