mirror of
https://github.com/RPCSX/llvm.git
synced 2025-05-13 10:56:01 +00:00
[mips][microMIPS] Delay slot filler modifications
Differential Revision: http://reviews.llvm.org/D18181 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@264147 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
2515d26400
commit
e7adbcc7a2
@ -562,6 +562,12 @@ bool Filler::runOnMachineBasicBlock(MachineBasicBlock &MBB) {
|
||||
bool InMicroMipsMode = STI.inMicroMipsMode();
|
||||
const MipsInstrInfo *TII = STI.getInstrInfo();
|
||||
|
||||
if (InMicroMipsMode && STI.hasMips32r6()) {
|
||||
// This is microMIPS32r6 or microMIPS64r6 processor. Delay slot for
|
||||
// branching instructions is not needed.
|
||||
return Changed;
|
||||
}
|
||||
|
||||
for (Iter I = MBB.begin(); I != MBB.end(); ++I) {
|
||||
if (!hasUnoccupiedSlot(&*I))
|
||||
continue;
|
||||
|
@ -1,5 +1,7 @@
|
||||
; RUN: llc -march=mipsel -mcpu=mips32r2 -mattr=+micromips \
|
||||
; RUN: -relocation-model=static -O2 < %s | FileCheck %s
|
||||
; RUN: llc -march=mipsel -mcpu=mips32r6 -mattr=+micromips \
|
||||
; RUN: -relocation-model=static -O2 < %s | FileCheck %s -check-prefix=CHECK-MMR6
|
||||
|
||||
; Function Attrs: nounwind
|
||||
define i32 @foo(i32 signext %a) #0 {
|
||||
@ -16,3 +18,5 @@ declare i32 @bar(i32 signext) #1
|
||||
|
||||
; CHECK: jals
|
||||
; CHECK-NEXT: sll16
|
||||
; CHECK-MMR6: jal
|
||||
; CHECK-MMR6-NOT: sll16
|
||||
|
Loading…
x
Reference in New Issue
Block a user