summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Target/PowerPC/PPCScheduleA2.td
diff options
context:
space:
mode:
authorHal Finkel <hfinkel@anl.gov>2013-04-05 05:34:08 +0000
committerHal Finkel <hfinkel@anl.gov>2013-04-05 05:34:08 +0000
commit5fde1b033e67bdc5d2df5f3423ed4c638ece61e6 (patch)
treed12dfa8f1a54313e0bec053f32eb1b43d0bbb9c5 /llvm/lib/Target/PowerPC/PPCScheduleA2.td
parent1218a40c92caf3b18ddc4dcd797a8514632b12de (diff)
downloadbcm5719-llvm-5fde1b033e67bdc5d2df5f3423ed4c638ece61e6.tar.gz
bcm5719-llvm-5fde1b033e67bdc5d2df5f3423ed4c638ece61e6.zip
Add a SchedMachineModel for the PPC A2
llvm-svn: 178848
Diffstat (limited to 'llvm/lib/Target/PowerPC/PPCScheduleA2.td')
-rw-r--r--llvm/lib/Target/PowerPC/PPCScheduleA2.td15
1 files changed, 15 insertions, 0 deletions
diff --git a/llvm/lib/Target/PowerPC/PPCScheduleA2.td b/llvm/lib/Target/PowerPC/PPCScheduleA2.td
index ba63b5cd8fa..ae084aa0e8c 100644
--- a/llvm/lib/Target/PowerPC/PPCScheduleA2.td
+++ b/llvm/lib/Target/PowerPC/PPCScheduleA2.td
@@ -749,3 +749,18 @@ def PPCA2Itineraries : ProcessorItineraries<
[15, 7],
[FPR_Bypass, FPR_Bypass]>
]>;
+
+// ===---------------------------------------------------------------------===//
+// A2 machine model for scheduling and other instruction cost heuristics.
+
+def PPCA2Model : SchedMachineModel {
+ let IssueWidth = 1; // 2 micro-ops are dispatched per cycle.
+ let MinLatency = -1; // OperandCycles are interpreted as MinLatency.
+ let LoadLatency = 6; // Optimistic load latency assuming bypass.
+ // This is overriden by OperandCycles if the
+ // Itineraries are queried instead.
+ let MispredictPenalty = 6;
+
+ let Itineraries = PPCA2Itineraries;
+}
+
OpenPOWER on IntegriCloud