diff options
author | Tim Northover <tnorthover@apple.com> | 2015-07-29 16:39:56 +0000 |
---|---|---|
committer | Tim Northover <tnorthover@apple.com> | 2015-07-29 16:39:56 +0000 |
commit | cf739b8c3dac5bbee2a81b300d6cdf7b60af53dc (patch) | |
tree | 82a16f30158eff10cc4ffe30fc16da1dfe65305b /llvm/lib/Target/AArch64/AArch64ConditionOptimizer.cpp | |
parent | eb26e1d03cf9117a102e8de215de31631dedb3d4 (diff) | |
download | bcm5719-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.cpp | 9 |
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 |