mirror of
https://github.com/RPCS3/llvm.git
synced 2024-12-19 09:57:42 +00:00
Fix regression with -O0 for mips .
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@203469 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
c869887dde
commit
017bc0fca6
@ -175,6 +175,9 @@ public:
|
||||
virtual bool addInstSelector();
|
||||
virtual void addMachineSSAOptimization();
|
||||
virtual bool addPreEmitPass();
|
||||
|
||||
virtual bool addPreRegAlloc();
|
||||
|
||||
};
|
||||
} // namespace
|
||||
|
||||
@ -208,6 +211,15 @@ void MipsPassConfig::addMachineSSAOptimization() {
|
||||
TargetPassConfig::addMachineSSAOptimization();
|
||||
}
|
||||
|
||||
bool MipsPassConfig::addPreRegAlloc() {
|
||||
if (getOptLevel() == CodeGenOpt::None) {
|
||||
addPass(createMipsOptimizePICCallPass(getMipsTargetMachine()));
|
||||
return true;
|
||||
}
|
||||
else
|
||||
return false;
|
||||
}
|
||||
|
||||
void MipsTargetMachine::addAnalysisPasses(PassManagerBase &PM) {
|
||||
if (Subtarget.allowMixed16_32()) {
|
||||
DEBUG(errs() << "No ");
|
||||
|
33
test/CodeGen/Mips/optimize-pic-o0.ll
Normal file
33
test/CodeGen/Mips/optimize-pic-o0.ll
Normal file
@ -0,0 +1,33 @@
|
||||
; RUN: llc -mtriple=mipsel -O0 < %s | FileCheck %s
|
||||
|
||||
; Function Attrs: nounwind
|
||||
define i32 @main() {
|
||||
entry:
|
||||
%retval = alloca i32, align 4
|
||||
%i = alloca i32, align 4
|
||||
store i32 0, i32* %retval
|
||||
store i32 0, i32* %i, align 4
|
||||
br label %for.cond
|
||||
|
||||
for.cond: ; preds = %for.inc, %entry
|
||||
%0 = load i32* %i, align 4
|
||||
%cmp = icmp slt i32 %0, 10
|
||||
br i1 %cmp, label %for.body, label %for.end
|
||||
|
||||
for.body: ; preds = %for.cond
|
||||
call void bitcast (void (...)* @foo to void ()*)()
|
||||
; CHECK: jalr $25
|
||||
br label %for.inc
|
||||
|
||||
for.inc: ; preds = %for.body
|
||||
%1 = load i32* %i, align 4
|
||||
%inc = add nsw i32 %1, 1
|
||||
store i32 %inc, i32* %i, align 4
|
||||
br label %for.cond
|
||||
|
||||
for.end: ; preds = %for.cond
|
||||
%2 = load i32* %retval
|
||||
ret i32 %2
|
||||
}
|
||||
|
||||
declare void @foo(...)
|
Loading…
Reference in New Issue
Block a user