mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-04-03 16:21:41 +00:00
[ModuloSchedule] removeBranch() *before* creating the trip count condition
The Hexagon code assumes there's no existing terminator when inserting its trip count condition check. This causes swp-stages5.ll to break. The generated code looks good to me, it is likely a permutation. I have disabled the new codegen path to keep everything green and will investigate along with the other 3-4 tests that have different codegen. Fixes expensive-checks build. llvm-svn: 373629
This commit is contained in:
parent
80f09c72f7
commit
b8695c33a2
@ -1772,12 +1772,12 @@ void PeelingModuloScheduleExpander::fixupBranches() {
|
||||
MachineBasicBlock *Fallthrough = *Prolog->succ_begin();
|
||||
MachineBasicBlock *Epilog = *EI;
|
||||
SmallVector<MachineOperand, 4> Cond;
|
||||
TII->removeBranch(*Prolog);
|
||||
Optional<bool> StaticallyGreater =
|
||||
Info->createTripCountGreaterCondition(TC, *Prolog, Cond);
|
||||
if (!StaticallyGreater.hasValue()) {
|
||||
LLVM_DEBUG(dbgs() << "Dynamic: TC > " << TC << "\n");
|
||||
// Dynamically branch based on Cond.
|
||||
TII->removeBranch(*Prolog);
|
||||
TII->insertBranch(*Prolog, Epilog, Fallthrough, Cond, DebugLoc());
|
||||
} else if (*StaticallyGreater == false) {
|
||||
LLVM_DEBUG(dbgs() << "Static-false: TC > " << TC << "\n");
|
||||
@ -1788,7 +1788,6 @@ void PeelingModuloScheduleExpander::fixupBranches() {
|
||||
P.RemoveOperand(2);
|
||||
P.RemoveOperand(1);
|
||||
}
|
||||
TII->removeBranch(*Prolog);
|
||||
TII->insertUnconditionalBranch(*Prolog, Epilog, DebugLoc());
|
||||
KernelDisposed = true;
|
||||
} else {
|
||||
|
@ -1,4 +1,4 @@
|
||||
; RUN: llc -march=hexagon -mcpu=hexagonv5 -enable-pipeliner -pipeliner-max-stages=2 -hexagon-bit=0 < %s -pipeliner-experimental-cg=true | FileCheck %s
|
||||
; RUN: llc -march=hexagon -mcpu=hexagonv5 -enable-pipeliner -pipeliner-max-stages=2 -hexagon-bit=0 < %s | FileCheck %s
|
||||
|
||||
; Very similar to swp-stages4.ll, but the pipelined schedule is a little
|
||||
; different.
|
||||
|
Loading…
x
Reference in New Issue
Block a user