mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-20 12:31:40 +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 {
|
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);
|
EVT VT = N->getValueType(i);
|
||||||
if (VT.isFloatingPoint() || VT.isVector())
|
if (VT.isFloatingPoint() || VT.isVector())
|
||||||
return Sched::Latency;
|
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;
|
return Sched::RegPressure;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user