mirror of
https://github.com/RPCS3/llvm.git
synced 2024-12-27 22:55:15 +00:00
[PPC] Fix the scheduling of CR logicals on the P7
CR logicals (crand, crxor, etc.) on the P7 need to be in the first slot of each dispatch group. The old itinerary entry was just wrong (but has not mattered because we don't generate these instructions). This will matter when, in an upcoming commit, we start generating these instructions. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@198359 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
628dca146e
commit
d151389bd1
@ -128,6 +128,7 @@ bool PPCDispatchGroupSBHazardRecognizer::mustComeFirst(const MCInstrDesc *MCID,
|
||||
default:
|
||||
// All multi-slot instructions must come first.
|
||||
return NSlots > 1;
|
||||
case PPC::Sched::IIC_BrCR: // cr logicals
|
||||
case PPC::Sched::IIC_SprMFCR:
|
||||
case PPC::Sched::IIC_SprMFCRF:
|
||||
case PPC::Sched::IIC_SprMTSPR:
|
||||
|
@ -137,8 +137,8 @@ def P7Itineraries : ProcessorItineraries<
|
||||
InstrItinData<IIC_BrB , [InstrStage<1, [P7_DU5, P7_DU6], 0>,
|
||||
InstrStage<1, [P7_BRU]>],
|
||||
[3, 1, 1]>,
|
||||
InstrItinData<IIC_BrCR , [InstrStage<1, [P7_DU5, P7_DU6], 0>,
|
||||
InstrStage<1, [P7_BRU]>],
|
||||
InstrItinData<IIC_BrCR , [InstrStage<1, [P7_DU1], 0>,
|
||||
InstrStage<1, [P7_CRU]>],
|
||||
[3, 1, 1]>,
|
||||
InstrItinData<IIC_BrMCR , [InstrStage<1, [P7_DU5, P7_DU6], 0>,
|
||||
InstrStage<1, [P7_BRU]>],
|
||||
|
Loading…
Reference in New Issue
Block a user