mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-31 20:51:52 +01:00
[mips][microMIPS] Delay slot filler modifications
Differential Revision: http://reviews.llvm.org/D18181 llvm-svn: 264147
This commit is contained in:
parent
d2783a8964
commit
54f466bad6
@ -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