| OLD | NEW |
| 1 // Copyright 2014 the V8 project authors. All rights reserved. | 1 // Copyright 2014 the V8 project authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "src/code-factory.h" | 5 #include "src/code-factory.h" |
| 6 #include "src/compiler/access-builder.h" | 6 #include "src/compiler/access-builder.h" |
| 7 #include "src/compiler/js-graph.h" | 7 #include "src/compiler/js-graph.h" |
| 8 #include "src/compiler/js-operator.h" | 8 #include "src/compiler/js-operator.h" |
| 9 #include "src/compiler/js-typed-lowering.h" | 9 #include "src/compiler/js-typed-lowering.h" |
| 10 #include "src/compiler/machine-operator.h" | 10 #include "src/compiler/machine-operator.h" |
| (...skipping 406 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 417 // JSShiftLeft | 417 // JSShiftLeft |
| 418 | 418 |
| 419 | 419 |
| 420 TEST_F(JSTypedLoweringTest, JSShiftLeftWithSigned32AndConstant) { | 420 TEST_F(JSTypedLoweringTest, JSShiftLeftWithSigned32AndConstant) { |
| 421 BinaryOperationHints const hints = BinaryOperationHints::Any(); | 421 BinaryOperationHints const hints = BinaryOperationHints::Any(); |
| 422 Node* const lhs = Parameter(Type::Signed32()); | 422 Node* const lhs = Parameter(Type::Signed32()); |
| 423 Node* const context = UndefinedConstant(); | 423 Node* const context = UndefinedConstant(); |
| 424 Node* const effect = graph()->start(); | 424 Node* const effect = graph()->start(); |
| 425 Node* const control = graph()->start(); | 425 Node* const control = graph()->start(); |
| 426 TRACED_FORRANGE(double, rhs, 0, 31) { | 426 TRACED_FORRANGE(double, rhs, 0, 31) { |
| 427 Reduction r = Reduce(graph()->NewNode( | 427 Reduction r = Reduce(graph()->NewNode(javascript()->ShiftLeft(hints), lhs, |
| 428 javascript()->ShiftLeft(hints), lhs, NumberConstant(rhs), context, | 428 NumberConstant(rhs), context, |
| 429 EmptyFrameState(), EmptyFrameState(), effect, control)); | 429 EmptyFrameState(), effect, control)); |
| 430 ASSERT_TRUE(r.Changed()); | 430 ASSERT_TRUE(r.Changed()); |
| 431 EXPECT_THAT(r.replacement(), | 431 EXPECT_THAT(r.replacement(), |
| 432 IsNumberShiftLeft(lhs, IsNumberConstant(BitEq(rhs)))); | 432 IsNumberShiftLeft(lhs, IsNumberConstant(BitEq(rhs)))); |
| 433 } | 433 } |
| 434 } | 434 } |
| 435 | 435 |
| 436 | 436 |
| 437 TEST_F(JSTypedLoweringTest, JSShiftLeftWithSigned32AndUnsigned32) { | 437 TEST_F(JSTypedLoweringTest, JSShiftLeftWithSigned32AndUnsigned32) { |
| 438 BinaryOperationHints const hints = BinaryOperationHints::Any(); | 438 BinaryOperationHints const hints = BinaryOperationHints::Any(); |
| 439 Node* const lhs = Parameter(Type::Signed32()); | 439 Node* const lhs = Parameter(Type::Signed32()); |
| 440 Node* const rhs = Parameter(Type::Unsigned32()); | 440 Node* const rhs = Parameter(Type::Unsigned32()); |
| 441 Node* const context = UndefinedConstant(); | 441 Node* const context = UndefinedConstant(); |
| 442 Node* const effect = graph()->start(); | 442 Node* const effect = graph()->start(); |
| 443 Node* const control = graph()->start(); | 443 Node* const control = graph()->start(); |
| 444 Reduction r = Reduce(graph()->NewNode(javascript()->ShiftLeft(hints), lhs, | 444 Reduction r = |
| 445 rhs, context, EmptyFrameState(), | 445 Reduce(graph()->NewNode(javascript()->ShiftLeft(hints), lhs, rhs, context, |
| 446 EmptyFrameState(), effect, control)); | 446 EmptyFrameState(), effect, control)); |
| 447 ASSERT_TRUE(r.Changed()); | 447 ASSERT_TRUE(r.Changed()); |
| 448 EXPECT_THAT(r.replacement(), IsNumberShiftLeft(lhs, rhs)); | 448 EXPECT_THAT(r.replacement(), IsNumberShiftLeft(lhs, rhs)); |
| 449 } | 449 } |
| 450 | 450 |
| 451 TEST_F(JSTypedLoweringTest, JSShiftLeftWithTypeFeedback) { | 451 TEST_F(JSTypedLoweringTest, JSShiftLeftWithTypeFeedback) { |
| 452 BinaryOperationHints::Hint const feedback_types[] = { | 452 BinaryOperationHints::Hint const feedback_types[] = { |
| 453 BinaryOperationHints::kSignedSmall, | 453 BinaryOperationHints::kSignedSmall, |
| 454 BinaryOperationHints::kNumberOrOddball}; | 454 BinaryOperationHints::kNumberOrOddball}; |
| 455 for (BinaryOperationHints::Hint feedback : feedback_types) { | 455 for (BinaryOperationHints::Hint feedback : feedback_types) { |
| 456 BinaryOperationHints const hints(feedback, feedback, feedback); | 456 BinaryOperationHints const hints(feedback, feedback, feedback); |
| 457 Node* lhs = Parameter(Type::Number(), 2); | 457 Node* lhs = Parameter(Type::Number(), 2); |
| 458 Node* rhs = Parameter(Type::Number(), 3); | 458 Node* rhs = Parameter(Type::Number(), 3); |
| 459 Node* effect = graph()->start(); | 459 Node* effect = graph()->start(); |
| 460 Node* control = graph()->start(); | 460 Node* control = graph()->start(); |
| 461 Reduction r = Reduce(graph()->NewNode( | 461 Reduction r = Reduce(graph()->NewNode(javascript()->ShiftLeft(hints), lhs, |
| 462 javascript()->ShiftLeft(hints), lhs, rhs, UndefinedConstant(), | 462 rhs, UndefinedConstant(), |
| 463 EmptyFrameState(), EmptyFrameState(), effect, control)); | 463 EmptyFrameState(), effect, control)); |
| 464 ASSERT_TRUE(r.Changed()); | 464 ASSERT_TRUE(r.Changed()); |
| 465 EXPECT_THAT(r.replacement(), IsSpeculativeNumberShiftLeft( | 465 EXPECT_THAT(r.replacement(), IsSpeculativeNumberShiftLeft( |
| 466 feedback, lhs, rhs, effect, control)); | 466 feedback, lhs, rhs, effect, control)); |
| 467 } | 467 } |
| 468 } | 468 } |
| 469 | 469 |
| 470 // ----------------------------------------------------------------------------- | 470 // ----------------------------------------------------------------------------- |
| 471 // JSShiftRight | 471 // JSShiftRight |
| 472 | 472 |
| 473 | 473 |
| 474 TEST_F(JSTypedLoweringTest, JSShiftRightWithSigned32AndConstant) { | 474 TEST_F(JSTypedLoweringTest, JSShiftRightWithSigned32AndConstant) { |
| 475 BinaryOperationHints const hints = BinaryOperationHints::Any(); | 475 BinaryOperationHints const hints = BinaryOperationHints::Any(); |
| 476 Node* const lhs = Parameter(Type::Signed32()); | 476 Node* const lhs = Parameter(Type::Signed32()); |
| 477 Node* const context = UndefinedConstant(); | 477 Node* const context = UndefinedConstant(); |
| 478 Node* const effect = graph()->start(); | 478 Node* const effect = graph()->start(); |
| 479 Node* const control = graph()->start(); | 479 Node* const control = graph()->start(); |
| 480 TRACED_FORRANGE(double, rhs, 0, 31) { | 480 TRACED_FORRANGE(double, rhs, 0, 31) { |
| 481 Reduction r = Reduce(graph()->NewNode( | 481 Reduction r = Reduce(graph()->NewNode(javascript()->ShiftRight(hints), lhs, |
| 482 javascript()->ShiftRight(hints), lhs, NumberConstant(rhs), context, | 482 NumberConstant(rhs), context, |
| 483 EmptyFrameState(), EmptyFrameState(), effect, control)); | 483 EmptyFrameState(), effect, control)); |
| 484 ASSERT_TRUE(r.Changed()); | 484 ASSERT_TRUE(r.Changed()); |
| 485 EXPECT_THAT(r.replacement(), | 485 EXPECT_THAT(r.replacement(), |
| 486 IsNumberShiftRight(lhs, IsNumberConstant(BitEq(rhs)))); | 486 IsNumberShiftRight(lhs, IsNumberConstant(BitEq(rhs)))); |
| 487 } | 487 } |
| 488 } | 488 } |
| 489 | 489 |
| 490 | 490 |
| 491 TEST_F(JSTypedLoweringTest, JSShiftRightWithSigned32AndUnsigned32) { | 491 TEST_F(JSTypedLoweringTest, JSShiftRightWithSigned32AndUnsigned32) { |
| 492 BinaryOperationHints const hints = BinaryOperationHints::Any(); | 492 BinaryOperationHints const hints = BinaryOperationHints::Any(); |
| 493 Node* const lhs = Parameter(Type::Signed32()); | 493 Node* const lhs = Parameter(Type::Signed32()); |
| 494 Node* const rhs = Parameter(Type::Unsigned32()); | 494 Node* const rhs = Parameter(Type::Unsigned32()); |
| 495 Node* const context = UndefinedConstant(); | 495 Node* const context = UndefinedConstant(); |
| 496 Node* const effect = graph()->start(); | 496 Node* const effect = graph()->start(); |
| 497 Node* const control = graph()->start(); | 497 Node* const control = graph()->start(); |
| 498 Reduction r = Reduce(graph()->NewNode(javascript()->ShiftRight(hints), lhs, | 498 Reduction r = |
| 499 rhs, context, EmptyFrameState(), | 499 Reduce(graph()->NewNode(javascript()->ShiftRight(hints), lhs, rhs, |
| 500 EmptyFrameState(), effect, control)); | 500 context, EmptyFrameState(), effect, control)); |
| 501 ASSERT_TRUE(r.Changed()); | 501 ASSERT_TRUE(r.Changed()); |
| 502 EXPECT_THAT(r.replacement(), IsNumberShiftRight(lhs, rhs)); | 502 EXPECT_THAT(r.replacement(), IsNumberShiftRight(lhs, rhs)); |
| 503 } | 503 } |
| 504 | 504 |
| 505 TEST_F(JSTypedLoweringTest, JSShiftRightWithTypeFeedback) { | 505 TEST_F(JSTypedLoweringTest, JSShiftRightWithTypeFeedback) { |
| 506 BinaryOperationHints::Hint const feedback_types[] = { | 506 BinaryOperationHints::Hint const feedback_types[] = { |
| 507 BinaryOperationHints::kSignedSmall, | 507 BinaryOperationHints::kSignedSmall, |
| 508 BinaryOperationHints::kNumberOrOddball}; | 508 BinaryOperationHints::kNumberOrOddball}; |
| 509 for (BinaryOperationHints::Hint feedback : feedback_types) { | 509 for (BinaryOperationHints::Hint feedback : feedback_types) { |
| 510 BinaryOperationHints const hints(feedback, feedback, feedback); | 510 BinaryOperationHints const hints(feedback, feedback, feedback); |
| 511 Node* lhs = Parameter(Type::Number(), 2); | 511 Node* lhs = Parameter(Type::Number(), 2); |
| 512 Node* rhs = Parameter(Type::Number(), 3); | 512 Node* rhs = Parameter(Type::Number(), 3); |
| 513 Node* effect = graph()->start(); | 513 Node* effect = graph()->start(); |
| 514 Node* control = graph()->start(); | 514 Node* control = graph()->start(); |
| 515 Reduction r = Reduce(graph()->NewNode( | 515 Reduction r = Reduce(graph()->NewNode(javascript()->ShiftRight(hints), lhs, |
| 516 javascript()->ShiftRight(hints), lhs, rhs, UndefinedConstant(), | 516 rhs, UndefinedConstant(), |
| 517 EmptyFrameState(), EmptyFrameState(), effect, control)); | 517 EmptyFrameState(), effect, control)); |
| 518 ASSERT_TRUE(r.Changed()); | 518 ASSERT_TRUE(r.Changed()); |
| 519 EXPECT_THAT(r.replacement(), IsSpeculativeNumberShiftRight( | 519 EXPECT_THAT(r.replacement(), IsSpeculativeNumberShiftRight( |
| 520 feedback, lhs, rhs, effect, control)); | 520 feedback, lhs, rhs, effect, control)); |
| 521 } | 521 } |
| 522 } | 522 } |
| 523 | 523 |
| 524 // ----------------------------------------------------------------------------- | 524 // ----------------------------------------------------------------------------- |
| 525 // JSShiftRightLogical | 525 // JSShiftRightLogical |
| 526 | 526 |
| 527 | 527 |
| 528 TEST_F(JSTypedLoweringTest, | 528 TEST_F(JSTypedLoweringTest, |
| 529 JSShiftRightLogicalWithUnsigned32AndConstant) { | 529 JSShiftRightLogicalWithUnsigned32AndConstant) { |
| 530 BinaryOperationHints const hints = BinaryOperationHints::Any(); | 530 BinaryOperationHints const hints = BinaryOperationHints::Any(); |
| 531 Node* const lhs = Parameter(Type::Unsigned32()); | 531 Node* const lhs = Parameter(Type::Unsigned32()); |
| 532 Node* const context = UndefinedConstant(); | 532 Node* const context = UndefinedConstant(); |
| 533 Node* const effect = graph()->start(); | 533 Node* const effect = graph()->start(); |
| 534 Node* const control = graph()->start(); | 534 Node* const control = graph()->start(); |
| 535 TRACED_FORRANGE(double, rhs, 0, 31) { | 535 TRACED_FORRANGE(double, rhs, 0, 31) { |
| 536 Reduction r = Reduce(graph()->NewNode( | 536 Reduction r = Reduce(graph()->NewNode( |
| 537 javascript()->ShiftRightLogical(hints), lhs, NumberConstant(rhs), | 537 javascript()->ShiftRightLogical(hints), lhs, NumberConstant(rhs), |
| 538 context, EmptyFrameState(), EmptyFrameState(), effect, control)); | 538 context, EmptyFrameState(), effect, control)); |
| 539 ASSERT_TRUE(r.Changed()); | 539 ASSERT_TRUE(r.Changed()); |
| 540 EXPECT_THAT(r.replacement(), | 540 EXPECT_THAT(r.replacement(), |
| 541 IsNumberShiftRightLogical(lhs, IsNumberConstant(BitEq(rhs)))); | 541 IsNumberShiftRightLogical(lhs, IsNumberConstant(BitEq(rhs)))); |
| 542 } | 542 } |
| 543 } | 543 } |
| 544 | 544 |
| 545 | 545 |
| 546 TEST_F(JSTypedLoweringTest, JSShiftRightLogicalWithUnsigned32AndUnsigned32) { | 546 TEST_F(JSTypedLoweringTest, JSShiftRightLogicalWithUnsigned32AndUnsigned32) { |
| 547 BinaryOperationHints const hints = BinaryOperationHints::Any(); | 547 BinaryOperationHints const hints = BinaryOperationHints::Any(); |
| 548 Node* const lhs = Parameter(Type::Unsigned32()); | 548 Node* const lhs = Parameter(Type::Unsigned32()); |
| 549 Node* const rhs = Parameter(Type::Unsigned32()); | 549 Node* const rhs = Parameter(Type::Unsigned32()); |
| 550 Node* const context = UndefinedConstant(); | 550 Node* const context = UndefinedConstant(); |
| 551 Node* const effect = graph()->start(); | 551 Node* const effect = graph()->start(); |
| 552 Node* const control = graph()->start(); | 552 Node* const control = graph()->start(); |
| 553 Reduction r = Reduce(graph()->NewNode(javascript()->ShiftRightLogical(hints), | 553 Reduction r = |
| 554 lhs, rhs, context, EmptyFrameState(), | 554 Reduce(graph()->NewNode(javascript()->ShiftRightLogical(hints), lhs, rhs, |
| 555 EmptyFrameState(), effect, control)); | 555 context, EmptyFrameState(), effect, control)); |
| 556 ASSERT_TRUE(r.Changed()); | 556 ASSERT_TRUE(r.Changed()); |
| 557 EXPECT_THAT(r.replacement(), IsNumberShiftRightLogical(lhs, rhs)); | 557 EXPECT_THAT(r.replacement(), IsNumberShiftRightLogical(lhs, rhs)); |
| 558 } | 558 } |
| 559 | 559 |
| 560 TEST_F(JSTypedLoweringTest, JSShiftRightLogicalWithTypeFeedback) { | 560 TEST_F(JSTypedLoweringTest, JSShiftRightLogicalWithTypeFeedback) { |
| 561 BinaryOperationHints::Hint const feedback_types[] = { | 561 BinaryOperationHints::Hint const feedback_types[] = { |
| 562 BinaryOperationHints::kSignedSmall, | 562 BinaryOperationHints::kSignedSmall, |
| 563 BinaryOperationHints::kNumberOrOddball}; | 563 BinaryOperationHints::kNumberOrOddball}; |
| 564 for (BinaryOperationHints::Hint feedback : feedback_types) { | 564 for (BinaryOperationHints::Hint feedback : feedback_types) { |
| 565 BinaryOperationHints const hints(feedback, feedback, feedback); | 565 BinaryOperationHints const hints(feedback, feedback, feedback); |
| 566 Node* lhs = Parameter(Type::Number(), 2); | 566 Node* lhs = Parameter(Type::Number(), 2); |
| 567 Node* rhs = Parameter(Type::Number(), 3); | 567 Node* rhs = Parameter(Type::Number(), 3); |
| 568 Node* effect = graph()->start(); | 568 Node* effect = graph()->start(); |
| 569 Node* control = graph()->start(); | 569 Node* control = graph()->start(); |
| 570 Reduction r = Reduce(graph()->NewNode( | 570 Reduction r = Reduce(graph()->NewNode( |
| 571 javascript()->ShiftRightLogical(hints), lhs, rhs, UndefinedConstant(), | 571 javascript()->ShiftRightLogical(hints), lhs, rhs, UndefinedConstant(), |
| 572 EmptyFrameState(), EmptyFrameState(), effect, control)); | 572 EmptyFrameState(), effect, control)); |
| 573 ASSERT_TRUE(r.Changed()); | 573 ASSERT_TRUE(r.Changed()); |
| 574 EXPECT_THAT(r.replacement(), IsSpeculativeNumberShiftRightLogical( | 574 EXPECT_THAT(r.replacement(), IsSpeculativeNumberShiftRightLogical( |
| 575 feedback, lhs, rhs, effect, control)); | 575 feedback, lhs, rhs, effect, control)); |
| 576 } | 576 } |
| 577 } | 577 } |
| 578 | 578 |
| 579 // ----------------------------------------------------------------------------- | 579 // ----------------------------------------------------------------------------- |
| 580 // JSLoadContext | 580 // JSLoadContext |
| 581 | 581 |
| 582 | 582 |
| (...skipping 419 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1002 Node* dummy = graph()->NewNode(javascript()->ToObject(), instanceOf, context, | 1002 Node* dummy = graph()->NewNode(javascript()->ToObject(), instanceOf, context, |
| 1003 frame_state, effect, control); | 1003 frame_state, effect, control); |
| 1004 Reduction r = Reduce(instanceOf); | 1004 Reduction r = Reduce(instanceOf); |
| 1005 ASSERT_FALSE(r.Changed()); | 1005 ASSERT_FALSE(r.Changed()); |
| 1006 ASSERT_EQ(instanceOf, dummy->InputAt(0)); | 1006 ASSERT_EQ(instanceOf, dummy->InputAt(0)); |
| 1007 } | 1007 } |
| 1008 | 1008 |
| 1009 } // namespace compiler | 1009 } // namespace compiler |
| 1010 } // namespace internal | 1010 } // namespace internal |
| 1011 } // namespace v8 | 1011 } // namespace v8 |
| OLD | NEW |