mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-08 18:31:23 +00:00
PPC::B and PPC::BCC's target operand may be an immediate.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@71282 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
3fbdbd9898
commit
82ae933e55
@ -220,9 +220,13 @@ bool PPCInstrInfo::AnalyzeBranch(MachineBasicBlock &MBB,MachineBasicBlock *&TBB,
|
||||
// If there is only one terminator instruction, process it.
|
||||
if (I == MBB.begin() || !isUnpredicatedTerminator(--I)) {
|
||||
if (LastInst->getOpcode() == PPC::B) {
|
||||
if (!LastInst->getOperand(0).isMBB())
|
||||
return true;
|
||||
TBB = LastInst->getOperand(0).getMBB();
|
||||
return false;
|
||||
} else if (LastInst->getOpcode() == PPC::BCC) {
|
||||
if (!LastInst->getOperand(2).isMBB())
|
||||
return true;
|
||||
// Block ends with fall-through condbranch.
|
||||
TBB = LastInst->getOperand(2).getMBB();
|
||||
Cond.push_back(LastInst->getOperand(0));
|
||||
@ -244,6 +248,9 @@ bool PPCInstrInfo::AnalyzeBranch(MachineBasicBlock &MBB,MachineBasicBlock *&TBB,
|
||||
// If the block ends with PPC::B and PPC:BCC, handle it.
|
||||
if (SecondLastInst->getOpcode() == PPC::BCC &&
|
||||
LastInst->getOpcode() == PPC::B) {
|
||||
if (!SecondLastInst->getOperand(2).isMBB() ||
|
||||
!LastInst->getOperand(0).isMBB())
|
||||
return true;
|
||||
TBB = SecondLastInst->getOperand(2).getMBB();
|
||||
Cond.push_back(SecondLastInst->getOperand(0));
|
||||
Cond.push_back(SecondLastInst->getOperand(1));
|
||||
@ -255,6 +262,8 @@ bool PPCInstrInfo::AnalyzeBranch(MachineBasicBlock &MBB,MachineBasicBlock *&TBB,
|
||||
// executed, so remove it.
|
||||
if (SecondLastInst->getOpcode() == PPC::B &&
|
||||
LastInst->getOpcode() == PPC::B) {
|
||||
if (!SecondLastInst->getOperand(0).isMBB())
|
||||
return true;
|
||||
TBB = SecondLastInst->getOperand(0).getMBB();
|
||||
I = LastInst;
|
||||
if (AllowModify)
|
||||
|
Loading…
Reference in New Issue
Block a user