Index: src/compiler/arm64/instruction-scheduler-arm64.cc |
diff --git a/src/compiler/arm64/instruction-scheduler-arm64.cc b/src/compiler/arm64/instruction-scheduler-arm64.cc |
index ca372993b84e616f6de152753352745f7fba5a6c..4320d56ea4fd8c9d3cf88bf707051f232147d71a 100644 |
--- a/src/compiler/arm64/instruction-scheduler-arm64.cc |
+++ b/src/compiler/arm64/instruction-scheduler-arm64.cc |
@@ -176,23 +176,46 @@ int InstructionScheduler::GetInstructionLatency(const Instruction* instr) { |
// Basic latency modeling for arm64 instructions. They have been determined |
// in an empirical way. |
switch (instr->arch_opcode()) { |
- case kArm64Float32ToFloat64: |
- case kArm64Float64ToFloat32: |
- case kArm64Float64ToInt32: |
- case kArm64Float64ToUint32: |
- case kArm64Int32ToFloat64: |
- case kArm64Uint32ToFloat64: |
- return 3; |
- |
- case kArm64Float64Add: |
- case kArm64Float64Sub: |
- return 2; |
- |
- case kArm64Float64Mul: |
- return 3; |
+ case kArm64Add: |
+ case kArm64Add32: |
+ case kArm64And: |
+ case kArm64And32: |
+ case kArm64Bic: |
+ case kArm64Bic32: |
+ case kArm64Cmn: |
+ case kArm64Cmn32: |
+ case kArm64Cmp: |
+ case kArm64Cmp32: |
+ case kArm64Eon: |
+ case kArm64Eon32: |
+ case kArm64Eor: |
+ case kArm64Eor32: |
+ case kArm64Not: |
+ case kArm64Not32: |
+ case kArm64Or: |
+ case kArm64Or32: |
+ case kArm64Orn: |
+ case kArm64Orn32: |
+ case kArm64Sub: |
+ case kArm64Sub32: |
+ case kArm64Tst: |
+ case kArm64Tst32: |
+ if (instr->addressing_mode() != kMode_None) { |
+ return 3; |
+ } else { |
+ return 1; |
+ } |
- case kArm64Float64Div: |
- return 6; |
+ case kArm64Clz: |
+ case kArm64Clz32: |
+ case kArm64Sbfx32: |
+ case kArm64Sxtb32: |
+ case kArm64Sxth32: |
+ case kArm64Sxtw: |
+ case kArm64Ubfiz32: |
+ case kArm64Ubfx: |
+ case kArm64Ubfx32: |
+ return 1; |
case kArm64Lsl: |
case kArm64Lsl32: |
@@ -202,7 +225,17 @@ int InstructionScheduler::GetInstructionLatency(const Instruction* instr) { |
case kArm64Asr32: |
case kArm64Ror: |
case kArm64Ror32: |
- return 3; |
+ return 1; |
+ |
+ case kArm64Ldr: |
+ case kArm64LdrD: |
+ case kArm64LdrS: |
+ case kArm64LdrW: |
+ case kArm64Ldrb: |
+ case kArm64Ldrh: |
+ case kArm64Ldrsb: |
+ case kArm64Ldrsh: |
+ return 11; |
case kCheckedLoadInt8: |
case kCheckedLoadUint8: |
@@ -212,18 +245,94 @@ int InstructionScheduler::GetInstructionLatency(const Instruction* instr) { |
case kCheckedLoadWord64: |
case kCheckedLoadFloat32: |
case kCheckedLoadFloat64: |
- case kArm64LdrS: |
- case kArm64LdrD: |
- case kArm64Ldrb: |
- case kArm64Ldrsb: |
- case kArm64Ldrh: |
- case kArm64Ldrsh: |
- case kArm64LdrW: |
- case kArm64Ldr: |
return 5; |
- default: |
+ case kArm64Str: |
+ case kArm64StrD: |
+ case kArm64StrS: |
+ case kArm64StrW: |
+ case kArm64Strb: |
+ case kArm64Strh: |
+ return 1; |
+ |
+ case kCheckedStoreWord8: |
+ case kCheckedStoreWord16: |
+ case kCheckedStoreWord32: |
+ case kCheckedStoreWord64: |
+ case kCheckedStoreFloat32: |
+ case kCheckedStoreFloat64: |
return 1; |
+ |
+ case kArm64Madd32: |
+ case kArm64Mneg32: |
+ case kArm64Msub32: |
+ case kArm64Mul32: |
+ return 3; |
+ |
+ case kArm64Madd: |
+ case kArm64Mneg: |
+ case kArm64Msub: |
+ case kArm64Mul: |
+ return 5; |
+ |
+ case kArm64Idiv32: |
+ case kArm64Udiv32: |
+ return 12; |
+ |
+ case kArm64Idiv: |
+ case kArm64Udiv: |
+ return 20; |
+ |
+ case kArm64Float32Add: |
+ case kArm64Float32Sub: |
+ case kArm64Float64Add: |
+ case kArm64Float64Sub: |
+ return 5; |
+ |
+ case kArm64Float32Abs: |
+ case kArm64Float32Cmp: |
+ case kArm64Float64Abs: |
+ case kArm64Float64Cmp: |
+ case kArm64Float64Neg: |
+ return 3; |
+ |
+ case kArm64Float32Div: |
+ case kArm64Float32Sqrt: |
+ return 12; |
+ |
+ case kArm64Float64Div: |
+ case kArm64Float64Sqrt: |
+ return 19; |
+ |
+ case kArm64Float32RoundDown: |
+ case kArm64Float32RoundTiesEven: |
+ case kArm64Float32RoundTruncate: |
+ case kArm64Float32RoundUp: |
+ case kArm64Float64RoundDown: |
+ case kArm64Float64RoundTiesAway: |
+ case kArm64Float64RoundTiesEven: |
+ case kArm64Float64RoundTruncate: |
+ case kArm64Float64RoundUp: |
+ return 5; |
+ |
+ case kArm64Float32ToFloat64: |
+ case kArm64Float64ToFloat32: |
+ case kArm64Float64ToInt32: |
+ case kArm64Float64ToUint32: |
+ case kArm64Float32ToInt64: |
+ case kArm64Float64ToInt64: |
+ case kArm64Float32ToUint64: |
+ case kArm64Float64ToUint64: |
+ case kArm64Int32ToFloat64: |
+ case kArm64Int64ToFloat32: |
+ case kArm64Int64ToFloat64: |
+ case kArm64Uint32ToFloat64: |
+ case kArm64Uint64ToFloat32: |
+ case kArm64Uint64ToFloat64: |
+ return 5; |
+ |
+ default: |
+ return 2; |
} |
} |