| 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 #ifndef V8_COMPILER_INSTRUCTION_SELECTOR_H_ | 5 #ifndef V8_COMPILER_INSTRUCTION_SELECTOR_H_ |
| 6 #define V8_COMPILER_INSTRUCTION_SELECTOR_H_ | 6 #define V8_COMPILER_INSTRUCTION_SELECTOR_H_ |
| 7 | 7 |
| 8 #include <map> | 8 #include <map> |
| 9 | 9 |
| 10 #include "src/compiler/common-operator.h" | 10 #include "src/compiler/common-operator.h" |
| (...skipping 50 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 61 | 61 |
| 62 void StartBlock(RpoNumber rpo); | 62 void StartBlock(RpoNumber rpo); |
| 63 void EndBlock(RpoNumber rpo); | 63 void EndBlock(RpoNumber rpo); |
| 64 void AddInstruction(Instruction* instr); | 64 void AddInstruction(Instruction* instr); |
| 65 | 65 |
| 66 // =========================================================================== | 66 // =========================================================================== |
| 67 // ============= Architecture-independent code emission methods. ============= | 67 // ============= Architecture-independent code emission methods. ============= |
| 68 // =========================================================================== | 68 // =========================================================================== |
| 69 | 69 |
| 70 Instruction* Emit(InstructionCode opcode, InstructionOperand output, | 70 Instruction* Emit(InstructionCode opcode, InstructionOperand output, |
| 71 size_t temp_count = 0, InstructionOperand* temps = NULL); | 71 size_t temp_count = 0, InstructionOperand* temps = nullptr); |
| 72 Instruction* Emit(InstructionCode opcode, InstructionOperand output, | 72 Instruction* Emit(InstructionCode opcode, InstructionOperand output, |
| 73 InstructionOperand a, size_t temp_count = 0, | 73 InstructionOperand a, size_t temp_count = 0, |
| 74 InstructionOperand* temps = NULL); | 74 InstructionOperand* temps = nullptr); |
| 75 Instruction* Emit(InstructionCode opcode, InstructionOperand output, | 75 Instruction* Emit(InstructionCode opcode, InstructionOperand output, |
| 76 InstructionOperand a, InstructionOperand b, | 76 InstructionOperand a, InstructionOperand b, |
| 77 size_t temp_count = 0, InstructionOperand* temps = NULL); | 77 size_t temp_count = 0, InstructionOperand* temps = nullptr); |
| 78 Instruction* Emit(InstructionCode opcode, InstructionOperand output, | 78 Instruction* Emit(InstructionCode opcode, InstructionOperand output, |
| 79 InstructionOperand a, InstructionOperand b, | 79 InstructionOperand a, InstructionOperand b, |
| 80 InstructionOperand c, size_t temp_count = 0, | 80 InstructionOperand c, size_t temp_count = 0, |
| 81 InstructionOperand* temps = NULL); | 81 InstructionOperand* temps = nullptr); |
| 82 Instruction* Emit(InstructionCode opcode, InstructionOperand output, | 82 Instruction* Emit(InstructionCode opcode, InstructionOperand output, |
| 83 InstructionOperand a, InstructionOperand b, | 83 InstructionOperand a, InstructionOperand b, |
| 84 InstructionOperand c, InstructionOperand d, | 84 InstructionOperand c, InstructionOperand d, |
| 85 size_t temp_count = 0, InstructionOperand* temps = NULL); | 85 size_t temp_count = 0, InstructionOperand* temps = nullptr); |
| 86 Instruction* Emit(InstructionCode opcode, InstructionOperand output, | 86 Instruction* Emit(InstructionCode opcode, InstructionOperand output, |
| 87 InstructionOperand a, InstructionOperand b, | 87 InstructionOperand a, InstructionOperand b, |
| 88 InstructionOperand c, InstructionOperand d, | 88 InstructionOperand c, InstructionOperand d, |
| 89 InstructionOperand e, size_t temp_count = 0, | 89 InstructionOperand e, size_t temp_count = 0, |
| 90 InstructionOperand* temps = NULL); | 90 InstructionOperand* temps = nullptr); |
| 91 Instruction* Emit(InstructionCode opcode, InstructionOperand output, | 91 Instruction* Emit(InstructionCode opcode, InstructionOperand output, |
| 92 InstructionOperand a, InstructionOperand b, | 92 InstructionOperand a, InstructionOperand b, |
| 93 InstructionOperand c, InstructionOperand d, | 93 InstructionOperand c, InstructionOperand d, |
| 94 InstructionOperand e, InstructionOperand f, | 94 InstructionOperand e, InstructionOperand f, |
| 95 size_t temp_count = 0, InstructionOperand* temps = NULL); | 95 size_t temp_count = 0, InstructionOperand* temps = nullptr); |
| 96 Instruction* Emit(InstructionCode opcode, size_t output_count, | 96 Instruction* Emit(InstructionCode opcode, size_t output_count, |
| 97 InstructionOperand* outputs, size_t input_count, | 97 InstructionOperand* outputs, size_t input_count, |
| 98 InstructionOperand* inputs, size_t temp_count = 0, | 98 InstructionOperand* inputs, size_t temp_count = 0, |
| 99 InstructionOperand* temps = NULL); | 99 InstructionOperand* temps = nullptr); |
| 100 Instruction* Emit(Instruction* instr); | 100 Instruction* Emit(Instruction* instr); |
| 101 | 101 |
| 102 // =========================================================================== | 102 // =========================================================================== |
| 103 // ============== Architecture-independent CPU feature methods. ============== | 103 // ============== Architecture-independent CPU feature methods. ============== |
| 104 // =========================================================================== | 104 // =========================================================================== |
| 105 | 105 |
| 106 class Features final { | 106 class Features final { |
| 107 public: | 107 public: |
| 108 Features() : bits_(0) {} | 108 Features() : bits_(0) {} |
| 109 explicit Features(unsigned bits) : bits_(bits) {} | 109 explicit Features(unsigned bits) : bits_(bits) {} |
| (...skipping 161 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 271 BoolVector used_; | 271 BoolVector used_; |
| 272 IntVector virtual_registers_; | 272 IntVector virtual_registers_; |
| 273 InstructionScheduler* scheduler_; | 273 InstructionScheduler* scheduler_; |
| 274 }; | 274 }; |
| 275 | 275 |
| 276 } // namespace compiler | 276 } // namespace compiler |
| 277 } // namespace internal | 277 } // namespace internal |
| 278 } // namespace v8 | 278 } // namespace v8 |
| 279 | 279 |
| 280 #endif // V8_COMPILER_INSTRUCTION_SELECTOR_H_ | 280 #endif // V8_COMPILER_INSTRUCTION_SELECTOR_H_ |
| OLD | NEW |