OLD | NEW |
1 // Copyright 2016 the V8 project authors. All rights reserved. | 1 // Copyright 2016 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 #ifndef V8_CODE_STUB_ASSEMBLER_H_ | 5 #ifndef V8_CODE_STUB_ASSEMBLER_H_ |
6 #define V8_CODE_STUB_ASSEMBLER_H_ | 6 #define V8_CODE_STUB_ASSEMBLER_H_ |
7 | 7 |
8 #include <functional> | 8 #include <functional> |
9 | 9 |
10 #include "src/compiler/code-assembler.h" | 10 #include "src/compiler/code-assembler.h" |
(...skipping 638 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
649 kTruncateMinusZero, | 649 kTruncateMinusZero, |
650 }; | 650 }; |
651 | 651 |
652 // Convert any object to an Integer. | 652 // Convert any object to an Integer. |
653 compiler::Node* ToInteger(compiler::Node* context, compiler::Node* input, | 653 compiler::Node* ToInteger(compiler::Node* context, compiler::Node* input, |
654 ToIntegerTruncationMode mode = kNoTruncation); | 654 ToIntegerTruncationMode mode = kNoTruncation); |
655 | 655 |
656 // Returns a node that contains a decoded (unsigned!) value of a bit | 656 // Returns a node that contains a decoded (unsigned!) value of a bit |
657 // field |T| in |word32|. Returns result as an uint32 node. | 657 // field |T| in |word32|. Returns result as an uint32 node. |
658 template <typename T> | 658 template <typename T> |
659 compiler::Node* BitFieldDecode(compiler::Node* word32) { | 659 compiler::Node* DecodeWord32(compiler::Node* word32) { |
660 return BitFieldDecode(word32, T::kShift, T::kMask); | 660 return DecodeWord32(word32, T::kShift, T::kMask); |
| 661 } |
| 662 |
| 663 // Returns a node that contains a decoded (unsigned!) value of a bit |
| 664 // field |T| in |word|. Returns result as a word-size node. |
| 665 template <typename T> |
| 666 compiler::Node* DecodeWord(compiler::Node* word) { |
| 667 return DecodeWord(word, T::kShift, T::kMask); |
661 } | 668 } |
662 | 669 |
663 // Returns a node that contains a decoded (unsigned!) value of a bit | 670 // Returns a node that contains a decoded (unsigned!) value of a bit |
664 // field |T| in |word32|. Returns result as a word-size node. | 671 // field |T| in |word32|. Returns result as a word-size node. |
665 template <typename T> | 672 template <typename T> |
666 compiler::Node* BitFieldDecodeWord(compiler::Node* word32) { | 673 compiler::Node* DecodeWordFromWord32(compiler::Node* word32) { |
667 return ChangeUint32ToWord(BitFieldDecode<T>(word32)); | 674 return DecodeWord<T>(ChangeUint32ToWord(word32)); |
668 } | 675 } |
669 | 676 |
670 // Decodes an unsigned (!) value from |word32| to an uint32 node. | 677 // Decodes an unsigned (!) value from |word32| to an uint32 node. |
671 compiler::Node* BitFieldDecode(compiler::Node* word32, uint32_t shift, | 678 compiler::Node* DecodeWord32(compiler::Node* word32, uint32_t shift, |
672 uint32_t mask); | 679 uint32_t mask); |
| 680 |
| 681 // Decodes an unsigned (!) value from |word| to a word-size node. |
| 682 compiler::Node* DecodeWord(compiler::Node* word, uint32_t shift, |
| 683 uint32_t mask); |
| 684 |
| 685 // Returns true if any of the |T|'s bits in given |word32| are set. |
| 686 template <typename T> |
| 687 compiler::Node* IsSetWord32(compiler::Node* word32) { |
| 688 return Word32NotEqual(Word32And(word32, Int32Constant(T::kMask)), |
| 689 Int32Constant(0)); |
| 690 } |
| 691 |
| 692 // Returns true if any of the |T|'s bits in given |word| are set. |
| 693 template <typename T> |
| 694 compiler::Node* IsSetWord(compiler::Node* word) { |
| 695 return WordNotEqual(WordAnd(word, IntPtrConstant(T::kMask)), |
| 696 IntPtrConstant(0)); |
| 697 } |
673 | 698 |
674 void SetCounter(StatsCounter* counter, int value); | 699 void SetCounter(StatsCounter* counter, int value); |
675 void IncrementCounter(StatsCounter* counter, int delta); | 700 void IncrementCounter(StatsCounter* counter, int delta); |
676 void DecrementCounter(StatsCounter* counter, int delta); | 701 void DecrementCounter(StatsCounter* counter, int delta); |
677 | 702 |
678 // Generates "if (false) goto label" code. Useful for marking a label as | 703 // Generates "if (false) goto label" code. Useful for marking a label as |
679 // "live" to avoid assertion failures during graph building. In the resulting | 704 // "live" to avoid assertion failures during graph building. In the resulting |
680 // code this check will be eliminated. | 705 // code this check will be eliminated. |
681 void Use(Label* label); | 706 void Use(Label* label); |
682 | 707 |
(...skipping 412 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1095 static const int kElementLoopUnrollThreshold = 8; | 1120 static const int kElementLoopUnrollThreshold = 8; |
1096 }; | 1121 }; |
1097 | 1122 |
1098 #define CSA_ASSERT(x) Assert((x), #x, __FILE__, __LINE__) | 1123 #define CSA_ASSERT(x) Assert((x), #x, __FILE__, __LINE__) |
1099 | 1124 |
1100 DEFINE_OPERATORS_FOR_FLAGS(CodeStubAssembler::AllocationFlags); | 1125 DEFINE_OPERATORS_FOR_FLAGS(CodeStubAssembler::AllocationFlags); |
1101 | 1126 |
1102 } // namespace internal | 1127 } // namespace internal |
1103 } // namespace v8 | 1128 } // namespace v8 |
1104 #endif // V8_CODE_STUB_ASSEMBLER_H_ | 1129 #endif // V8_CODE_STUB_ASSEMBLER_H_ |
OLD | NEW |