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 <algorithm> | 5 #include <algorithm> |
6 | 6 |
7 #include "src/base/adapters.h" | 7 #include "src/base/adapters.h" |
8 #include "src/compiler/instruction-selector-impl.h" | 8 #include "src/compiler/instruction-selector-impl.h" |
9 #include "src/compiler/node-matchers.h" | 9 #include "src/compiler/node-matchers.h" |
10 #include "src/compiler/node-properties.h" | 10 #include "src/compiler/node-properties.h" |
(...skipping 182 matching lines...) Loading... | |
193 InstructionOperand outputs[1]; | 193 InstructionOperand outputs[1]; |
194 outputs[0] = g.DefineAsRegister(node); | 194 outputs[0] = g.DefineAsRegister(node); |
195 InstructionOperand inputs[3]; | 195 InstructionOperand inputs[3]; |
196 size_t input_count = 0; | 196 size_t input_count = 0; |
197 AddressingMode mode = | 197 AddressingMode mode = |
198 g.GetEffectiveAddressMemoryOperand(node, inputs, &input_count); | 198 g.GetEffectiveAddressMemoryOperand(node, inputs, &input_count); |
199 InstructionCode code = opcode | AddressingModeField::encode(mode); | 199 InstructionCode code = opcode | AddressingModeField::encode(mode); |
200 Emit(code, 1, outputs, input_count, inputs); | 200 Emit(code, 1, outputs, input_count, inputs); |
201 } | 201 } |
202 | 202 |
203 void InstructionSelector::VisitProtectedLoad(Node* node) { | |
titzer
2016/09/08 17:06:36
Can we factor out a helper routine here?
Eric Holk
2016/09/08 21:11:56
I factored out the big switch statement. I think m
| |
204 LoadRepresentation load_rep = LoadRepresentationOf(node->op()); | |
205 X64OperandGenerator g(this); | |
206 | |
207 ArchOpcode opcode = kArchNop; | |
208 switch (load_rep.representation()) { | |
209 case MachineRepresentation::kFloat32: | |
210 opcode = kX64Movss; | |
211 break; | |
212 case MachineRepresentation::kFloat64: | |
213 opcode = kX64Movsd; | |
214 break; | |
215 case MachineRepresentation::kBit: // Fall through. | |
216 case MachineRepresentation::kWord8: | |
217 opcode = load_rep.IsSigned() ? kX64Movsxbl : kX64Movzxbl; | |
218 break; | |
219 case MachineRepresentation::kWord16: | |
220 opcode = load_rep.IsSigned() ? kX64Movsxwl : kX64Movzxwl; | |
221 break; | |
222 case MachineRepresentation::kWord32: | |
223 opcode = kX64TrapMovl; | |
224 break; | |
225 case MachineRepresentation::kTaggedSigned: // Fall through. | |
226 case MachineRepresentation::kTaggedPointer: // Fall through. | |
227 case MachineRepresentation::kTagged: // Fall through. | |
228 case MachineRepresentation::kWord64: | |
229 opcode = kX64Movq; | |
230 break; | |
231 case MachineRepresentation::kSimd128: // Fall through. | |
232 case MachineRepresentation::kNone: | |
233 UNREACHABLE(); | |
234 return; | |
235 } | |
236 | |
237 InstructionOperand outputs[1]; | |
238 outputs[0] = g.DefineAsRegister(node); | |
239 InstructionOperand inputs[4]; | |
240 size_t input_count = 0; | |
241 AddressingMode mode = | |
242 g.GetEffectiveAddressMemoryOperand(node, inputs, &input_count); | |
243 // Add the context parameter as an input. | |
244 inputs[input_count++] = g.UseUniqueRegister(node->InputAt(2)); | |
245 // Add the source position as an input | |
246 inputs[input_count++] = g.UseImmediate(node->InputAt(3)); | |
247 InstructionCode code = opcode | AddressingModeField::encode(mode); | |
248 Emit(code, 1, outputs, input_count, inputs); | |
249 } | |
203 | 250 |
204 void InstructionSelector::VisitStore(Node* node) { | 251 void InstructionSelector::VisitStore(Node* node) { |
205 X64OperandGenerator g(this); | 252 X64OperandGenerator g(this); |
206 Node* base = node->InputAt(0); | 253 Node* base = node->InputAt(0); |
207 Node* index = node->InputAt(1); | 254 Node* index = node->InputAt(1); |
208 Node* value = node->InputAt(2); | 255 Node* value = node->InputAt(2); |
209 | 256 |
210 StoreRepresentation store_rep = StoreRepresentationOf(node->op()); | 257 StoreRepresentation store_rep = StoreRepresentationOf(node->op()); |
211 WriteBarrierKind write_barrier_kind = store_rep.write_barrier_kind(); | 258 WriteBarrierKind write_barrier_kind = store_rep.write_barrier_kind(); |
212 MachineRepresentation rep = store_rep.representation(); | 259 MachineRepresentation rep = store_rep.representation(); |
(...skipping 2037 matching lines...) Loading... | |
2250 // static | 2297 // static |
2251 MachineOperatorBuilder::AlignmentRequirements | 2298 MachineOperatorBuilder::AlignmentRequirements |
2252 InstructionSelector::AlignmentRequirements() { | 2299 InstructionSelector::AlignmentRequirements() { |
2253 return MachineOperatorBuilder::AlignmentRequirements:: | 2300 return MachineOperatorBuilder::AlignmentRequirements:: |
2254 FullUnalignedAccessSupport(); | 2301 FullUnalignedAccessSupport(); |
2255 } | 2302 } |
2256 | 2303 |
2257 } // namespace compiler | 2304 } // namespace compiler |
2258 } // namespace internal | 2305 } // namespace internal |
2259 } // namespace v8 | 2306 } // namespace v8 |
OLD | NEW |