| 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/ast/scopes.h" | 5 #include "src/ast/scopes.h" |
| 6 #include "src/compiler/code-generator.h" | 6 #include "src/compiler/code-generator.h" |
| 7 #include "src/compiler/code-generator-impl.h" | 7 #include "src/compiler/code-generator-impl.h" |
| 8 #include "src/compiler/gap-resolver.h" | 8 #include "src/compiler/gap-resolver.h" |
| 9 #include "src/compiler/node-matchers.h" | 9 #include "src/compiler/node-matchers.h" |
| 10 #include "src/compiler/osr.h" | 10 #include "src/compiler/osr.h" |
| (...skipping 631 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 642 break; | 642 break; |
| 643 case kMips64MulHighU: | 643 case kMips64MulHighU: |
| 644 __ Mulhu(i.OutputRegister(), i.InputRegister(0), i.InputOperand(1)); | 644 __ Mulhu(i.OutputRegister(), i.InputRegister(0), i.InputOperand(1)); |
| 645 break; | 645 break; |
| 646 case kMips64DMulHigh: | 646 case kMips64DMulHigh: |
| 647 __ Dmulh(i.OutputRegister(), i.InputRegister(0), i.InputOperand(1)); | 647 __ Dmulh(i.OutputRegister(), i.InputRegister(0), i.InputOperand(1)); |
| 648 break; | 648 break; |
| 649 case kMips64Div: | 649 case kMips64Div: |
| 650 __ Div(i.OutputRegister(), i.InputRegister(0), i.InputOperand(1)); | 650 __ Div(i.OutputRegister(), i.InputRegister(0), i.InputOperand(1)); |
| 651 if (kArchVariant == kMips64r6) { | 651 if (kArchVariant == kMips64r6) { |
| 652 __ seleqz(i.OutputRegister(), i.InputRegister(0), i.InputRegister(0)); | 652 __ selnez(i.OutputRegister(), i.InputRegister(1), i.InputRegister(0)); |
| 653 } else { | 653 } else { |
| 654 __ Movz(i.OutputRegister(), i.InputRegister(1), i.InputRegister(1)); | 654 __ Movz(i.OutputRegister(), i.InputRegister(1), i.InputRegister(1)); |
| 655 } | 655 } |
| 656 break; | 656 break; |
| 657 case kMips64DivU: | 657 case kMips64DivU: |
| 658 __ Divu(i.OutputRegister(), i.InputRegister(0), i.InputOperand(1)); | 658 __ Divu(i.OutputRegister(), i.InputRegister(0), i.InputOperand(1)); |
| 659 if (kArchVariant == kMips64r6) { | 659 if (kArchVariant == kMips64r6) { |
| 660 __ seleqz(i.OutputRegister(), i.InputRegister(0), i.InputRegister(0)); | 660 __ selnez(i.OutputRegister(), i.InputRegister(1), i.InputRegister(0)); |
| 661 } else { | 661 } else { |
| 662 __ Movz(i.OutputRegister(), i.InputRegister(1), i.InputRegister(1)); | 662 __ Movz(i.OutputRegister(), i.InputRegister(1), i.InputRegister(1)); |
| 663 } | 663 } |
| 664 break; | 664 break; |
| 665 case kMips64Mod: | 665 case kMips64Mod: |
| 666 __ Mod(i.OutputRegister(), i.InputRegister(0), i.InputOperand(1)); | 666 __ Mod(i.OutputRegister(), i.InputRegister(0), i.InputOperand(1)); |
| 667 break; | 667 break; |
| 668 case kMips64ModU: | 668 case kMips64ModU: |
| 669 __ Modu(i.OutputRegister(), i.InputRegister(0), i.InputOperand(1)); | 669 __ Modu(i.OutputRegister(), i.InputRegister(0), i.InputOperand(1)); |
| 670 break; | 670 break; |
| 671 case kMips64Dmul: | 671 case kMips64Dmul: |
| 672 __ Dmul(i.OutputRegister(), i.InputRegister(0), i.InputOperand(1)); | 672 __ Dmul(i.OutputRegister(), i.InputRegister(0), i.InputOperand(1)); |
| 673 break; | 673 break; |
| 674 case kMips64Ddiv: | 674 case kMips64Ddiv: |
| 675 __ Ddiv(i.OutputRegister(), i.InputRegister(0), i.InputOperand(1)); | 675 __ Ddiv(i.OutputRegister(), i.InputRegister(0), i.InputOperand(1)); |
| 676 if (kArchVariant == kMips64r6) { | 676 if (kArchVariant == kMips64r6) { |
| 677 __ seleqz(i.OutputRegister(), i.InputRegister(0), i.InputRegister(0)); | 677 __ selnez(i.OutputRegister(), i.InputRegister(1), i.InputRegister(0)); |
| 678 } else { | 678 } else { |
| 679 __ Movz(i.OutputRegister(), i.InputRegister(1), i.InputRegister(1)); | 679 __ Movz(i.OutputRegister(), i.InputRegister(1), i.InputRegister(1)); |
| 680 } | 680 } |
| 681 break; | 681 break; |
| 682 case kMips64DdivU: | 682 case kMips64DdivU: |
| 683 __ Ddivu(i.OutputRegister(), i.InputRegister(0), i.InputOperand(1)); | 683 __ Ddivu(i.OutputRegister(), i.InputRegister(0), i.InputOperand(1)); |
| 684 if (kArchVariant == kMips64r6) { | 684 if (kArchVariant == kMips64r6) { |
| 685 __ seleqz(i.OutputRegister(), i.InputRegister(0), i.InputRegister(0)); | 685 __ selnez(i.OutputRegister(), i.InputRegister(1), i.InputRegister(0)); |
| 686 } else { | 686 } else { |
| 687 __ Movz(i.OutputRegister(), i.InputRegister(1), i.InputRegister(1)); | 687 __ Movz(i.OutputRegister(), i.InputRegister(1), i.InputRegister(1)); |
| 688 } | 688 } |
| 689 break; | 689 break; |
| 690 case kMips64Dmod: | 690 case kMips64Dmod: |
| 691 __ Dmod(i.OutputRegister(), i.InputRegister(0), i.InputOperand(1)); | 691 __ Dmod(i.OutputRegister(), i.InputRegister(0), i.InputOperand(1)); |
| 692 break; | 692 break; |
| 693 case kMips64DmodU: | 693 case kMips64DmodU: |
| 694 __ Dmodu(i.OutputRegister(), i.InputRegister(0), i.InputOperand(1)); | 694 __ Dmodu(i.OutputRegister(), i.InputRegister(0), i.InputOperand(1)); |
| 695 break; | 695 break; |
| (...skipping 1154 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1850 padding_size -= v8::internal::Assembler::kInstrSize; | 1850 padding_size -= v8::internal::Assembler::kInstrSize; |
| 1851 } | 1851 } |
| 1852 } | 1852 } |
| 1853 } | 1853 } |
| 1854 | 1854 |
| 1855 #undef __ | 1855 #undef __ |
| 1856 | 1856 |
| 1857 } // namespace compiler | 1857 } // namespace compiler |
| 1858 } // namespace internal | 1858 } // namespace internal |
| 1859 } // namespace v8 | 1859 } // namespace v8 |
| OLD | NEW |