| OLD | NEW |
| 1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 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_MIPS_MACRO_ASSEMBLER_MIPS_H_ | 5 #ifndef V8_MIPS_MACRO_ASSEMBLER_MIPS_H_ |
| 6 #define V8_MIPS_MACRO_ASSEMBLER_MIPS_H_ | 6 #define V8_MIPS_MACRO_ASSEMBLER_MIPS_H_ |
| 7 | 7 |
| 8 #include "src/assembler.h" | 8 #include "src/assembler.h" |
| 9 #include "src/globals.h" | 9 #include "src/globals.h" |
| 10 #include "src/mips64/assembler-mips64.h" | 10 #include "src/mips64/assembler-mips64.h" |
| (...skipping 60 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 71 // Allow programmer to use Branch Delay Slot of Branches, Jumps, Calls. | 71 // Allow programmer to use Branch Delay Slot of Branches, Jumps, Calls. |
| 72 enum BranchDelaySlot { | 72 enum BranchDelaySlot { |
| 73 USE_DELAY_SLOT, | 73 USE_DELAY_SLOT, |
| 74 PROTECT | 74 PROTECT |
| 75 }; | 75 }; |
| 76 | 76 |
| 77 // Flags used for the li macro-assembler function. | 77 // Flags used for the li macro-assembler function. |
| 78 enum LiFlags { | 78 enum LiFlags { |
| 79 // If the constant value can be represented in just 16 bits, then | 79 // If the constant value can be represented in just 16 bits, then |
| 80 // optimize the li to use a single instruction, rather than lui/ori/dsll | 80 // optimize the li to use a single instruction, rather than lui/ori/dsll |
| 81 // sequence. | 81 // sequence. A number of other optimizations that emits less than |
| 82 // maximum number of instructions exists. |
| 82 OPTIMIZE_SIZE = 0, | 83 OPTIMIZE_SIZE = 0, |
| 83 // Always use 6 instructions (lui/ori/dsll sequence), even if the constant | 84 // Always use 6 instructions (lui/ori/dsll sequence) for release 2 or 4 |
| 85 // instructions for release 6 (lui/ori/dahi/dati), even if the constant |
| 84 // could be loaded with just one, so that this value is patchable later. | 86 // could be loaded with just one, so that this value is patchable later. |
| 85 CONSTANT_SIZE = 1, | 87 CONSTANT_SIZE = 1, |
| 86 // For address loads only 4 instruction are required. Used to mark | 88 // For address loads only 4 instruction are required. Used to mark |
| 87 // constant load that will be used as address without relocation | 89 // constant load that will be used as address without relocation |
| 88 // information. It ensures predictable code size, so specific sites | 90 // information. It ensures predictable code size, so specific sites |
| 89 // in code are patchable. | 91 // in code are patchable. |
| 90 ADDRESS_LOAD = 2 | 92 ADDRESS_LOAD = 2 |
| 91 }; | 93 }; |
| 92 | 94 |
| 93 | |
| 94 enum RememberedSetAction { EMIT_REMEMBERED_SET, OMIT_REMEMBERED_SET }; | 95 enum RememberedSetAction { EMIT_REMEMBERED_SET, OMIT_REMEMBERED_SET }; |
| 95 enum SmiCheck { INLINE_SMI_CHECK, OMIT_SMI_CHECK }; | 96 enum SmiCheck { INLINE_SMI_CHECK, OMIT_SMI_CHECK }; |
| 96 enum PointersToHereCheck { | 97 enum PointersToHereCheck { |
| 97 kPointersToHereMaybeInteresting, | 98 kPointersToHereMaybeInteresting, |
| 98 kPointersToHereAreAlwaysInteresting | 99 kPointersToHereAreAlwaysInteresting |
| 99 }; | 100 }; |
| 100 enum RAStatus { kRAHasNotBeenSaved, kRAHasBeenSaved }; | 101 enum RAStatus { kRAHasNotBeenSaved, kRAHasBeenSaved }; |
| 101 | 102 |
| 102 Register GetRegisterThatIsNotOneOf(Register reg1, | 103 Register GetRegisterThatIsNotOneOf(Register reg1, |
| 103 Register reg2 = no_reg, | 104 Register reg2 = no_reg, |
| (...skipping 628 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 732 void Sd(Register rd, const MemOperand& rs); | 733 void Sd(Register rd, const MemOperand& rs); |
| 733 | 734 |
| 734 void Lwc1(FPURegister fd, const MemOperand& src); | 735 void Lwc1(FPURegister fd, const MemOperand& src); |
| 735 void Swc1(FPURegister fs, const MemOperand& dst); | 736 void Swc1(FPURegister fs, const MemOperand& dst); |
| 736 | 737 |
| 737 void Ldc1(FPURegister fd, const MemOperand& src); | 738 void Ldc1(FPURegister fd, const MemOperand& src); |
| 738 void Sdc1(FPURegister fs, const MemOperand& dst); | 739 void Sdc1(FPURegister fs, const MemOperand& dst); |
| 739 | 740 |
| 740 // Load int32 in the rd register. | 741 // Load int32 in the rd register. |
| 741 void li(Register rd, Operand j, LiFlags mode = OPTIMIZE_SIZE); | 742 void li(Register rd, Operand j, LiFlags mode = OPTIMIZE_SIZE); |
| 742 inline bool LiLower32BitHelper(Register rd, Operand j); | 743 inline void LiLower32BitHelper(Register rd, Operand j); |
| 743 inline void li(Register rd, int64_t j, LiFlags mode = OPTIMIZE_SIZE) { | 744 inline void li(Register rd, int64_t j, LiFlags mode = OPTIMIZE_SIZE) { |
| 744 li(rd, Operand(j), mode); | 745 li(rd, Operand(j), mode); |
| 745 } | 746 } |
| 746 void li(Register dst, Handle<Object> value, LiFlags mode = OPTIMIZE_SIZE); | 747 void li(Register dst, Handle<Object> value, LiFlags mode = OPTIMIZE_SIZE); |
| 747 | 748 |
| 748 // Push multiple registers on the stack. | 749 // Push multiple registers on the stack. |
| 749 // Registers are saved in numerical order, with higher numbered registers | 750 // Registers are saved in numerical order, with higher numbered registers |
| 750 // saved in higher memory addresses. | 751 // saved in higher memory addresses. |
| 751 void MultiPush(RegList regs); | 752 void MultiPush(RegList regs); |
| 752 void MultiPushReversed(RegList regs); | 753 void MultiPushReversed(RegList regs); |
| (...skipping 1211 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1964 dd(GetLabelFunction(index)); | 1965 dd(GetLabelFunction(index)); |
| 1965 } | 1966 } |
| 1966 } | 1967 } |
| 1967 | 1968 |
| 1968 #define ACCESS_MASM(masm) masm-> | 1969 #define ACCESS_MASM(masm) masm-> |
| 1969 | 1970 |
| 1970 } // namespace internal | 1971 } // namespace internal |
| 1971 } // namespace v8 | 1972 } // namespace v8 |
| 1972 | 1973 |
| 1973 #endif // V8_MIPS_MACRO_ASSEMBLER_MIPS_H_ | 1974 #endif // V8_MIPS_MACRO_ASSEMBLER_MIPS_H_ |
| OLD | NEW |