summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Target/AArch64/AArch64ConditionOptimizer.cpp
diff options
context:
space:
mode:
authorTim Northover <tnorthover@apple.com>2015-07-29 16:39:56 +0000
committerTim Northover <tnorthover@apple.com>2015-07-29 16:39:56 +0000
commitcf739b8c3dac5bbee2a81b300d6cdf7b60af53dc (patch)
tree82a16f30158eff10cc4ffe30fc16da1dfe65305b /llvm/lib/Target/AArch64/AArch64ConditionOptimizer.cpp
parenteb26e1d03cf9117a102e8de215de31631dedb3d4 (diff)
downloadbcm5719-llvm-cf739b8c3dac5bbee2a81b300d6cdf7b60af53dc.tar.gz
bcm5719-llvm-cf739b8c3dac5bbee2a81b300d6cdf7b60af53dc.zip
AArch64: use AddressingModes.h accessors for compare shifts
No functional change because "lsl #12" is actually encoded as 12, but one less bug if someone ever decides to change that for the giggles. llvm-svn: 243536
Diffstat (limited to 'llvm/lib/Target/AArch64/AArch64ConditionOptimizer.cpp')
-rw-r--r--llvm/lib/Target/AArch64/AArch64ConditionOptimizer.cpp9
1 files changed, 5 insertions, 4 deletions
diff --git a/llvm/lib/Target/AArch64/AArch64ConditionOptimizer.cpp b/llvm/lib/Target/AArch64/AArch64ConditionOptimizer.cpp
index 99a5eaa7aef..fc27bfee73d 100644
--- a/llvm/lib/Target/AArch64/AArch64ConditionOptimizer.cpp
+++ b/llvm/lib/Target/AArch64/AArch64ConditionOptimizer.cpp
@@ -59,6 +59,7 @@
//===----------------------------------------------------------------------===//
#include "AArch64.h"
+#include "MCTargetDesc/AArch64AddressingModes.h"
#include "llvm/ADT/DepthFirstIterator.h"
#include "llvm/ADT/SmallVector.h"
#include "llvm/ADT/Statistic.h"
@@ -153,12 +154,12 @@ MachineInstr *AArch64ConditionOptimizer::findSuitableCompare(
case AArch64::SUBSXri:
// cmn is an alias for adds with a dead destination register.
case AArch64::ADDSWri:
- case AArch64::ADDSXri:
+ case AArch64::ADDSXri: {
+ unsigned ShiftAmt = AArch64_AM::getShiftValue(I->getOperand(3).getImm());
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) {
+ } else if (I->getOperand(2).getImm() << ShiftAmt >= 0xfff) {
DEBUG(dbgs() << "Immediate of cmp may be out of range, " << *I << '\n');
return nullptr;
} else if (!MRI->use_empty(I->getOperand(0).getReg())) {
@@ -166,7 +167,7 @@ MachineInstr *AArch64ConditionOptimizer::findSuitableCompare(
return nullptr;
}
return I;
-
+ }
// Prevent false positive case like:
// cmp w19, #0
// cinc w0, w19, gt
OpenPOWER on IntegriCloud