| 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 133 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 144 case MachineRepresentation::kWord8: | 144 case MachineRepresentation::kWord8: |
| 145 opcode = load_rep.IsSigned() ? kX87Movsxbl : kX87Movzxbl; | 145 opcode = load_rep.IsSigned() ? kX87Movsxbl : kX87Movzxbl; |
| 146 break; | 146 break; |
| 147 case MachineRepresentation::kWord16: | 147 case MachineRepresentation::kWord16: |
| 148 opcode = load_rep.IsSigned() ? kX87Movsxwl : kX87Movzxwl; | 148 opcode = load_rep.IsSigned() ? kX87Movsxwl : kX87Movzxwl; |
| 149 break; | 149 break; |
| 150 case MachineRepresentation::kTagged: // Fall through. | 150 case MachineRepresentation::kTagged: // Fall through. |
| 151 case MachineRepresentation::kWord32: | 151 case MachineRepresentation::kWord32: |
| 152 opcode = kX87Movl; | 152 opcode = kX87Movl; |
| 153 break; | 153 break; |
| 154 case MachineRepresentation::kWord64: // Fall through. | 154 case MachineRepresentation::kWord64: // Fall through. |
| 155 case MachineRepresentation::kSimd128: // Fall through. |
| 155 case MachineRepresentation::kNone: | 156 case MachineRepresentation::kNone: |
| 156 UNREACHABLE(); | 157 UNREACHABLE(); |
| 157 return; | 158 return; |
| 158 } | 159 } |
| 159 | 160 |
| 160 X87OperandGenerator g(this); | 161 X87OperandGenerator g(this); |
| 161 InstructionOperand outputs[1]; | 162 InstructionOperand outputs[1]; |
| 162 outputs[0] = g.DefineAsRegister(node); | 163 outputs[0] = g.DefineAsRegister(node); |
| 163 InstructionOperand inputs[3]; | 164 InstructionOperand inputs[3]; |
| 164 size_t input_count = 0; | 165 size_t input_count = 0; |
| (...skipping 64 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 229 case MachineRepresentation::kWord8: | 230 case MachineRepresentation::kWord8: |
| 230 opcode = kX87Movb; | 231 opcode = kX87Movb; |
| 231 break; | 232 break; |
| 232 case MachineRepresentation::kWord16: | 233 case MachineRepresentation::kWord16: |
| 233 opcode = kX87Movw; | 234 opcode = kX87Movw; |
| 234 break; | 235 break; |
| 235 case MachineRepresentation::kTagged: // Fall through. | 236 case MachineRepresentation::kTagged: // Fall through. |
| 236 case MachineRepresentation::kWord32: | 237 case MachineRepresentation::kWord32: |
| 237 opcode = kX87Movl; | 238 opcode = kX87Movl; |
| 238 break; | 239 break; |
| 239 case MachineRepresentation::kWord64: // Fall through. | 240 case MachineRepresentation::kWord64: // Fall through. |
| 241 case MachineRepresentation::kSimd128: // Fall through. |
| 240 case MachineRepresentation::kNone: | 242 case MachineRepresentation::kNone: |
| 241 UNREACHABLE(); | 243 UNREACHABLE(); |
| 242 return; | 244 return; |
| 243 } | 245 } |
| 244 | 246 |
| 245 InstructionOperand val; | 247 InstructionOperand val; |
| 246 if (g.CanBeImmediate(value)) { | 248 if (g.CanBeImmediate(value)) { |
| 247 val = g.UseImmediate(value); | 249 val = g.UseImmediate(value); |
| 248 } else if (rep == MachineRepresentation::kWord8 || | 250 } else if (rep == MachineRepresentation::kWord8 || |
| 249 rep == MachineRepresentation::kBit) { | 251 rep == MachineRepresentation::kBit) { |
| (...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 281 break; | 283 break; |
| 282 case MachineRepresentation::kWord32: | 284 case MachineRepresentation::kWord32: |
| 283 opcode = kCheckedLoadWord32; | 285 opcode = kCheckedLoadWord32; |
| 284 break; | 286 break; |
| 285 case MachineRepresentation::kFloat32: | 287 case MachineRepresentation::kFloat32: |
| 286 opcode = kCheckedLoadFloat32; | 288 opcode = kCheckedLoadFloat32; |
| 287 break; | 289 break; |
| 288 case MachineRepresentation::kFloat64: | 290 case MachineRepresentation::kFloat64: |
| 289 opcode = kCheckedLoadFloat64; | 291 opcode = kCheckedLoadFloat64; |
| 290 break; | 292 break; |
| 291 case MachineRepresentation::kBit: // Fall through. | 293 case MachineRepresentation::kBit: // Fall through. |
| 292 case MachineRepresentation::kTagged: // Fall through. | 294 case MachineRepresentation::kTagged: // Fall through. |
| 293 case MachineRepresentation::kWord64: // Fall through. | 295 case MachineRepresentation::kWord64: // Fall through. |
| 296 case MachineRepresentation::kSimd128: // Fall through. |
| 294 case MachineRepresentation::kNone: | 297 case MachineRepresentation::kNone: |
| 295 UNREACHABLE(); | 298 UNREACHABLE(); |
| 296 return; | 299 return; |
| 297 } | 300 } |
| 298 InstructionOperand offset_operand = g.UseRegister(offset); | 301 InstructionOperand offset_operand = g.UseRegister(offset); |
| 299 InstructionOperand length_operand = | 302 InstructionOperand length_operand = |
| 300 g.CanBeImmediate(length) ? g.UseImmediate(length) : g.UseRegister(length); | 303 g.CanBeImmediate(length) ? g.UseImmediate(length) : g.UseRegister(length); |
| 301 if (g.CanBeImmediate(buffer)) { | 304 if (g.CanBeImmediate(buffer)) { |
| 302 Emit(opcode | AddressingModeField::encode(kMode_MRI), | 305 Emit(opcode | AddressingModeField::encode(kMode_MRI), |
| 303 g.DefineAsRegister(node), offset_operand, length_operand, | 306 g.DefineAsRegister(node), offset_operand, length_operand, |
| (...skipping 23 matching lines...) Expand all Loading... |
| 327 break; | 330 break; |
| 328 case MachineRepresentation::kWord32: | 331 case MachineRepresentation::kWord32: |
| 329 opcode = kCheckedStoreWord32; | 332 opcode = kCheckedStoreWord32; |
| 330 break; | 333 break; |
| 331 case MachineRepresentation::kFloat32: | 334 case MachineRepresentation::kFloat32: |
| 332 opcode = kCheckedStoreFloat32; | 335 opcode = kCheckedStoreFloat32; |
| 333 break; | 336 break; |
| 334 case MachineRepresentation::kFloat64: | 337 case MachineRepresentation::kFloat64: |
| 335 opcode = kCheckedStoreFloat64; | 338 opcode = kCheckedStoreFloat64; |
| 336 break; | 339 break; |
| 337 case MachineRepresentation::kBit: // Fall through. | 340 case MachineRepresentation::kBit: // Fall through. |
| 338 case MachineRepresentation::kTagged: // Fall through. | 341 case MachineRepresentation::kTagged: // Fall through. |
| 339 case MachineRepresentation::kWord64: // Fall through. | 342 case MachineRepresentation::kWord64: // Fall through. |
| 343 case MachineRepresentation::kSimd128: // Fall through. |
| 340 case MachineRepresentation::kNone: | 344 case MachineRepresentation::kNone: |
| 341 UNREACHABLE(); | 345 UNREACHABLE(); |
| 342 return; | 346 return; |
| 343 } | 347 } |
| 344 InstructionOperand value_operand = | 348 InstructionOperand value_operand = |
| 345 g.CanBeImmediate(value) ? g.UseImmediate(value) | 349 g.CanBeImmediate(value) ? g.UseImmediate(value) |
| 346 : ((rep == MachineRepresentation::kWord8 || | 350 : ((rep == MachineRepresentation::kWord8 || |
| 347 rep == MachineRepresentation::kBit) | 351 rep == MachineRepresentation::kBit) |
| 348 ? g.UseByteRegister(value) | 352 ? g.UseByteRegister(value) |
| 349 : g.UseRegister(value)); | 353 : g.UseRegister(value)); |
| (...skipping 1016 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1366 MachineOperatorBuilder::kFloat32RoundTruncate | | 1370 MachineOperatorBuilder::kFloat32RoundTruncate | |
| 1367 MachineOperatorBuilder::kFloat64RoundTruncate | | 1371 MachineOperatorBuilder::kFloat64RoundTruncate | |
| 1368 MachineOperatorBuilder::kFloat32RoundTiesEven | | 1372 MachineOperatorBuilder::kFloat32RoundTiesEven | |
| 1369 MachineOperatorBuilder::kFloat64RoundTiesEven; | 1373 MachineOperatorBuilder::kFloat64RoundTiesEven; |
| 1370 return flags; | 1374 return flags; |
| 1371 } | 1375 } |
| 1372 | 1376 |
| 1373 } // namespace compiler | 1377 } // namespace compiler |
| 1374 } // namespace internal | 1378 } // namespace internal |
| 1375 } // namespace v8 | 1379 } // namespace v8 |
| OLD | NEW |