mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-03 13:31:05 +00:00
Schedule high latency instructions for latency reduction even if they are not vfp / NEON instructions.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@105060 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
2f05cc06a2
commit
c10f5434b4
@ -605,11 +605,29 @@ unsigned ARMTargetLowering::getFunctionAlignment(const Function *F) const {
|
||||
}
|
||||
|
||||
Sched::Preference ARMTargetLowering::getSchedulingPreference(SDNode *N) const {
|
||||
for (unsigned i = 0, e = N->getNumValues(); i != e; ++i) {
|
||||
unsigned NumVals = N->getNumValues();
|
||||
if (!NumVals)
|
||||
return Sched::RegPressure;
|
||||
|
||||
for (unsigned i = 0; i != NumVals; ++i) {
|
||||
EVT VT = N->getValueType(i);
|
||||
if (VT.isFloatingPoint() || VT.isVector())
|
||||
return Sched::Latency;
|
||||
}
|
||||
|
||||
if (!N->isMachineOpcode())
|
||||
return Sched::RegPressure;
|
||||
|
||||
// Load are scheduled for latency even if there instruction itinerary
|
||||
// is not available.
|
||||
const TargetInstrInfo *TII = getTargetMachine().getInstrInfo();
|
||||
const TargetInstrDesc &TID = TII->get(N->getMachineOpcode());
|
||||
if (TID.mayLoad())
|
||||
return Sched::Latency;
|
||||
|
||||
const InstrItineraryData &Itins = getTargetMachine().getInstrItineraryData();
|
||||
if (!Itins.isEmpty() && Itins.getStageLatency(TID.getSchedClass()) > 2)
|
||||
return Sched::Latency;
|
||||
return Sched::RegPressure;
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user