Commit 25e0c83b authored by Leszek Swirski's avatar Leszek Swirski Committed by Commit Bot

Revert "[compiler] Hook in binary op builtins with feedback in generic lowering"

This reverts commit 8748613f.

Reason for revert: MSAN failures (https://ci.chromium.org/p/v8/builders/ci/V8%20Linux%20-%20arm64%20-%20sim%20-%20MSAN/32760?)

Original change's description:
> [compiler] Hook in binary op builtins with feedback in generic lowering
> 
> If --turbo-nci is enabled, use binary op builtins with feedback
> collection during generic lowering.
> 
> Bug: v8:8888
> Change-Id: I307dc742488982bdc68006be5bcd1da8e68768f5
> Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2228614
> Commit-Queue: Jakob Gruber <jgruber@chromium.org>
> Reviewed-by: Georg Neis <neis@chromium.org>
> Cr-Commit-Position: refs/heads/master@{#68227}

TBR=neis@chromium.org,jgruber@chromium.org

Change-Id: I635b1a5a28b25ce29e4f8bc23eb52841885b0cdf
No-Presubmit: true
No-Tree-Checks: true
No-Try: true
Bug: v8:8888
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2235535Reviewed-by: 's avatarLeszek Swirski <leszeks@chromium.org>
Commit-Queue: Leszek Swirski <leszeks@chromium.org>
Cr-Commit-Position: refs/heads/master@{#68229}
parent 19b4a6c4
...@@ -69,7 +69,6 @@ class BytecodeGraphBuilder { ...@@ -69,7 +69,6 @@ class BytecodeGraphBuilder {
// Helper function for creating a feedback source containing type feedback // Helper function for creating a feedback source containing type feedback
// vector and a feedback slot. // vector and a feedback slot.
FeedbackSource CreateFeedbackSource(int slot_id); FeedbackSource CreateFeedbackSource(int slot_id);
FeedbackSource CreateFeedbackSource(FeedbackSlot slot);
void set_environment(Environment* env) { environment_ = env; } void set_environment(Environment* env) { environment_ = env; }
const Environment* environment() const { return environment_; } const Environment* environment() const { return environment_; }
...@@ -244,6 +243,10 @@ class BytecodeGraphBuilder { ...@@ -244,6 +243,10 @@ class BytecodeGraphBuilder {
Environment* CheckContextExtensionAtDepth(Environment* slow_environment, Environment* CheckContextExtensionAtDepth(Environment* slow_environment,
uint32_t depth); uint32_t depth);
// Helper function to create binary operation hint from the recorded
// type feedback.
BinaryOperationHint GetBinaryOperationHint(int operand_index);
// Helper function to create for-in mode from the recorded type feedback. // Helper function to create for-in mode from the recorded type feedback.
ForInMode GetForInMode(int operand_index); ForInMode GetForInMode(int operand_index);
...@@ -1016,10 +1019,7 @@ Node* BytecodeGraphBuilder::BuildLoadNativeContextField(int index) { ...@@ -1016,10 +1019,7 @@ Node* BytecodeGraphBuilder::BuildLoadNativeContextField(int index) {
} }
FeedbackSource BytecodeGraphBuilder::CreateFeedbackSource(int slot_id) { FeedbackSource BytecodeGraphBuilder::CreateFeedbackSource(int slot_id) {
return CreateFeedbackSource(FeedbackVector::ToSlot(slot_id)); FeedbackSlot slot = FeedbackVector::ToSlot(slot_id);
}
FeedbackSource BytecodeGraphBuilder::CreateFeedbackSource(FeedbackSlot slot) {
return FeedbackSource(feedback_vector(), slot); return FeedbackSource(feedback_vector(), slot);
} }
...@@ -2749,6 +2749,15 @@ void BytecodeGraphBuilder::BuildBinaryOp(const Operator* op) { ...@@ -2749,6 +2749,15 @@ void BytecodeGraphBuilder::BuildBinaryOp(const Operator* op) {
environment()->BindAccumulator(node, Environment::kAttachFrameState); environment()->BindAccumulator(node, Environment::kAttachFrameState);
} }
// Helper function to create binary operation hint from the recorded type
// feedback.
BinaryOperationHint BytecodeGraphBuilder::GetBinaryOperationHint(
int operand_index) {
FeedbackSlot slot = bytecode_iterator().GetSlotOperand(operand_index);
FeedbackSource source(feedback_vector(), slot);
return broker()->GetFeedbackForBinaryOperation(source);
}
// Helper function to create for-in mode from the recorded type feedback. // Helper function to create for-in mode from the recorded type feedback.
ForInMode BytecodeGraphBuilder::GetForInMode(int operand_index) { ForInMode BytecodeGraphBuilder::GetForInMode(int operand_index) {
FeedbackSlot slot = bytecode_iterator().GetSlotOperand(operand_index); FeedbackSlot slot = bytecode_iterator().GetSlotOperand(operand_index);
...@@ -2789,98 +2798,73 @@ SpeculationMode BytecodeGraphBuilder::GetSpeculationMode(int slot_id) const { ...@@ -2789,98 +2798,73 @@ SpeculationMode BytecodeGraphBuilder::GetSpeculationMode(int slot_id) const {
void BytecodeGraphBuilder::VisitBitwiseNot() { void BytecodeGraphBuilder::VisitBitwiseNot() {
FeedbackSource feedback = CreateFeedbackSource( FeedbackSource feedback = CreateFeedbackSource(
bytecode_iterator().GetSlotOperand(kUnaryOperationHintIndex)); bytecode_iterator().GetSlotOperand(kUnaryOperationHintIndex).ToInt());
BuildUnaryOp(javascript()->BitwiseNot(feedback)); BuildUnaryOp(javascript()->BitwiseNot(feedback));
} }
void BytecodeGraphBuilder::VisitDec() { void BytecodeGraphBuilder::VisitDec() {
FeedbackSource feedback = CreateFeedbackSource( FeedbackSource feedback = CreateFeedbackSource(
bytecode_iterator().GetSlotOperand(kUnaryOperationHintIndex)); bytecode_iterator().GetSlotOperand(kUnaryOperationHintIndex).ToInt());
BuildUnaryOp(javascript()->Decrement(feedback)); BuildUnaryOp(javascript()->Decrement(feedback));
} }
void BytecodeGraphBuilder::VisitInc() { void BytecodeGraphBuilder::VisitInc() {
FeedbackSource feedback = CreateFeedbackSource( FeedbackSource feedback = CreateFeedbackSource(
bytecode_iterator().GetSlotOperand(kUnaryOperationHintIndex)); bytecode_iterator().GetSlotOperand(kUnaryOperationHintIndex).ToInt());
BuildUnaryOp(javascript()->Increment(feedback)); BuildUnaryOp(javascript()->Increment(feedback));
} }
void BytecodeGraphBuilder::VisitNegate() { void BytecodeGraphBuilder::VisitNegate() {
FeedbackSource feedback = CreateFeedbackSource( FeedbackSource feedback = CreateFeedbackSource(
bytecode_iterator().GetSlotOperand(kUnaryOperationHintIndex)); bytecode_iterator().GetSlotOperand(kUnaryOperationHintIndex).ToInt());
BuildUnaryOp(javascript()->Negate(feedback)); BuildUnaryOp(javascript()->Negate(feedback));
} }
void BytecodeGraphBuilder::VisitAdd() { void BytecodeGraphBuilder::VisitAdd() {
FeedbackSource feedback = CreateFeedbackSource( BuildBinaryOp(
bytecode_iterator().GetSlotOperand(kBinaryOperationHintIndex)); javascript()->Add(GetBinaryOperationHint(kBinaryOperationHintIndex)));
BuildBinaryOp(javascript()->Add(feedback));
} }
void BytecodeGraphBuilder::VisitSub() { void BytecodeGraphBuilder::VisitSub() {
FeedbackSource feedback = CreateFeedbackSource( BuildBinaryOp(javascript()->Subtract());
bytecode_iterator().GetSlotOperand(kBinaryOperationHintIndex));
BuildBinaryOp(javascript()->Subtract(feedback));
} }
void BytecodeGraphBuilder::VisitMul() { void BytecodeGraphBuilder::VisitMul() {
FeedbackSource feedback = CreateFeedbackSource( BuildBinaryOp(javascript()->Multiply());
bytecode_iterator().GetSlotOperand(kBinaryOperationHintIndex));
BuildBinaryOp(javascript()->Multiply(feedback));
} }
void BytecodeGraphBuilder::VisitDiv() { void BytecodeGraphBuilder::VisitDiv() { BuildBinaryOp(javascript()->Divide()); }
FeedbackSource feedback = CreateFeedbackSource(
bytecode_iterator().GetSlotOperand(kBinaryOperationHintIndex));
BuildBinaryOp(javascript()->Divide(feedback));
}
void BytecodeGraphBuilder::VisitMod() { void BytecodeGraphBuilder::VisitMod() {
FeedbackSource feedback = CreateFeedbackSource( BuildBinaryOp(javascript()->Modulus());
bytecode_iterator().GetSlotOperand(kBinaryOperationHintIndex));
BuildBinaryOp(javascript()->Modulus(feedback));
} }
void BytecodeGraphBuilder::VisitExp() { void BytecodeGraphBuilder::VisitExp() {
FeedbackSource feedback = CreateFeedbackSource( BuildBinaryOp(javascript()->Exponentiate());
bytecode_iterator().GetSlotOperand(kBinaryOperationHintIndex));
BuildBinaryOp(javascript()->Exponentiate(feedback));
} }
void BytecodeGraphBuilder::VisitBitwiseOr() { void BytecodeGraphBuilder::VisitBitwiseOr() {
FeedbackSource feedback = CreateFeedbackSource( BuildBinaryOp(javascript()->BitwiseOr());
bytecode_iterator().GetSlotOperand(kBinaryOperationHintIndex));
BuildBinaryOp(javascript()->BitwiseOr(feedback));
} }
void BytecodeGraphBuilder::VisitBitwiseXor() { void BytecodeGraphBuilder::VisitBitwiseXor() {
FeedbackSource feedback = CreateFeedbackSource( BuildBinaryOp(javascript()->BitwiseXor());
bytecode_iterator().GetSlotOperand(kBinaryOperationHintIndex));
BuildBinaryOp(javascript()->BitwiseXor(feedback));
} }
void BytecodeGraphBuilder::VisitBitwiseAnd() { void BytecodeGraphBuilder::VisitBitwiseAnd() {
FeedbackSource feedback = CreateFeedbackSource( BuildBinaryOp(javascript()->BitwiseAnd());
bytecode_iterator().GetSlotOperand(kBinaryOperationHintIndex));
BuildBinaryOp(javascript()->BitwiseAnd(feedback));
} }
void BytecodeGraphBuilder::VisitShiftLeft() { void BytecodeGraphBuilder::VisitShiftLeft() {
FeedbackSource feedback = CreateFeedbackSource( BuildBinaryOp(javascript()->ShiftLeft());
bytecode_iterator().GetSlotOperand(kBinaryOperationHintIndex));
BuildBinaryOp(javascript()->ShiftLeft(feedback));
} }
void BytecodeGraphBuilder::VisitShiftRight() { void BytecodeGraphBuilder::VisitShiftRight() {
FeedbackSource feedback = CreateFeedbackSource( BuildBinaryOp(javascript()->ShiftRight());
bytecode_iterator().GetSlotOperand(kBinaryOperationHintIndex));
BuildBinaryOp(javascript()->ShiftRight(feedback));
} }
void BytecodeGraphBuilder::VisitShiftRightLogical() { void BytecodeGraphBuilder::VisitShiftRightLogical() {
FeedbackSource feedback = CreateFeedbackSource( BuildBinaryOp(javascript()->ShiftRightLogical());
bytecode_iterator().GetSlotOperand(kBinaryOperationHintIndex));
BuildBinaryOp(javascript()->ShiftRightLogical(feedback));
} }
void BytecodeGraphBuilder::BuildBinaryOpWithImmediate(const Operator* op) { void BytecodeGraphBuilder::BuildBinaryOpWithImmediate(const Operator* op) {
...@@ -2905,75 +2889,52 @@ void BytecodeGraphBuilder::BuildBinaryOpWithImmediate(const Operator* op) { ...@@ -2905,75 +2889,52 @@ void BytecodeGraphBuilder::BuildBinaryOpWithImmediate(const Operator* op) {
} }
void BytecodeGraphBuilder::VisitAddSmi() { void BytecodeGraphBuilder::VisitAddSmi() {
FeedbackSource feedback = CreateFeedbackSource( BuildBinaryOpWithImmediate(
bytecode_iterator().GetSlotOperand(kBinaryOperationSmiHintIndex)); javascript()->Add(GetBinaryOperationHint(kBinaryOperationSmiHintIndex)));
BuildBinaryOpWithImmediate(javascript()->Add(feedback));
} }
void BytecodeGraphBuilder::VisitSubSmi() { void BytecodeGraphBuilder::VisitSubSmi() {
FeedbackSource feedback = CreateFeedbackSource( BuildBinaryOpWithImmediate(javascript()->Subtract());
bytecode_iterator().GetSlotOperand(kBinaryOperationSmiHintIndex));
BuildBinaryOpWithImmediate(javascript()->Subtract(feedback));
} }
void BytecodeGraphBuilder::VisitMulSmi() { void BytecodeGraphBuilder::VisitMulSmi() {
FeedbackSource feedback = CreateFeedbackSource( BuildBinaryOpWithImmediate(javascript()->Multiply());
bytecode_iterator().GetSlotOperand(kBinaryOperationSmiHintIndex));
BuildBinaryOpWithImmediate(javascript()->Multiply(feedback));
} }
void BytecodeGraphBuilder::VisitDivSmi() { void BytecodeGraphBuilder::VisitDivSmi() {
FeedbackSource feedback = CreateFeedbackSource( BuildBinaryOpWithImmediate(javascript()->Divide());
bytecode_iterator().GetSlotOperand(kBinaryOperationSmiHintIndex));
BuildBinaryOpWithImmediate(javascript()->Divide(feedback));
} }
void BytecodeGraphBuilder::VisitModSmi() { void BytecodeGraphBuilder::VisitModSmi() {
FeedbackSource feedback = CreateFeedbackSource( BuildBinaryOpWithImmediate(javascript()->Modulus());
bytecode_iterator().GetSlotOperand(kBinaryOperationSmiHintIndex));
BuildBinaryOpWithImmediate(javascript()->Modulus(feedback));
} }
void BytecodeGraphBuilder::VisitExpSmi() { void BytecodeGraphBuilder::VisitExpSmi() {
FeedbackSource feedback = CreateFeedbackSource( BuildBinaryOpWithImmediate(javascript()->Exponentiate());
bytecode_iterator().GetSlotOperand(kBinaryOperationSmiHintIndex));
BuildBinaryOpWithImmediate(javascript()->Exponentiate(feedback));
} }
void BytecodeGraphBuilder::VisitBitwiseOrSmi() { void BytecodeGraphBuilder::VisitBitwiseOrSmi() {
FeedbackSource feedback = CreateFeedbackSource( BuildBinaryOpWithImmediate(javascript()->BitwiseOr());
bytecode_iterator().GetSlotOperand(kBinaryOperationSmiHintIndex));
BuildBinaryOpWithImmediate(javascript()->BitwiseOr(feedback));
} }
void BytecodeGraphBuilder::VisitBitwiseXorSmi() { void BytecodeGraphBuilder::VisitBitwiseXorSmi() {
FeedbackSource feedback = CreateFeedbackSource( BuildBinaryOpWithImmediate(javascript()->BitwiseXor());
bytecode_iterator().GetSlotOperand(kBinaryOperationSmiHintIndex));
BuildBinaryOpWithImmediate(javascript()->BitwiseXor(feedback));
} }
void BytecodeGraphBuilder::VisitBitwiseAndSmi() { void BytecodeGraphBuilder::VisitBitwiseAndSmi() {
FeedbackSource feedback = CreateFeedbackSource( BuildBinaryOpWithImmediate(javascript()->BitwiseAnd());
bytecode_iterator().GetSlotOperand(kBinaryOperationSmiHintIndex));
BuildBinaryOpWithImmediate(javascript()->BitwiseAnd(feedback));
} }
void BytecodeGraphBuilder::VisitShiftLeftSmi() { void BytecodeGraphBuilder::VisitShiftLeftSmi() {
FeedbackSource feedback = CreateFeedbackSource( BuildBinaryOpWithImmediate(javascript()->ShiftLeft());
bytecode_iterator().GetSlotOperand(kBinaryOperationSmiHintIndex));
BuildBinaryOpWithImmediate(javascript()->ShiftLeft(feedback));
} }
void BytecodeGraphBuilder::VisitShiftRightSmi() { void BytecodeGraphBuilder::VisitShiftRightSmi() {
FeedbackSource feedback = CreateFeedbackSource( BuildBinaryOpWithImmediate(javascript()->ShiftRight());
bytecode_iterator().GetSlotOperand(kBinaryOperationSmiHintIndex));
BuildBinaryOpWithImmediate(javascript()->ShiftRight(feedback));
} }
void BytecodeGraphBuilder::VisitShiftRightLogicalSmi() { void BytecodeGraphBuilder::VisitShiftRightLogicalSmi() {
FeedbackSource feedback = CreateFeedbackSource( BuildBinaryOpWithImmediate(javascript()->ShiftRightLogical());
bytecode_iterator().GetSlotOperand(kBinaryOperationSmiHintIndex));
BuildBinaryOpWithImmediate(javascript()->ShiftRightLogical(feedback));
} }
void BytecodeGraphBuilder::VisitLogicalNot() { void BytecodeGraphBuilder::VisitLogicalNot() {
...@@ -3043,37 +3004,37 @@ void BytecodeGraphBuilder::BuildCompareOp(const Operator* op) { ...@@ -3043,37 +3004,37 @@ void BytecodeGraphBuilder::BuildCompareOp(const Operator* op) {
void BytecodeGraphBuilder::VisitTestEqual() { void BytecodeGraphBuilder::VisitTestEqual() {
FeedbackSource feedback = CreateFeedbackSource( FeedbackSource feedback = CreateFeedbackSource(
bytecode_iterator().GetSlotOperand(kCompareOperationHintIndex)); bytecode_iterator().GetSlotOperand(kCompareOperationHintIndex).ToInt());
BuildCompareOp(javascript()->Equal(feedback)); BuildCompareOp(javascript()->Equal(feedback));
} }
void BytecodeGraphBuilder::VisitTestEqualStrict() { void BytecodeGraphBuilder::VisitTestEqualStrict() {
FeedbackSource feedback = CreateFeedbackSource( FeedbackSource feedback = CreateFeedbackSource(
bytecode_iterator().GetSlotOperand(kCompareOperationHintIndex)); bytecode_iterator().GetSlotOperand(kCompareOperationHintIndex).ToInt());
BuildCompareOp(javascript()->StrictEqual(feedback)); BuildCompareOp(javascript()->StrictEqual(feedback));
} }
void BytecodeGraphBuilder::VisitTestLessThan() { void BytecodeGraphBuilder::VisitTestLessThan() {
FeedbackSource feedback = CreateFeedbackSource( FeedbackSource feedback = CreateFeedbackSource(
bytecode_iterator().GetSlotOperand(kCompareOperationHintIndex)); bytecode_iterator().GetSlotOperand(kCompareOperationHintIndex).ToInt());
BuildCompareOp(javascript()->LessThan(feedback)); BuildCompareOp(javascript()->LessThan(feedback));
} }
void BytecodeGraphBuilder::VisitTestGreaterThan() { void BytecodeGraphBuilder::VisitTestGreaterThan() {
FeedbackSource feedback = CreateFeedbackSource( FeedbackSource feedback = CreateFeedbackSource(
bytecode_iterator().GetSlotOperand(kCompareOperationHintIndex)); bytecode_iterator().GetSlotOperand(kCompareOperationHintIndex).ToInt());
BuildCompareOp(javascript()->GreaterThan(feedback)); BuildCompareOp(javascript()->GreaterThan(feedback));
} }
void BytecodeGraphBuilder::VisitTestLessThanOrEqual() { void BytecodeGraphBuilder::VisitTestLessThanOrEqual() {
FeedbackSource feedback = CreateFeedbackSource( FeedbackSource feedback = CreateFeedbackSource(
bytecode_iterator().GetSlotOperand(kCompareOperationHintIndex)); bytecode_iterator().GetSlotOperand(kCompareOperationHintIndex).ToInt());
BuildCompareOp(javascript()->LessThanOrEqual(feedback)); BuildCompareOp(javascript()->LessThanOrEqual(feedback));
} }
void BytecodeGraphBuilder::VisitTestGreaterThanOrEqual() { void BytecodeGraphBuilder::VisitTestGreaterThanOrEqual() {
FeedbackSource feedback = CreateFeedbackSource( FeedbackSource feedback = CreateFeedbackSource(
bytecode_iterator().GetSlotOperand(kCompareOperationHintIndex)); bytecode_iterator().GetSlotOperand(kCompareOperationHintIndex).ToInt());
BuildCompareOp(javascript()->GreaterThanOrEqual(feedback)); BuildCompareOp(javascript()->GreaterThanOrEqual(feedback));
} }
......
...@@ -61,6 +61,18 @@ Reduction JSGenericLowering::Reduce(Node* node) { ...@@ -61,6 +61,18 @@ Reduction JSGenericLowering::Reduce(Node* node) {
Callable callable = Builtins::CallableFor(isolate(), Builtins::k##Name); \ Callable callable = Builtins::CallableFor(isolate(), Builtins::k##Name); \
ReplaceWithStubCall(node, callable, flags); \ ReplaceWithStubCall(node, callable, flags); \
} }
REPLACE_STUB_CALL(Add)
REPLACE_STUB_CALL(Subtract)
REPLACE_STUB_CALL(Multiply)
REPLACE_STUB_CALL(Divide)
REPLACE_STUB_CALL(Modulus)
REPLACE_STUB_CALL(Exponentiate)
REPLACE_STUB_CALL(BitwiseAnd)
REPLACE_STUB_CALL(BitwiseOr)
REPLACE_STUB_CALL(BitwiseXor)
REPLACE_STUB_CALL(ShiftLeft)
REPLACE_STUB_CALL(ShiftRight)
REPLACE_STUB_CALL(ShiftRightLogical)
REPLACE_STUB_CALL(HasProperty) REPLACE_STUB_CALL(HasProperty)
REPLACE_STUB_CALL(ToLength) REPLACE_STUB_CALL(ToLength)
REPLACE_STUB_CALL(ToNumber) REPLACE_STUB_CALL(ToNumber)
...@@ -80,6 +92,8 @@ REPLACE_STUB_CALL(RejectPromise) ...@@ -80,6 +92,8 @@ REPLACE_STUB_CALL(RejectPromise)
REPLACE_STUB_CALL(ResolvePromise) REPLACE_STUB_CALL(ResolvePromise)
#undef REPLACE_STUB_CALL #undef REPLACE_STUB_CALL
// TODO(jgruber): Hook in binary and compare op builtins with feedback.
void JSGenericLowering::ReplaceWithStubCall(Node* node, void JSGenericLowering::ReplaceWithStubCall(Node* node,
Callable callable, Callable callable,
CallDescriptor::Flags flags) { CallDescriptor::Flags flags) {
...@@ -157,26 +171,14 @@ DEF_UNARY_LOWERING(Increment) ...@@ -157,26 +171,14 @@ DEF_UNARY_LOWERING(Increment)
DEF_UNARY_LOWERING(Negate) DEF_UNARY_LOWERING(Negate)
#undef DEF_UNARY_LOWERING #undef DEF_UNARY_LOWERING
void JSGenericLowering::ReplaceBinaryOrCompareOpWithBuiltinCall( void JSGenericLowering::ReplaceCompareOpWithBuiltinCall(
Node* node, Builtins::Name builtin_without_feedback, Node* node, Builtins::Name builtin_without_feedback,
Builtins::Name builtin_with_feedback) { Builtins::Name builtin_with_feedback) {
DCHECK(node->opcode() == IrOpcode::kJSAdd || DCHECK(node->opcode() == IrOpcode::kJSEqual ||
node->opcode() == IrOpcode::kJSBitwiseAnd ||
node->opcode() == IrOpcode::kJSBitwiseOr ||
node->opcode() == IrOpcode::kJSBitwiseXor ||
node->opcode() == IrOpcode::kJSDivide ||
node->opcode() == IrOpcode::kJSEqual ||
node->opcode() == IrOpcode::kJSExponentiate ||
node->opcode() == IrOpcode::kJSGreaterThan || node->opcode() == IrOpcode::kJSGreaterThan ||
node->opcode() == IrOpcode::kJSGreaterThanOrEqual || node->opcode() == IrOpcode::kJSGreaterThanOrEqual ||
node->opcode() == IrOpcode::kJSLessThan || node->opcode() == IrOpcode::kJSLessThan ||
node->opcode() == IrOpcode::kJSLessThanOrEqual || node->opcode() == IrOpcode::kJSLessThanOrEqual);
node->opcode() == IrOpcode::kJSModulus ||
node->opcode() == IrOpcode::kJSMultiply ||
node->opcode() == IrOpcode::kJSShiftLeft ||
node->opcode() == IrOpcode::kJSShiftRight ||
node->opcode() == IrOpcode::kJSShiftRightLogical ||
node->opcode() == IrOpcode::kJSSubtract);
Builtins::Name builtin_id; Builtins::Name builtin_id;
const FeedbackParameter& p = FeedbackParameterOf(node->op()); const FeedbackParameter& p = FeedbackParameterOf(node->op());
if (CollectFeedbackInGenericLowering() && p.feedback().IsValid()) { if (CollectFeedbackInGenericLowering() && p.feedback().IsValid()) {
...@@ -194,31 +196,17 @@ void JSGenericLowering::ReplaceBinaryOrCompareOpWithBuiltinCall( ...@@ -194,31 +196,17 @@ void JSGenericLowering::ReplaceBinaryOrCompareOpWithBuiltinCall(
ReplaceWithStubCall(node, callable, flags); ReplaceWithStubCall(node, callable, flags);
} }
#define DEF_BINARY_OR_COMPARE_LOWERING(Name) \ #define DEF_COMPARE_LOWERING(Name) \
void JSGenericLowering::LowerJS##Name(Node* node) { \ void JSGenericLowering::LowerJS##Name(Node* node) { \
ReplaceBinaryOrCompareOpWithBuiltinCall(node, Builtins::k##Name, \ ReplaceCompareOpWithBuiltinCall(node, Builtins::k##Name, \
Builtins::k##Name##_WithFeedback); \ Builtins::k##Name##_WithFeedback); \
} }
// Binary ops. DEF_COMPARE_LOWERING(Equal)
DEF_BINARY_OR_COMPARE_LOWERING(Add) DEF_COMPARE_LOWERING(GreaterThan)
DEF_BINARY_OR_COMPARE_LOWERING(BitwiseAnd) DEF_COMPARE_LOWERING(GreaterThanOrEqual)
DEF_BINARY_OR_COMPARE_LOWERING(BitwiseOr) DEF_COMPARE_LOWERING(LessThan)
DEF_BINARY_OR_COMPARE_LOWERING(BitwiseXor) DEF_COMPARE_LOWERING(LessThanOrEqual)
DEF_BINARY_OR_COMPARE_LOWERING(Divide) #undef DEF_COMPARE_LOWERING
DEF_BINARY_OR_COMPARE_LOWERING(Exponentiate)
DEF_BINARY_OR_COMPARE_LOWERING(Modulus)
DEF_BINARY_OR_COMPARE_LOWERING(Multiply)
DEF_BINARY_OR_COMPARE_LOWERING(ShiftLeft)
DEF_BINARY_OR_COMPARE_LOWERING(ShiftRight)
DEF_BINARY_OR_COMPARE_LOWERING(ShiftRightLogical)
DEF_BINARY_OR_COMPARE_LOWERING(Subtract)
// Compare ops.
DEF_BINARY_OR_COMPARE_LOWERING(Equal)
DEF_BINARY_OR_COMPARE_LOWERING(GreaterThan)
DEF_BINARY_OR_COMPARE_LOWERING(GreaterThanOrEqual)
DEF_BINARY_OR_COMPARE_LOWERING(LessThan)
DEF_BINARY_OR_COMPARE_LOWERING(LessThanOrEqual)
#undef DEF_BINARY_OR_COMPARE_LOWERING
void JSGenericLowering::LowerJSStrictEqual(Node* node) { void JSGenericLowering::LowerJSStrictEqual(Node* node) {
// The === operator doesn't need the current context. // The === operator doesn't need the current context.
......
...@@ -45,9 +45,9 @@ class JSGenericLowering final : public AdvancedReducer { ...@@ -45,9 +45,9 @@ class JSGenericLowering final : public AdvancedReducer {
void ReplaceUnaryOpWithBuiltinCall(Node* node, void ReplaceUnaryOpWithBuiltinCall(Node* node,
Builtins::Name builtin_without_feedback, Builtins::Name builtin_without_feedback,
Builtins::Name builtin_with_feedback); Builtins::Name builtin_with_feedback);
void ReplaceBinaryOrCompareOpWithBuiltinCall( void ReplaceCompareOpWithBuiltinCall(Node* node,
Node* node, Builtins::Name builtin_without_feedback, Builtins::Name builtin_without_feedback,
Builtins::Name builtin_with_feedback); Builtins::Name builtin_with_feedback);
Zone* zone() const; Zone* zone() const;
Isolate* isolate() const; Isolate* isolate() const;
......
...@@ -85,38 +85,16 @@ Reduction JSHeapCopyReducer::Reduce(Node* node) { ...@@ -85,38 +85,16 @@ Reduction JSHeapCopyReducer::Reduce(Node* node) {
} }
break; break;
} }
/* Unary ops. */
case IrOpcode::kJSBitwiseNot: case IrOpcode::kJSBitwiseNot:
case IrOpcode::kJSDecrement: case IrOpcode::kJSDecrement:
case IrOpcode::kJSIncrement: case IrOpcode::kJSIncrement:
case IrOpcode::kJSNegate: { case IrOpcode::kJSNegate: {
FeedbackParameter const& p = FeedbackParameterOf(node->op()); FeedbackParameter const& p = FeedbackParameterOf(node->op());
if (p.feedback().IsValid()) { if (p.feedback().IsValid()) {
// Unary ops are treated as binary ops with respect to feedback.
broker()->ProcessFeedbackForBinaryOperation(p.feedback()); broker()->ProcessFeedbackForBinaryOperation(p.feedback());
} }
break; break;
} }
/* Binary ops. */
case IrOpcode::kJSAdd:
case IrOpcode::kJSSubtract:
case IrOpcode::kJSMultiply:
case IrOpcode::kJSDivide:
case IrOpcode::kJSModulus:
case IrOpcode::kJSExponentiate:
case IrOpcode::kJSBitwiseOr:
case IrOpcode::kJSBitwiseXor:
case IrOpcode::kJSBitwiseAnd:
case IrOpcode::kJSShiftLeft:
case IrOpcode::kJSShiftRight:
case IrOpcode::kJSShiftRightLogical: {
FeedbackParameter const& p = FeedbackParameterOf(node->op());
if (p.feedback().IsValid()) {
broker()->ProcessFeedbackForBinaryOperation(p.feedback());
}
break;
}
/* Compare ops. */
case IrOpcode::kJSEqual: case IrOpcode::kJSEqual:
case IrOpcode::kJSGreaterThan: case IrOpcode::kJSGreaterThan:
case IrOpcode::kJSGreaterThanOrEqual: case IrOpcode::kJSGreaterThanOrEqual:
......
...@@ -225,46 +225,21 @@ std::ostream& operator<<(std::ostream& os, FeedbackParameter const& p) { ...@@ -225,46 +225,21 @@ std::ostream& operator<<(std::ostream& os, FeedbackParameter const& p) {
return os << p.feedback(); return os << p.feedback();
} }
#define UNARY_OP_LIST(V) \
V(BitwiseNot) \
V(Decrement) \
V(Increment) \
V(Negate)
#define BINARY_OP_LIST(V) \
V(Add) \
V(Subtract) \
V(Multiply) \
V(Divide) \
V(Modulus) \
V(Exponentiate) \
V(BitwiseOr) \
V(BitwiseXor) \
V(BitwiseAnd) \
V(ShiftLeft) \
V(ShiftRight) \
V(ShiftRightLogical)
#define COMPARE_OP_LIST(V) \
V(Equal, Operator::kNoProperties) \
V(StrictEqual, Operator::kPure) \
V(LessThan, Operator::kNoProperties) \
V(GreaterThan, Operator::kNoProperties) \
V(LessThanOrEqual, Operator::kNoProperties) \
V(GreaterThanOrEqual, Operator::kNoProperties)
FeedbackParameter const& FeedbackParameterOf(const Operator* op) { FeedbackParameter const& FeedbackParameterOf(const Operator* op) {
#define V(Name, ...) op->opcode() == IrOpcode::kJS##Name || DCHECK(op->opcode() == IrOpcode::kJSBitwiseNot ||
// clang-format off
DCHECK(UNARY_OP_LIST(V)
BINARY_OP_LIST(V)
COMPARE_OP_LIST(V)
op->opcode() == IrOpcode::kJSCreateEmptyLiteralArray || op->opcode() == IrOpcode::kJSCreateEmptyLiteralArray ||
op->opcode() == IrOpcode::kJSDecrement ||
op->opcode() == IrOpcode::kJSEqual ||
op->opcode() == IrOpcode::kJSGreaterThan ||
op->opcode() == IrOpcode::kJSGreaterThanOrEqual ||
op->opcode() == IrOpcode::kJSIncrement ||
op->opcode() == IrOpcode::kJSInstanceOf || op->opcode() == IrOpcode::kJSInstanceOf ||
op->opcode() == IrOpcode::kJSLessThan ||
op->opcode() == IrOpcode::kJSLessThanOrEqual ||
op->opcode() == IrOpcode::kJSNegate ||
op->opcode() == IrOpcode::kJSStoreDataPropertyInLiteral || op->opcode() == IrOpcode::kJSStoreDataPropertyInLiteral ||
op->opcode() == IrOpcode::kJSStoreInArrayLiteral); op->opcode() == IrOpcode::kJSStoreInArrayLiteral ||
// clang-format on op->opcode() == IrOpcode::kJSStrictEqual);
#undef V
return OpParameter<FeedbackParameter>(op); return OpParameter<FeedbackParameter>(op);
} }
...@@ -673,6 +648,17 @@ BinaryOperationHint BinaryOperationHintOf(const Operator* op) { ...@@ -673,6 +648,17 @@ BinaryOperationHint BinaryOperationHintOf(const Operator* op) {
} }
#define CACHED_OP_LIST(V) \ #define CACHED_OP_LIST(V) \
V(BitwiseOr, Operator::kNoProperties, 2, 1) \
V(BitwiseXor, Operator::kNoProperties, 2, 1) \
V(BitwiseAnd, Operator::kNoProperties, 2, 1) \
V(ShiftLeft, Operator::kNoProperties, 2, 1) \
V(ShiftRight, Operator::kNoProperties, 2, 1) \
V(ShiftRightLogical, Operator::kNoProperties, 2, 1) \
V(Subtract, Operator::kNoProperties, 2, 1) \
V(Multiply, Operator::kNoProperties, 2, 1) \
V(Divide, Operator::kNoProperties, 2, 1) \
V(Modulus, Operator::kNoProperties, 2, 1) \
V(Exponentiate, Operator::kNoProperties, 2, 1) \
V(ToLength, Operator::kNoProperties, 1, 1) \ V(ToLength, Operator::kNoProperties, 1, 1) \
V(ToName, Operator::kNoProperties, 1, 1) \ V(ToName, Operator::kNoProperties, 1, 1) \
V(ToNumber, Operator::kNoProperties, 1, 1) \ V(ToNumber, Operator::kNoProperties, 1, 1) \
...@@ -709,6 +695,22 @@ BinaryOperationHint BinaryOperationHintOf(const Operator* op) { ...@@ -709,6 +695,22 @@ BinaryOperationHint BinaryOperationHintOf(const Operator* op) {
V(ParseInt, Operator::kNoProperties, 2, 1) \ V(ParseInt, Operator::kNoProperties, 2, 1) \
V(RegExpTest, Operator::kNoProperties, 2, 1) V(RegExpTest, Operator::kNoProperties, 2, 1)
#define UNARY_OP_LIST(V) \
V(BitwiseNot) \
V(Decrement) \
V(Increment) \
V(Negate)
#define BINARY_OP_LIST(V) V(Add)
#define COMPARE_OP_LIST(V) \
V(Equal, Operator::kNoProperties) \
V(GreaterThan, Operator::kNoProperties) \
V(GreaterThanOrEqual, Operator::kNoProperties) \
V(LessThan, Operator::kNoProperties) \
V(LessThanOrEqual, Operator::kNoProperties) \
V(StrictEqual, Operator::kPure)
struct JSOperatorGlobalCache final { struct JSOperatorGlobalCache final {
#define CACHED_OP(Name, properties, value_input_count, value_output_count) \ #define CACHED_OP(Name, properties, value_input_count, value_output_count) \
struct Name##Operator final : public Operator { \ struct Name##Operator final : public Operator { \
...@@ -722,6 +724,29 @@ struct JSOperatorGlobalCache final { ...@@ -722,6 +724,29 @@ struct JSOperatorGlobalCache final {
Name##Operator k##Name##Operator; Name##Operator k##Name##Operator;
CACHED_OP_LIST(CACHED_OP) CACHED_OP_LIST(CACHED_OP)
#undef CACHED_OP #undef CACHED_OP
#define BINARY_OP(Name) \
template <BinaryOperationHint kHint> \
struct Name##Operator final : public Operator1<BinaryOperationHint> { \
Name##Operator() \
: Operator1<BinaryOperationHint>(IrOpcode::kJS##Name, \
Operator::kNoProperties, "JS" #Name, \
2, 1, 1, 1, 1, 2, kHint) {} \
}; \
Name##Operator<BinaryOperationHint::kNone> k##Name##NoneOperator; \
Name##Operator<BinaryOperationHint::kSignedSmall> \
k##Name##SignedSmallOperator; \
Name##Operator<BinaryOperationHint::kSignedSmallInputs> \
k##Name##SignedSmallInputsOperator; \
Name##Operator<BinaryOperationHint::kSigned32> k##Name##Signed32Operator; \
Name##Operator<BinaryOperationHint::kNumber> k##Name##NumberOperator; \
Name##Operator<BinaryOperationHint::kNumberOrOddball> \
k##Name##NumberOrOddballOperator; \
Name##Operator<BinaryOperationHint::kString> k##Name##StringOperator; \
Name##Operator<BinaryOperationHint::kBigInt> k##Name##BigIntOperator; \
Name##Operator<BinaryOperationHint::kAny> k##Name##AnyOperator;
BINARY_OP_LIST(BINARY_OP)
#undef BINARY_OP
}; };
namespace { namespace {
...@@ -738,6 +763,34 @@ JSOperatorBuilder::JSOperatorBuilder(Zone* zone) ...@@ -738,6 +763,34 @@ JSOperatorBuilder::JSOperatorBuilder(Zone* zone)
CACHED_OP_LIST(CACHED_OP) CACHED_OP_LIST(CACHED_OP)
#undef CACHED_OP #undef CACHED_OP
#define BINARY_OP(Name) \
const Operator* JSOperatorBuilder::Name(BinaryOperationHint hint) { \
switch (hint) { \
case BinaryOperationHint::kNone: \
return &cache_.k##Name##NoneOperator; \
case BinaryOperationHint::kSignedSmall: \
return &cache_.k##Name##SignedSmallOperator; \
case BinaryOperationHint::kSignedSmallInputs: \
return &cache_.k##Name##SignedSmallInputsOperator; \
case BinaryOperationHint::kSigned32: \
return &cache_.k##Name##Signed32Operator; \
case BinaryOperationHint::kNumber: \
return &cache_.k##Name##NumberOperator; \
case BinaryOperationHint::kNumberOrOddball: \
return &cache_.k##Name##NumberOrOddballOperator; \
case BinaryOperationHint::kString: \
return &cache_.k##Name##StringOperator; \
case BinaryOperationHint::kBigInt: \
return &cache_.k##Name##BigIntOperator; \
case BinaryOperationHint::kAny: \
return &cache_.k##Name##AnyOperator; \
} \
UNREACHABLE(); \
return nullptr; \
}
BINARY_OP_LIST(BINARY_OP)
#undef BINARY_OP
#define UNARY_OP(Name) \ #define UNARY_OP(Name) \
const Operator* JSOperatorBuilder::Name(FeedbackSource const& feedback) { \ const Operator* JSOperatorBuilder::Name(FeedbackSource const& feedback) { \
FeedbackParameter parameters(feedback); \ FeedbackParameter parameters(feedback); \
...@@ -748,16 +801,6 @@ CACHED_OP_LIST(CACHED_OP) ...@@ -748,16 +801,6 @@ CACHED_OP_LIST(CACHED_OP)
UNARY_OP_LIST(UNARY_OP) UNARY_OP_LIST(UNARY_OP)
#undef UNARY_OP #undef UNARY_OP
#define BINARY_OP(Name) \
const Operator* JSOperatorBuilder::Name(FeedbackSource const& feedback) { \
FeedbackParameter parameters(feedback); \
return new (zone()) Operator1<FeedbackParameter>( \
IrOpcode::kJS##Name, Operator::kNoProperties, "JS" #Name, 2, 1, 1, 1, \
1, 2, parameters); \
}
BINARY_OP_LIST(BINARY_OP)
#undef BINARY_OP
#define COMPARE_OP(Name, Properties) \ #define COMPARE_OP(Name, Properties) \
const Operator* JSOperatorBuilder::Name(FeedbackSource const& feedback) { \ const Operator* JSOperatorBuilder::Name(FeedbackSource const& feedback) { \
FeedbackParameter parameters(feedback); \ FeedbackParameter parameters(feedback); \
......
...@@ -784,18 +784,18 @@ class V8_EXPORT_PRIVATE JSOperatorBuilder final ...@@ -784,18 +784,18 @@ class V8_EXPORT_PRIVATE JSOperatorBuilder final
const Operator* LessThanOrEqual(FeedbackSource const& feedback); const Operator* LessThanOrEqual(FeedbackSource const& feedback);
const Operator* GreaterThanOrEqual(FeedbackSource const& feedback); const Operator* GreaterThanOrEqual(FeedbackSource const& feedback);
const Operator* BitwiseOr(FeedbackSource const& feedback); const Operator* BitwiseOr();
const Operator* BitwiseXor(FeedbackSource const& feedback); const Operator* BitwiseXor();
const Operator* BitwiseAnd(FeedbackSource const& feedback); const Operator* BitwiseAnd();
const Operator* ShiftLeft(FeedbackSource const& feedback); const Operator* ShiftLeft();
const Operator* ShiftRight(FeedbackSource const& feedback); const Operator* ShiftRight();
const Operator* ShiftRightLogical(FeedbackSource const& feedback); const Operator* ShiftRightLogical();
const Operator* Add(FeedbackSource const& feedback); const Operator* Add(BinaryOperationHint hint);
const Operator* Subtract(FeedbackSource const& feedback); const Operator* Subtract();
const Operator* Multiply(FeedbackSource const& feedback); const Operator* Multiply();
const Operator* Divide(FeedbackSource const& feedback); const Operator* Divide();
const Operator* Modulus(FeedbackSource const& feedback); const Operator* Modulus();
const Operator* Exponentiate(FeedbackSource const& feedback); const Operator* Exponentiate();
const Operator* BitwiseNot(FeedbackSource const& feedback); const Operator* BitwiseNot(FeedbackSource const& feedback);
const Operator* Decrement(FeedbackSource const& feedback); const Operator* Decrement(FeedbackSource const& feedback);
......
...@@ -285,33 +285,31 @@ JSTypeHintLowering::LoweringResult JSTypeHintLowering::ReduceUnaryOperation( ...@@ -285,33 +285,31 @@ JSTypeHintLowering::LoweringResult JSTypeHintLowering::ReduceUnaryOperation(
return LoweringResult::Exit(node); return LoweringResult::Exit(node);
} }
// Note: Unary and binary operations collect the same kind of feedback.
FeedbackSource feedback(feedback_vector(), slot);
Node* node; Node* node;
switch (op->opcode()) { switch (op->opcode()) {
case IrOpcode::kJSBitwiseNot: { case IrOpcode::kJSBitwiseNot: {
// Lower to a speculative xor with -1 if we have some kind of Number // Lower to a speculative xor with -1 if we have some kind of Number
// feedback. // feedback.
JSSpeculativeBinopBuilder b( JSSpeculativeBinopBuilder b(this, jsgraph()->javascript()->BitwiseXor(),
this, jsgraph()->javascript()->BitwiseXor(feedback), operand, operand, jsgraph()->SmiConstant(-1), effect,
jsgraph()->SmiConstant(-1), effect, control, slot); control, slot);
node = b.TryBuildNumberBinop(); node = b.TryBuildNumberBinop();
break; break;
} }
case IrOpcode::kJSDecrement: { case IrOpcode::kJSDecrement: {
// Lower to a speculative subtraction of 1 if we have some kind of Number // Lower to a speculative subtraction of 1 if we have some kind of Number
// feedback. // feedback.
JSSpeculativeBinopBuilder b( JSSpeculativeBinopBuilder b(this, jsgraph()->javascript()->Subtract(),
this, jsgraph()->javascript()->Subtract(feedback), operand, operand, jsgraph()->SmiConstant(1), effect,
jsgraph()->SmiConstant(1), effect, control, slot); control, slot);
node = b.TryBuildNumberBinop(); node = b.TryBuildNumberBinop();
break; break;
} }
case IrOpcode::kJSIncrement: { case IrOpcode::kJSIncrement: {
// Lower to a speculative addition of 1 if we have some kind of Number // Lower to a speculative addition of 1 if we have some kind of Number
// feedback. // feedback.
JSSpeculativeBinopBuilder b(this, jsgraph()->javascript()->Add(feedback), BinaryOperationHint hint = BinaryOperationHint::kAny; // Dummy.
JSSpeculativeBinopBuilder b(this, jsgraph()->javascript()->Add(hint),
operand, jsgraph()->SmiConstant(1), effect, operand, jsgraph()->SmiConstant(1), effect,
control, slot); control, slot);
node = b.TryBuildNumberBinop(); node = b.TryBuildNumberBinop();
...@@ -320,9 +318,9 @@ JSTypeHintLowering::LoweringResult JSTypeHintLowering::ReduceUnaryOperation( ...@@ -320,9 +318,9 @@ JSTypeHintLowering::LoweringResult JSTypeHintLowering::ReduceUnaryOperation(
case IrOpcode::kJSNegate: { case IrOpcode::kJSNegate: {
// Lower to a speculative multiplication with -1 if we have some kind of // Lower to a speculative multiplication with -1 if we have some kind of
// Number feedback. // Number feedback.
JSSpeculativeBinopBuilder b( JSSpeculativeBinopBuilder b(this, jsgraph()->javascript()->Multiply(),
this, jsgraph()->javascript()->Multiply(feedback), operand, operand, jsgraph()->SmiConstant(-1), effect,
jsgraph()->SmiConstant(-1), effect, control, slot); control, slot);
node = b.TryBuildNumberBinop(); node = b.TryBuildNumberBinop();
if (!node) { if (!node) {
if (GetBinaryOperationHint(slot) == BinaryOperationHint::kBigInt) { if (GetBinaryOperationHint(slot) == BinaryOperationHint::kBigInt) {
......
...@@ -449,9 +449,8 @@ Reduction JSTypedLowering::ReduceJSBitwiseNot(Node* node) { ...@@ -449,9 +449,8 @@ Reduction JSTypedLowering::ReduceJSBitwiseNot(Node* node) {
Type input_type = NodeProperties::GetType(input); Type input_type = NodeProperties::GetType(input);
if (input_type.Is(Type::PlainPrimitive())) { if (input_type.Is(Type::PlainPrimitive())) {
// JSBitwiseNot(x) => NumberBitwiseXor(ToInt32(x), -1) // JSBitwiseNot(x) => NumberBitwiseXor(ToInt32(x), -1)
const FeedbackParameter& p = FeedbackParameterOf(node->op());
node->InsertInput(graph()->zone(), 1, jsgraph()->SmiConstant(-1)); node->InsertInput(graph()->zone(), 1, jsgraph()->SmiConstant(-1));
NodeProperties::ChangeOp(node, javascript()->BitwiseXor(p.feedback())); NodeProperties::ChangeOp(node, javascript()->BitwiseXor());
JSBinopReduction r(this, node); JSBinopReduction r(this, node);
r.ConvertInputsToNumber(); r.ConvertInputsToNumber();
r.ConvertInputsToUI32(kSigned, kSigned); r.ConvertInputsToUI32(kSigned, kSigned);
...@@ -465,9 +464,8 @@ Reduction JSTypedLowering::ReduceJSDecrement(Node* node) { ...@@ -465,9 +464,8 @@ Reduction JSTypedLowering::ReduceJSDecrement(Node* node) {
Type input_type = NodeProperties::GetType(input); Type input_type = NodeProperties::GetType(input);
if (input_type.Is(Type::PlainPrimitive())) { if (input_type.Is(Type::PlainPrimitive())) {
// JSDecrement(x) => NumberSubtract(ToNumber(x), 1) // JSDecrement(x) => NumberSubtract(ToNumber(x), 1)
const FeedbackParameter& p = FeedbackParameterOf(node->op());
node->InsertInput(graph()->zone(), 1, jsgraph()->OneConstant()); node->InsertInput(graph()->zone(), 1, jsgraph()->OneConstant());
NodeProperties::ChangeOp(node, javascript()->Subtract(p.feedback())); NodeProperties::ChangeOp(node, javascript()->Subtract());
JSBinopReduction r(this, node); JSBinopReduction r(this, node);
r.ConvertInputsToNumber(); r.ConvertInputsToNumber();
DCHECK_EQ(simplified()->NumberSubtract(), r.NumberOp()); DCHECK_EQ(simplified()->NumberSubtract(), r.NumberOp());
...@@ -481,9 +479,9 @@ Reduction JSTypedLowering::ReduceJSIncrement(Node* node) { ...@@ -481,9 +479,9 @@ Reduction JSTypedLowering::ReduceJSIncrement(Node* node) {
Type input_type = NodeProperties::GetType(input); Type input_type = NodeProperties::GetType(input);
if (input_type.Is(Type::PlainPrimitive())) { if (input_type.Is(Type::PlainPrimitive())) {
// JSIncrement(x) => NumberAdd(ToNumber(x), 1) // JSIncrement(x) => NumberAdd(ToNumber(x), 1)
const FeedbackParameter& p = FeedbackParameterOf(node->op());
node->InsertInput(graph()->zone(), 1, jsgraph()->OneConstant()); node->InsertInput(graph()->zone(), 1, jsgraph()->OneConstant());
NodeProperties::ChangeOp(node, javascript()->Add(p.feedback())); BinaryOperationHint hint = BinaryOperationHint::kAny; // Dummy.
NodeProperties::ChangeOp(node, javascript()->Add(hint));
JSBinopReduction r(this, node); JSBinopReduction r(this, node);
r.ConvertInputsToNumber(); r.ConvertInputsToNumber();
DCHECK_EQ(simplified()->NumberAdd(), r.NumberOp()); DCHECK_EQ(simplified()->NumberAdd(), r.NumberOp());
...@@ -497,9 +495,8 @@ Reduction JSTypedLowering::ReduceJSNegate(Node* node) { ...@@ -497,9 +495,8 @@ Reduction JSTypedLowering::ReduceJSNegate(Node* node) {
Type input_type = NodeProperties::GetType(input); Type input_type = NodeProperties::GetType(input);
if (input_type.Is(Type::PlainPrimitive())) { if (input_type.Is(Type::PlainPrimitive())) {
// JSNegate(x) => NumberMultiply(ToNumber(x), -1) // JSNegate(x) => NumberMultiply(ToNumber(x), -1)
const FeedbackParameter& p = FeedbackParameterOf(node->op());
node->InsertInput(graph()->zone(), 1, jsgraph()->SmiConstant(-1)); node->InsertInput(graph()->zone(), 1, jsgraph()->SmiConstant(-1));
NodeProperties::ChangeOp(node, javascript()->Multiply(p.feedback())); NodeProperties::ChangeOp(node, javascript()->Multiply());
JSBinopReduction r(this, node); JSBinopReduction r(this, node);
r.ConvertInputsToNumber(); r.ConvertInputsToNumber();
return r.ChangeToPureOperator(r.NumberOp(), Type::Number()); return r.ChangeToPureOperator(r.NumberOp(), Type::Number());
......
...@@ -324,11 +324,13 @@ Handle<FeedbackVector> FeedbackVector::New( ...@@ -324,11 +324,13 @@ Handle<FeedbackVector> FeedbackVector::New(
return result; return result;
} }
namespace { // static
Handle<FeedbackVector> FeedbackVector::NewWithOneCompareSlotForTesting(
Zone* zone, Isolate* isolate) {
FeedbackVectorSpec one_slot(zone);
one_slot.AddCompareICSlot();
Handle<FeedbackVector> NewFeedbackVectorForTesting( Handle<FeedbackMetadata> metadata = FeedbackMetadata::New(isolate, &one_slot);
Isolate* isolate, const FeedbackVectorSpec* spec) {
Handle<FeedbackMetadata> metadata = FeedbackMetadata::New(isolate, spec);
Handle<SharedFunctionInfo> shared = Handle<SharedFunctionInfo> shared =
isolate->factory()->NewSharedFunctionInfoForBuiltin( isolate->factory()->NewSharedFunctionInfoForBuiltin(
isolate->factory()->empty_string(), Builtins::kIllegal); isolate->factory()->empty_string(), Builtins::kIllegal);
...@@ -343,24 +345,6 @@ Handle<FeedbackVector> NewFeedbackVectorForTesting( ...@@ -343,24 +345,6 @@ Handle<FeedbackVector> NewFeedbackVectorForTesting(
&is_compiled_scope); &is_compiled_scope);
} }
} // namespace
// static
Handle<FeedbackVector> FeedbackVector::NewWithOneBinarySlotForTesting(
Zone* zone, Isolate* isolate) {
FeedbackVectorSpec one_slot(zone);
one_slot.AddBinaryOpICSlot();
return NewFeedbackVectorForTesting(isolate, &one_slot);
}
// static
Handle<FeedbackVector> FeedbackVector::NewWithOneCompareSlotForTesting(
Zone* zone, Isolate* isolate) {
FeedbackVectorSpec one_slot(zone);
one_slot.AddCompareICSlot();
return NewFeedbackVectorForTesting(isolate, &one_slot);
}
// static // static
void FeedbackVector::AddToVectorsForProfilingTools( void FeedbackVector::AddToVectorsForProfilingTools(
Isolate* isolate, Handle<FeedbackVector> vector) { Isolate* isolate, Handle<FeedbackVector> vector) {
......
...@@ -265,8 +265,6 @@ class FeedbackVector : public HeapObject { ...@@ -265,8 +265,6 @@ class FeedbackVector : public HeapObject {
Handle<ClosureFeedbackCellArray> closure_feedback_cell_array, Handle<ClosureFeedbackCellArray> closure_feedback_cell_array,
IsCompiledScope* is_compiled_scope); IsCompiledScope* is_compiled_scope);
V8_EXPORT_PRIVATE static Handle<FeedbackVector>
NewWithOneBinarySlotForTesting(Zone* zone, Isolate* isolate);
V8_EXPORT_PRIVATE static Handle<FeedbackVector> V8_EXPORT_PRIVATE static Handle<FeedbackVector>
NewWithOneCompareSlotForTesting(Zone* zone, Isolate* isolate); NewWithOneCompareSlotForTesting(Zone* zone, Isolate* isolate);
......
...@@ -55,6 +55,7 @@ class JSTypedLoweringTester : public HandleAndZoneScope { ...@@ -55,6 +55,7 @@ class JSTypedLoweringTester : public HandleAndZoneScope {
Graph graph; Graph graph;
Typer typer; Typer typer;
Node* context_node; Node* context_node;
BinaryOperationHint const binop_hints = BinaryOperationHint::kAny;
Node* Parameter(Type t, int32_t index = 0) { Node* Parameter(Type t, int32_t index = 0) {
Node* n = graph.NewNode(common.Parameter(index), graph.start()); Node* n = graph.NewNode(common.Parameter(index), graph.start());
...@@ -217,21 +218,6 @@ static IrOpcode::Value NumberToI32(bool is_signed) { ...@@ -217,21 +218,6 @@ static IrOpcode::Value NumberToI32(bool is_signed) {
return is_signed ? IrOpcode::kNumberToInt32 : IrOpcode::kNumberToUint32; return is_signed ? IrOpcode::kNumberToInt32 : IrOpcode::kNumberToUint32;
} }
namespace {
FeedbackSource FeedbackSourceWithOneBinarySlot(JSTypedLoweringTester* R) {
return FeedbackSource{FeedbackVector::NewWithOneBinarySlotForTesting(
R->main_zone(), R->main_isolate()),
FeedbackSlot{0}};
}
FeedbackSource FeedbackSourceWithOneCompareSlot(JSTypedLoweringTester* R) {
return FeedbackSource{FeedbackVector::NewWithOneCompareSlotForTesting(
R->main_zone(), R->main_isolate()),
FeedbackSlot{0}};
}
} // namespace
TEST(StringBinops) { TEST(StringBinops) {
JSTypedLoweringTester R; JSTypedLoweringTester R;
...@@ -242,8 +228,7 @@ TEST(StringBinops) { ...@@ -242,8 +228,7 @@ TEST(StringBinops) {
for (size_t j = 0; j < arraysize(kStringTypes); ++j) { for (size_t j = 0; j < arraysize(kStringTypes); ++j) {
Node* p1 = R.Parameter(kStringTypes[j], 1); Node* p1 = R.Parameter(kStringTypes[j], 1);
Node* add = R.Binop(R.javascript.Add(FeedbackSourceWithOneBinarySlot(&R)), Node* add = R.Binop(R.javascript.Add(BinaryOperationHint::kAny), p0, p1);
p0, p1);
Node* r = R.reduce(add); Node* r = R.reduce(add);
R.CheckBinop(IrOpcode::kStringConcat, r); R.CheckBinop(IrOpcode::kStringConcat, r);
...@@ -258,8 +243,7 @@ TEST(AddNumber1) { ...@@ -258,8 +243,7 @@ TEST(AddNumber1) {
for (size_t i = 0; i < arraysize(kNumberTypes); ++i) { for (size_t i = 0; i < arraysize(kNumberTypes); ++i) {
Node* p0 = R.Parameter(kNumberTypes[i], 0); Node* p0 = R.Parameter(kNumberTypes[i], 0);
Node* p1 = R.Parameter(kNumberTypes[i], 1); Node* p1 = R.Parameter(kNumberTypes[i], 1);
Node* add = Node* add = R.Binop(R.javascript.Add(BinaryOperationHint::kAny), p0, p1);
R.Binop(R.javascript.Add(FeedbackSourceWithOneBinarySlot(&R)), p0, p1);
Node* r = R.reduce(add); Node* r = R.reduce(add);
R.CheckBinop(IrOpcode::kNumberAdd, r); R.CheckBinop(IrOpcode::kNumberAdd, r);
...@@ -270,13 +254,12 @@ TEST(AddNumber1) { ...@@ -270,13 +254,12 @@ TEST(AddNumber1) {
TEST(NumberBinops) { TEST(NumberBinops) {
JSTypedLoweringTester R; JSTypedLoweringTester R;
FeedbackSource feedback_source = FeedbackSourceWithOneBinarySlot(&R);
const Operator* ops[] = { const Operator* ops[] = {
R.javascript.Add(feedback_source), R.simplified.NumberAdd(), R.javascript.Add(R.binop_hints), R.simplified.NumberAdd(),
R.javascript.Subtract(feedback_source), R.simplified.NumberSubtract(), R.javascript.Subtract(), R.simplified.NumberSubtract(),
R.javascript.Multiply(feedback_source), R.simplified.NumberMultiply(), R.javascript.Multiply(), R.simplified.NumberMultiply(),
R.javascript.Divide(feedback_source), R.simplified.NumberDivide(), R.javascript.Divide(), R.simplified.NumberDivide(),
R.javascript.Modulus(feedback_source), R.simplified.NumberModulus(), R.javascript.Modulus(), R.simplified.NumberModulus(),
}; };
for (size_t i = 0; i < arraysize(kNumberTypes); ++i) { for (size_t i = 0; i < arraysize(kNumberTypes); ++i) {
...@@ -318,12 +301,11 @@ class JSBitwiseShiftTypedLoweringTester : public JSTypedLoweringTester { ...@@ -318,12 +301,11 @@ class JSBitwiseShiftTypedLoweringTester : public JSTypedLoweringTester {
public: public:
JSBitwiseShiftTypedLoweringTester() : JSTypedLoweringTester() { JSBitwiseShiftTypedLoweringTester() : JSTypedLoweringTester() {
int i = 0; int i = 0;
FeedbackSource feedback_source = FeedbackSourceWithOneBinarySlot(this); set(i++, javascript.ShiftLeft(), true);
set(i++, javascript.ShiftLeft(feedback_source), true);
set(i++, simplified.NumberShiftLeft(), false); set(i++, simplified.NumberShiftLeft(), false);
set(i++, javascript.ShiftRight(feedback_source), true); set(i++, javascript.ShiftRight(), true);
set(i++, simplified.NumberShiftRight(), false); set(i++, simplified.NumberShiftRight(), false);
set(i++, javascript.ShiftRightLogical(feedback_source), false); set(i++, javascript.ShiftRightLogical(), false);
set(i++, simplified.NumberShiftRightLogical(), false); set(i++, simplified.NumberShiftRightLogical(), false);
} }
static const int kNumberOps = 6; static const int kNumberOps = 6;
...@@ -375,12 +357,11 @@ class JSBitwiseTypedLoweringTester : public JSTypedLoweringTester { ...@@ -375,12 +357,11 @@ class JSBitwiseTypedLoweringTester : public JSTypedLoweringTester {
public: public:
JSBitwiseTypedLoweringTester() : JSTypedLoweringTester() { JSBitwiseTypedLoweringTester() : JSTypedLoweringTester() {
int i = 0; int i = 0;
FeedbackSource feedback_source = FeedbackSourceWithOneBinarySlot(this); set(i++, javascript.BitwiseOr(), true);
set(i++, javascript.BitwiseOr(feedback_source), true);
set(i++, simplified.NumberBitwiseOr(), true); set(i++, simplified.NumberBitwiseOr(), true);
set(i++, javascript.BitwiseXor(feedback_source), true); set(i++, javascript.BitwiseXor(), true);
set(i++, simplified.NumberBitwiseXor(), true); set(i++, simplified.NumberBitwiseXor(), true);
set(i++, javascript.BitwiseAnd(feedback_source), true); set(i++, javascript.BitwiseAnd(), true);
set(i++, simplified.NumberBitwiseAnd(), true); set(i++, simplified.NumberBitwiseAnd(), true);
} }
static const int kNumberOps = 6; static const int kNumberOps = 6;
...@@ -585,6 +566,16 @@ TEST(JSToString_replacement) { ...@@ -585,6 +566,16 @@ TEST(JSToString_replacement) {
} }
} }
namespace {
FeedbackSource FeedbackSourceWithOneCompareSlot(JSTypedLoweringTester* R) {
return FeedbackSource{FeedbackVector::NewWithOneCompareSlotForTesting(
R->main_zone(), R->main_isolate()),
FeedbackSlot{0}};
}
} // namespace
TEST(StringComparison) { TEST(StringComparison) {
JSTypedLoweringTester R; JSTypedLoweringTester R;
FeedbackSource feedback_source = FeedbackSourceWithOneCompareSlot(&R); FeedbackSource feedback_source = FeedbackSourceWithOneCompareSlot(&R);
...@@ -702,7 +693,6 @@ TEST(MixedComparison1) { ...@@ -702,7 +693,6 @@ TEST(MixedComparison1) {
TEST(RemoveToNumberEffects) { TEST(RemoveToNumberEffects) {
JSTypedLoweringTester R; JSTypedLoweringTester R;
FeedbackSource feedback_source = FeedbackSourceWithOneBinarySlot(&R);
Node* effect_use = nullptr; Node* effect_use = nullptr;
Node* zero = R.graph.NewNode(R.common.NumberConstant(0)); Node* zero = R.graph.NewNode(R.common.NumberConstant(0));
for (int i = 0; i < 10; i++) { for (int i = 0; i < 10; i++) {
...@@ -728,12 +718,11 @@ TEST(RemoveToNumberEffects) { ...@@ -728,12 +718,11 @@ TEST(RemoveToNumberEffects) {
effect_use = R.graph.NewNode(R.common.EffectPhi(1), ton, R.start()); effect_use = R.graph.NewNode(R.common.EffectPhi(1), ton, R.start());
break; break;
case 3: case 3:
effect_use = effect_use = R.graph.NewNode(R.javascript.Add(R.binop_hints), ton, ton,
R.graph.NewNode(R.javascript.Add(feedback_source), ton, ton, R.context(), frame_state, ton, R.start());
R.context(), frame_state, ton, R.start());
break; break;
case 4: case 4:
effect_use = R.graph.NewNode(R.javascript.Add(feedback_source), p0, p0, effect_use = R.graph.NewNode(R.javascript.Add(R.binop_hints), p0, p0,
R.context(), frame_state, ton, R.start()); R.context(), frame_state, ton, R.start());
break; break;
case 5: case 5:
...@@ -893,25 +882,24 @@ TEST(StringEquality) { ...@@ -893,25 +882,24 @@ TEST(StringEquality) {
TEST(RemovePureNumberBinopEffects) { TEST(RemovePureNumberBinopEffects) {
JSTypedLoweringTester R; JSTypedLoweringTester R;
FeedbackSource binary_source = FeedbackSourceWithOneBinarySlot(&R); FeedbackSource feedback_source = FeedbackSourceWithOneCompareSlot(&R);
FeedbackSource compare_source = FeedbackSourceWithOneCompareSlot(&R);
const Operator* ops[] = { const Operator* ops[] = {
R.javascript.Equal(compare_source), R.javascript.Equal(feedback_source),
R.simplified.NumberEqual(), R.simplified.NumberEqual(),
R.javascript.Add(binary_source), R.javascript.Add(R.binop_hints),
R.simplified.NumberAdd(), R.simplified.NumberAdd(),
R.javascript.Subtract(binary_source), R.javascript.Subtract(),
R.simplified.NumberSubtract(), R.simplified.NumberSubtract(),
R.javascript.Multiply(binary_source), R.javascript.Multiply(),
R.simplified.NumberMultiply(), R.simplified.NumberMultiply(),
R.javascript.Divide(binary_source), R.javascript.Divide(),
R.simplified.NumberDivide(), R.simplified.NumberDivide(),
R.javascript.Modulus(binary_source), R.javascript.Modulus(),
R.simplified.NumberModulus(), R.simplified.NumberModulus(),
R.javascript.LessThan(compare_source), R.javascript.LessThan(feedback_source),
R.simplified.NumberLessThan(), R.simplified.NumberLessThan(),
R.javascript.LessThanOrEqual(compare_source), R.javascript.LessThanOrEqual(feedback_source),
R.simplified.NumberLessThanOrEqual(), R.simplified.NumberLessThanOrEqual(),
}; };
......
...@@ -166,12 +166,6 @@ TEST_F(JSTypedLoweringTest, JSToStringWithBoolean) { ...@@ -166,12 +166,6 @@ TEST_F(JSTypedLoweringTest, JSToStringWithBoolean) {
namespace { namespace {
FeedbackSource FeedbackSourceWithOneBinarySlot(JSTypedLoweringTest* R) {
return FeedbackSource{
FeedbackVector::NewWithOneBinarySlotForTesting(R->zone(), R->isolate()),
FeedbackSlot{0}};
}
FeedbackSource FeedbackSourceWithOneCompareSlot(JSTypedLoweringTest* R) { FeedbackSource FeedbackSourceWithOneCompareSlot(JSTypedLoweringTest* R) {
return FeedbackSource{ return FeedbackSource{
FeedbackVector::NewWithOneCompareSlotForTesting(R->zone(), R->isolate()), FeedbackVector::NewWithOneCompareSlotForTesting(R->zone(), R->isolate()),
...@@ -218,9 +212,9 @@ TEST_F(JSTypedLoweringTest, JSShiftLeftWithSigned32AndConstant) { ...@@ -218,9 +212,9 @@ TEST_F(JSTypedLoweringTest, JSShiftLeftWithSigned32AndConstant) {
Node* const effect = graph()->start(); Node* const effect = graph()->start();
Node* const control = graph()->start(); Node* const control = graph()->start();
TRACED_FORRANGE(double, rhs, 0, 31) { TRACED_FORRANGE(double, rhs, 0, 31) {
Reduction r = Reduce(graph()->NewNode( Reduction r = Reduce(graph()->NewNode(javascript()->ShiftLeft(), lhs,
javascript()->ShiftLeft(FeedbackSourceWithOneBinarySlot(this)), lhs, NumberConstant(rhs), context,
NumberConstant(rhs), context, EmptyFrameState(), effect, control)); EmptyFrameState(), effect, control));
ASSERT_TRUE(r.Changed()); ASSERT_TRUE(r.Changed());
EXPECT_THAT(r.replacement(), EXPECT_THAT(r.replacement(),
IsNumberShiftLeft(lhs, IsNumberConstant(BitEq(rhs)))); IsNumberShiftLeft(lhs, IsNumberConstant(BitEq(rhs))));
...@@ -233,9 +227,9 @@ TEST_F(JSTypedLoweringTest, JSShiftLeftWithSigned32AndUnsigned32) { ...@@ -233,9 +227,9 @@ TEST_F(JSTypedLoweringTest, JSShiftLeftWithSigned32AndUnsigned32) {
Node* const context = UndefinedConstant(); Node* const context = UndefinedConstant();
Node* const effect = graph()->start(); Node* const effect = graph()->start();
Node* const control = graph()->start(); Node* const control = graph()->start();
Reduction r = Reduce(graph()->NewNode( Reduction r =
javascript()->ShiftLeft(FeedbackSourceWithOneBinarySlot(this)), lhs, rhs, Reduce(graph()->NewNode(javascript()->ShiftLeft(), lhs, rhs, context,
context, EmptyFrameState(), effect, control)); EmptyFrameState(), effect, control));
ASSERT_TRUE(r.Changed()); ASSERT_TRUE(r.Changed());
EXPECT_THAT(r.replacement(), IsNumberShiftLeft(lhs, rhs)); EXPECT_THAT(r.replacement(), IsNumberShiftLeft(lhs, rhs));
} }
...@@ -251,9 +245,9 @@ TEST_F(JSTypedLoweringTest, JSShiftRightWithSigned32AndConstant) { ...@@ -251,9 +245,9 @@ TEST_F(JSTypedLoweringTest, JSShiftRightWithSigned32AndConstant) {
Node* const effect = graph()->start(); Node* const effect = graph()->start();
Node* const control = graph()->start(); Node* const control = graph()->start();
TRACED_FORRANGE(double, rhs, 0, 31) { TRACED_FORRANGE(double, rhs, 0, 31) {
Reduction r = Reduce(graph()->NewNode( Reduction r = Reduce(graph()->NewNode(javascript()->ShiftRight(), lhs,
javascript()->ShiftRight(FeedbackSourceWithOneBinarySlot(this)), lhs, NumberConstant(rhs), context,
NumberConstant(rhs), context, EmptyFrameState(), effect, control)); EmptyFrameState(), effect, control));
ASSERT_TRUE(r.Changed()); ASSERT_TRUE(r.Changed());
EXPECT_THAT(r.replacement(), EXPECT_THAT(r.replacement(),
IsNumberShiftRight(lhs, IsNumberConstant(BitEq(rhs)))); IsNumberShiftRight(lhs, IsNumberConstant(BitEq(rhs))));
...@@ -267,9 +261,9 @@ TEST_F(JSTypedLoweringTest, JSShiftRightWithSigned32AndUnsigned32) { ...@@ -267,9 +261,9 @@ TEST_F(JSTypedLoweringTest, JSShiftRightWithSigned32AndUnsigned32) {
Node* const context = UndefinedConstant(); Node* const context = UndefinedConstant();
Node* const effect = graph()->start(); Node* const effect = graph()->start();
Node* const control = graph()->start(); Node* const control = graph()->start();
Reduction r = Reduce(graph()->NewNode( Reduction r =
javascript()->ShiftRight(FeedbackSourceWithOneBinarySlot(this)), lhs, rhs, Reduce(graph()->NewNode(javascript()->ShiftRight(), lhs, rhs, context,
context, EmptyFrameState(), effect, control)); EmptyFrameState(), effect, control));
ASSERT_TRUE(r.Changed()); ASSERT_TRUE(r.Changed());
EXPECT_THAT(r.replacement(), IsNumberShiftRight(lhs, rhs)); EXPECT_THAT(r.replacement(), IsNumberShiftRight(lhs, rhs));
} }
...@@ -286,9 +280,9 @@ TEST_F(JSTypedLoweringTest, ...@@ -286,9 +280,9 @@ TEST_F(JSTypedLoweringTest,
Node* const effect = graph()->start(); Node* const effect = graph()->start();
Node* const control = graph()->start(); Node* const control = graph()->start();
TRACED_FORRANGE(double, rhs, 0, 31) { TRACED_FORRANGE(double, rhs, 0, 31) {
Reduction r = Reduce(graph()->NewNode( Reduction r = Reduce(graph()->NewNode(javascript()->ShiftRightLogical(),
javascript()->ShiftRightLogical(FeedbackSourceWithOneBinarySlot(this)), lhs, NumberConstant(rhs), context,
lhs, NumberConstant(rhs), context, EmptyFrameState(), effect, control)); EmptyFrameState(), effect, control));
ASSERT_TRUE(r.Changed()); ASSERT_TRUE(r.Changed());
EXPECT_THAT(r.replacement(), EXPECT_THAT(r.replacement(),
IsNumberShiftRightLogical(lhs, IsNumberConstant(BitEq(rhs)))); IsNumberShiftRightLogical(lhs, IsNumberConstant(BitEq(rhs))));
...@@ -302,9 +296,9 @@ TEST_F(JSTypedLoweringTest, JSShiftRightLogicalWithUnsigned32AndUnsigned32) { ...@@ -302,9 +296,9 @@ TEST_F(JSTypedLoweringTest, JSShiftRightLogicalWithUnsigned32AndUnsigned32) {
Node* const context = UndefinedConstant(); Node* const context = UndefinedConstant();
Node* const effect = graph()->start(); Node* const effect = graph()->start();
Node* const control = graph()->start(); Node* const control = graph()->start();
Reduction r = Reduce(graph()->NewNode( Reduction r =
javascript()->ShiftRightLogical(FeedbackSourceWithOneBinarySlot(this)), Reduce(graph()->NewNode(javascript()->ShiftRightLogical(), lhs, rhs,
lhs, rhs, context, EmptyFrameState(), effect, control)); context, EmptyFrameState(), effect, control));
ASSERT_TRUE(r.Changed()); ASSERT_TRUE(r.Changed());
EXPECT_THAT(r.replacement(), IsNumberShiftRightLogical(lhs, rhs)); EXPECT_THAT(r.replacement(), IsNumberShiftRightLogical(lhs, rhs));
} }
...@@ -402,15 +396,15 @@ TEST_F(JSTypedLoweringTest, JSLoadNamedStringLength) { ...@@ -402,15 +396,15 @@ TEST_F(JSTypedLoweringTest, JSLoadNamedStringLength) {
TEST_F(JSTypedLoweringTest, JSAddWithString) { TEST_F(JSTypedLoweringTest, JSAddWithString) {
BinaryOperationHint const hint = BinaryOperationHint::kAny;
Node* lhs = Parameter(Type::String(), 0); Node* lhs = Parameter(Type::String(), 0);
Node* rhs = Parameter(Type::String(), 1); Node* rhs = Parameter(Type::String(), 1);
Node* context = Parameter(Type::Any(), 2); Node* context = Parameter(Type::Any(), 2);
Node* frame_state = EmptyFrameState(); Node* frame_state = EmptyFrameState();
Node* effect = graph()->start(); Node* effect = graph()->start();
Node* control = graph()->start(); Node* control = graph()->start();
Reduction r = Reduce( Reduction r = Reduce(graph()->NewNode(javascript()->Add(hint), lhs, rhs,
graph()->NewNode(javascript()->Add(FeedbackSourceWithOneBinarySlot(this)), context, frame_state, effect, control));
lhs, rhs, context, frame_state, effect, control));
ASSERT_TRUE(r.Changed()); ASSERT_TRUE(r.Changed());
EXPECT_THAT(r.replacement(), IsStringConcat(_, lhs, rhs)); EXPECT_THAT(r.replacement(), IsStringConcat(_, lhs, rhs));
} }
......
...@@ -61,6 +61,7 @@ class TyperTest : public TypedGraphTest { ...@@ -61,6 +61,7 @@ class TyperTest : public TypedGraphTest {
Types types_; Types types_;
JSOperatorBuilder javascript_; JSOperatorBuilder javascript_;
SimplifiedOperatorBuilder simplified_; SimplifiedOperatorBuilder simplified_;
BinaryOperationHint const hints_ = BinaryOperationHint::kAny;
Node* context_node_; Node* context_node_;
v8::base::RandomNumberGenerator* rng_; v8::base::RandomNumberGenerator* rng_;
std::vector<double> integers; std::vector<double> integers;
...@@ -312,18 +313,6 @@ int32_t bit_xor(int32_t x, int32_t y) { return x ^ y; } ...@@ -312,18 +313,6 @@ int32_t bit_xor(int32_t x, int32_t y) { return x ^ y; }
double divide_double_double(double x, double y) { return base::Divide(x, y); } double divide_double_double(double x, double y) { return base::Divide(x, y); }
double modulo_double_double(double x, double y) { return Modulo(x, y); } double modulo_double_double(double x, double y) { return Modulo(x, y); }
FeedbackSource FeedbackSourceWithOneBinarySlot(TyperTest* R) {
return FeedbackSource{
FeedbackVector::NewWithOneBinarySlotForTesting(R->zone(), R->isolate()),
FeedbackSlot{0}};
}
FeedbackSource FeedbackSourceWithOneCompareSlot(TyperTest* R) {
return FeedbackSource{
FeedbackVector::NewWithOneCompareSlotForTesting(R->zone(), R->isolate()),
FeedbackSlot{0}};
}
} // namespace } // namespace
...@@ -334,55 +323,55 @@ FeedbackSource FeedbackSourceWithOneCompareSlot(TyperTest* R) { ...@@ -334,55 +323,55 @@ FeedbackSource FeedbackSourceWithOneCompareSlot(TyperTest* R) {
// to ranges as input types. // to ranges as input types.
TEST_F(TyperTest, TypeJSAdd) { TEST_F(TyperTest, TypeJSAdd) {
TestBinaryArithOp(javascript_.Add(FeedbackSourceWithOneBinarySlot(this)), TestBinaryArithOp(javascript_.Add(hints_), std::plus<double>());
std::plus<double>());
} }
TEST_F(TyperTest, TypeJSSubtract) { TEST_F(TyperTest, TypeJSSubtract) {
TestBinaryArithOp(javascript_.Subtract(FeedbackSourceWithOneBinarySlot(this)), TestBinaryArithOp(javascript_.Subtract(), std::minus<double>());
std::minus<double>());
} }
TEST_F(TyperTest, TypeJSMultiply) { TEST_F(TyperTest, TypeJSMultiply) {
TestBinaryArithOp(javascript_.Multiply(FeedbackSourceWithOneBinarySlot(this)), TestBinaryArithOp(javascript_.Multiply(), std::multiplies<double>());
std::multiplies<double>());
} }
TEST_F(TyperTest, TypeJSDivide) { TEST_F(TyperTest, TypeJSDivide) {
TestBinaryArithOp(javascript_.Divide(FeedbackSourceWithOneBinarySlot(this)), TestBinaryArithOp(javascript_.Divide(), divide_double_double);
divide_double_double);
} }
TEST_F(TyperTest, TypeJSModulus) { TEST_F(TyperTest, TypeJSModulus) {
TestBinaryArithOp(javascript_.Modulus(FeedbackSourceWithOneBinarySlot(this)), TestBinaryArithOp(javascript_.Modulus(), modulo_double_double);
modulo_double_double);
} }
TEST_F(TyperTest, TypeJSBitwiseOr) { TEST_F(TyperTest, TypeJSBitwiseOr) {
TestBinaryBitOp(javascript_.BitwiseOr(FeedbackSourceWithOneBinarySlot(this)), TestBinaryBitOp(javascript_.BitwiseOr(), bit_or);
bit_or);
} }
TEST_F(TyperTest, TypeJSBitwiseAnd) { TEST_F(TyperTest, TypeJSBitwiseAnd) {
TestBinaryBitOp(javascript_.BitwiseAnd(FeedbackSourceWithOneBinarySlot(this)), TestBinaryBitOp(javascript_.BitwiseAnd(), bit_and);
bit_and);
} }
TEST_F(TyperTest, TypeJSBitwiseXor) { TEST_F(TyperTest, TypeJSBitwiseXor) {
TestBinaryBitOp(javascript_.BitwiseXor(FeedbackSourceWithOneBinarySlot(this)), TestBinaryBitOp(javascript_.BitwiseXor(), bit_xor);
bit_xor);
} }
TEST_F(TyperTest, TypeJSShiftLeft) { TEST_F(TyperTest, TypeJSShiftLeft) {
TestBinaryBitOp(javascript_.ShiftLeft(FeedbackSourceWithOneBinarySlot(this)), TestBinaryBitOp(javascript_.ShiftLeft(), shift_left);
shift_left);
} }
TEST_F(TyperTest, TypeJSShiftRight) { TEST_F(TyperTest, TypeJSShiftRight) {
TestBinaryBitOp(javascript_.ShiftRight(FeedbackSourceWithOneBinarySlot(this)), TestBinaryBitOp(javascript_.ShiftRight(), shift_right);
shift_right); }
namespace {
FeedbackSource FeedbackSourceWithOneCompareSlot(TyperTest* R) {
return FeedbackSource{
FeedbackVector::NewWithOneCompareSlotForTesting(R->zone(), R->isolate()),
FeedbackSlot{0}};
} }
} // namespace
TEST_F(TyperTest, TypeJSLessThan) { TEST_F(TyperTest, TypeJSLessThan) {
TestBinaryCompareOp( TestBinaryCompareOp(
javascript_.LessThan(FeedbackSourceWithOneCompareSlot(this)), javascript_.LessThan(FeedbackSourceWithOneCompareSlot(this)),
...@@ -466,7 +455,7 @@ TEST_MONOTONICITY(ToObject) ...@@ -466,7 +455,7 @@ TEST_MONOTONICITY(ToObject)
TEST_MONOTONICITY(ToString) TEST_MONOTONICITY(ToString)
#undef TEST_MONOTONICITY #undef TEST_MONOTONICITY
// JS compare ops. // JS BINOPs with CompareOperationHint
#define TEST_MONOTONICITY(name) \ #define TEST_MONOTONICITY(name) \
TEST_F(TyperTest, Monotonicity_##name) { \ TEST_F(TyperTest, Monotonicity_##name) { \
TestBinaryMonotonicity( \ TestBinaryMonotonicity( \
...@@ -480,33 +469,36 @@ TEST_MONOTONICITY(LessThanOrEqual) ...@@ -480,33 +469,36 @@ TEST_MONOTONICITY(LessThanOrEqual)
TEST_MONOTONICITY(GreaterThanOrEqual) TEST_MONOTONICITY(GreaterThanOrEqual)
#undef TEST_MONOTONICITY #undef TEST_MONOTONICITY
// JS binary ops. // JS BINOPs with BinaryOperationHint
#define TEST_MONOTONICITY(name) \ #define TEST_MONOTONICITY(name) \
TEST_F(TyperTest, Monotonicity_##name) { \ TEST_F(TyperTest, Monotonicity_##name) { \
TestBinaryMonotonicity( \ TestBinaryMonotonicity(javascript_.name(BinaryOperationHint::kAny)); \
javascript_.name(FeedbackSourceWithOneBinarySlot(this))); \
} }
TEST_MONOTONICITY(Add) TEST_MONOTONICITY(Add)
TEST_MONOTONICITY(BitwiseAnd) #undef TEST_MONOTONICITY
TEST_F(TyperTest, Monotonicity_InstanceOf) {
TestBinaryMonotonicity(javascript_.InstanceOf(FeedbackSource()));
}
// JS BINOPS without hint
#define TEST_MONOTONICITY(name) \
TEST_F(TyperTest, Monotonicity_##name) { \
TestBinaryMonotonicity(javascript_.name()); \
}
TEST_MONOTONICITY(BitwiseOr) TEST_MONOTONICITY(BitwiseOr)
TEST_MONOTONICITY(BitwiseXor) TEST_MONOTONICITY(BitwiseXor)
TEST_MONOTONICITY(Divide) TEST_MONOTONICITY(BitwiseAnd)
TEST_MONOTONICITY(Modulus)
TEST_MONOTONICITY(Multiply)
TEST_MONOTONICITY(ShiftLeft) TEST_MONOTONICITY(ShiftLeft)
TEST_MONOTONICITY(ShiftRight) TEST_MONOTONICITY(ShiftRight)
TEST_MONOTONICITY(ShiftRightLogical) TEST_MONOTONICITY(ShiftRightLogical)
TEST_MONOTONICITY(Subtract) TEST_MONOTONICITY(Subtract)
TEST_MONOTONICITY(Multiply)
TEST_MONOTONICITY(Divide)
TEST_MONOTONICITY(Modulus)
TEST_MONOTONICITY(OrdinaryHasInstance)
#undef TEST_MONOTONICITY #undef TEST_MONOTONICITY
TEST_F(TyperTest, Monotonicity_InstanceOf) {
TestBinaryMonotonicity(javascript_.InstanceOf(FeedbackSource()));
}
TEST_F(TyperTest, Monotonicity_OrdinaryHasInstance) {
TestBinaryMonotonicity(javascript_.OrdinaryHasInstance());
}
// SIMPLIFIED UNOPs without hint // SIMPLIFIED UNOPs without hint
#define TEST_MONOTONICITY(name) \ #define TEST_MONOTONICITY(name) \
TEST_F(TyperTest, Monotonicity_##name) { \ TEST_F(TyperTest, Monotonicity_##name) { \
......
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