| 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/base/adapters.h" | 5 #include "src/base/adapters.h" |
| 6 #include "src/compiler/instruction-selector-impl.h" | 6 #include "src/compiler/instruction-selector-impl.h" |
| 7 #include "src/compiler/node-matchers.h" | 7 #include "src/compiler/node-matchers.h" |
| 8 #include "src/compiler/node-properties.h" | 8 #include "src/compiler/node-properties.h" |
| 9 | 9 |
| 10 namespace v8 { | 10 namespace v8 { |
| (...skipping 156 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 167 Emit(code, 1, outputs, input_count, inputs); | 167 Emit(code, 1, outputs, input_count, inputs); |
| 168 } | 168 } |
| 169 | 169 |
| 170 | 170 |
| 171 void InstructionSelector::VisitStore(Node* node) { | 171 void InstructionSelector::VisitStore(Node* node) { |
| 172 X87OperandGenerator g(this); | 172 X87OperandGenerator g(this); |
| 173 Node* base = node->InputAt(0); | 173 Node* base = node->InputAt(0); |
| 174 Node* index = node->InputAt(1); | 174 Node* index = node->InputAt(1); |
| 175 Node* value = node->InputAt(2); | 175 Node* value = node->InputAt(2); |
| 176 | 176 |
| 177 StoreRepresentation store_rep = OpParameter<StoreRepresentation>(node); | 177 StoreRepresentation store_rep = StoreRepresentationOf(node->op()); |
| 178 WriteBarrierKind write_barrier_kind = store_rep.write_barrier_kind(); | 178 WriteBarrierKind write_barrier_kind = store_rep.write_barrier_kind(); |
| 179 MachineRepresentation rep = store_rep.machine_type().representation(); | 179 MachineRepresentation rep = store_rep.representation(); |
| 180 | 180 |
| 181 if (write_barrier_kind != kNoWriteBarrier) { | 181 if (write_barrier_kind != kNoWriteBarrier) { |
| 182 DCHECK_EQ(MachineRepresentation::kTagged, rep); | 182 DCHECK_EQ(MachineRepresentation::kTagged, rep); |
| 183 AddressingMode addressing_mode; | 183 AddressingMode addressing_mode; |
| 184 InstructionOperand inputs[3]; | 184 InstructionOperand inputs[3]; |
| 185 size_t input_count = 0; | 185 size_t input_count = 0; |
| 186 inputs[input_count++] = g.UseUniqueRegister(base); | 186 inputs[input_count++] = g.UseUniqueRegister(base); |
| 187 if (g.CanBeImmediate(index)) { | 187 if (g.CanBeImmediate(index)) { |
| 188 inputs[input_count++] = g.UseImmediate(index); | 188 inputs[input_count++] = g.UseImmediate(index); |
| 189 addressing_mode = kMode_MRI; | 189 addressing_mode = kMode_MRI; |
| (...skipping 108 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 298 offset_operand, g.UseImmediate(buffer)); | 298 offset_operand, g.UseImmediate(buffer)); |
| 299 } else { | 299 } else { |
| 300 Emit(opcode | AddressingModeField::encode(kMode_MR1), | 300 Emit(opcode | AddressingModeField::encode(kMode_MR1), |
| 301 g.DefineAsRegister(node), offset_operand, length_operand, | 301 g.DefineAsRegister(node), offset_operand, length_operand, |
| 302 g.UseRegister(buffer), offset_operand); | 302 g.UseRegister(buffer), offset_operand); |
| 303 } | 303 } |
| 304 } | 304 } |
| 305 | 305 |
| 306 | 306 |
| 307 void InstructionSelector::VisitCheckedStore(Node* node) { | 307 void InstructionSelector::VisitCheckedStore(Node* node) { |
| 308 MachineRepresentation rep = | 308 MachineRepresentation rep = CheckedStoreRepresentationOf(node->op()); |
| 309 CheckedStoreRepresentationOf(node->op()).representation(); | |
| 310 X87OperandGenerator g(this); | 309 X87OperandGenerator g(this); |
| 311 Node* const buffer = node->InputAt(0); | 310 Node* const buffer = node->InputAt(0); |
| 312 Node* const offset = node->InputAt(1); | 311 Node* const offset = node->InputAt(1); |
| 313 Node* const length = node->InputAt(2); | 312 Node* const length = node->InputAt(2); |
| 314 Node* const value = node->InputAt(3); | 313 Node* const value = node->InputAt(3); |
| 315 ArchOpcode opcode; | 314 ArchOpcode opcode; |
| 316 switch (rep) { | 315 switch (rep) { |
| 317 case MachineRepresentation::kWord8: | 316 case MachineRepresentation::kWord8: |
| 318 opcode = kCheckedStoreWord8; | 317 opcode = kCheckedStoreWord8; |
| 319 break; | 318 break; |
| (...skipping 1007 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1327 MachineOperatorBuilder::kFloat32RoundTruncate | | 1326 MachineOperatorBuilder::kFloat32RoundTruncate | |
| 1328 MachineOperatorBuilder::kFloat64RoundTruncate | | 1327 MachineOperatorBuilder::kFloat64RoundTruncate | |
| 1329 MachineOperatorBuilder::kFloat32RoundTiesEven | | 1328 MachineOperatorBuilder::kFloat32RoundTiesEven | |
| 1330 MachineOperatorBuilder::kFloat64RoundTiesEven; | 1329 MachineOperatorBuilder::kFloat64RoundTiesEven; |
| 1331 return flags; | 1330 return flags; |
| 1332 } | 1331 } |
| 1333 | 1332 |
| 1334 } // namespace compiler | 1333 } // namespace compiler |
| 1335 } // namespace internal | 1334 } // namespace internal |
| 1336 } // namespace v8 | 1335 } // namespace v8 |
| OLD | NEW |