Updates include:
- More accurate ALU pipeline latencies.
- Forwarding between the ALU, Integer MAC, and Integer Div pipes.
- Proper Vector Load/Store latencies with hazards.
- Single vs. double precision FP and Vector latencies and hazards.
| Paths 
 |  Differential  D3769  
[ARM64] Increases the Sched Model accuracy for Cortex-A53. ClosedPublic Authored by cestes on May 14 2014, 12:13 PM. 
Details 
 Summary Updates include: 
 
Diff Detail Event Timelinecestes updated this object. Comment Actions Hi Dave, I'll leave Andy to take a look at the schedulery bits, but I spotted a couple of more general things: 
 cestes edited edge metadata.Comment Actions Explicitly checking Opcodes in the helper function(s) for shifting/extending. This revision is now accepted and ready to land.May 15 2014, 9:20 PM Comment Actions Accidentally committed the patchset without the recommended revisions from Tim. Will submit with a subsequent patchset that adds these revisions and also resolves http://llvm.org/bugs/show_bug.cgi?id=19761. 
Revision Contents 
 
 
Diff 9449 lib/Target/ARM64/ARM64InstrFormats.td
 
 lib/Target/ARM64/ARM64InstrInfo.h
 lib/Target/ARM64/ARM64InstrInfo.cpp
 lib/Target/ARM64/ARM64SchedA53.td
 lib/Target/ARM64/ARM64SchedCyclone.td
 lib/Target/ARM64/ARM64Schedule.td
 test/CodeGen/ARM64/misched-basic-A53.ll
 test/CodeGen/ARM64/misched-forwarding-A53.ll
 
 | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
I think it would be good to be explicit about the instructions you intend to support here and make default llvm_unreachable.
The code will be longer, but if nothing else it means that anyone changing those instructions and grepping the source for significant locations will find this function.