Skip to content
This repository has been archived by the owner on Feb 5, 2019. It is now read-only.

Commit

Permalink
AArch64: be careful of large immediates when optimising cmps.
Browse files Browse the repository at this point in the history
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@243492 91177308-0d34-0410-b5e6-96231b3b80d8
  • Loading branch information
TNorthover committed Jul 28, 2015
1 parent 62df004 commit db059db
Show file tree
Hide file tree
Showing 2 changed files with 38 additions and 5 deletions.
17 changes: 12 additions & 5 deletions lib/Target/AArch64/AArch64ConditionOptimizer.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -154,11 +154,18 @@ MachineInstr *AArch64ConditionOptimizer::findSuitableCompare(
// cmn is an alias for adds with a dead destination register.
case AArch64::ADDSWri:
case AArch64::ADDSXri:
if (MRI->use_empty(I->getOperand(0).getReg()))
return I;

DEBUG(dbgs() << "Destination of cmp is not dead, " << *I << '\n');
return nullptr;
if (!I->getOperand(2).isImm()) {
DEBUG(dbgs() << "Immediate of cmp is symbolic, " << *I << '\n');
return nullptr;
} else if (I->getOperand(2).getImm() << I->getOperand(3).getImm() >=
0xfff) {
DEBUG(dbgs() << "Immediate of cmp may be out of range, " << *I << '\n');
return nullptr;
} else if (!MRI->use_empty(I->getOperand(0).getReg())) {
DEBUG(dbgs() << "Destination of cmp is not dead, " << *I << '\n');
return nullptr;
}
return I;

// Prevent false positive case like:
// cmp w19, #0
Expand Down
26 changes: 26 additions & 0 deletions test/CodeGen/AArch64/combine-comparisons-by-cse.ll
Original file line number Diff line number Diff line change
Expand Up @@ -403,6 +403,32 @@ return: ; preds = %land.lhs.true, %con
ret i32 %retval.0
}

define void @cmp_shifted(i32 %in, i32 %lhs, i32 %rhs) {
; CHECK-LABEL: cmp_shifted:
; CHECK: cmp w0, #1
; [...]
; CHECK: cmp w0, #2, lsl #12

%tst_low = icmp sgt i32 %in, 0
br i1 %tst_low, label %true, label %false

true:
call i32 @zoo(i32 128)
ret void

false:
%tst = icmp sgt i32 %in, 8191
br i1 %tst, label %truer, label %falser

truer:
call i32 @zoo(i32 42)
ret void

falser:
call i32 @zoo(i32 1)
ret void
}

declare i32 @zoo(i32)

declare double @yoo(i32)
Expand Down

0 comments on commit db059db

Please sign in to comment.