aboutsummaryrefslogtreecommitdiffstats
path: root/lib
diff options
context:
space:
mode:
authorManman Ren <mren@apple.com>2012-05-31 17:20:29 +0000
committerManman Ren <mren@apple.com>2012-05-31 17:20:29 +0000
commit91c5346d91973a1d3458a20f8c6b0e899b732e38 (patch)
treeeb29d9f46d2f9184cb248413cc98369f6179c089 /lib
parent5ddc04caf25a649963c99be02646c3a9fc88d514 (diff)
downloadexternal_llvm-91c5346d91973a1d3458a20f8c6b0e899b732e38.zip
external_llvm-91c5346d91973a1d3458a20f8c6b0e899b732e38.tar.gz
external_llvm-91c5346d91973a1d3458a20f8c6b0e899b732e38.tar.bz2
X86: replace SUB with CMP if possible
This patch will optimize the following movq %rdi, %rax subq %rsi, %rax cmovsq %rsi, %rdi movq %rdi, %rax to cmpq %rsi, %rdi cmovsq %rsi, %rdi movq %rdi, %rax Perform this optimization if the actual result of SUB is not used. rdar: 11540023 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@157755 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib')
-rw-r--r--lib/CodeGen/PeepholeOptimizer.cpp1
-rw-r--r--lib/Target/X86/X86InstrInfo.cpp38
-rw-r--r--lib/Target/X86/X86InstrInfo.h3
3 files changed, 42 insertions, 0 deletions
diff --git a/lib/CodeGen/PeepholeOptimizer.cpp b/lib/CodeGen/PeepholeOptimizer.cpp
index 81cf901..d7d112f 100644
--- a/lib/CodeGen/PeepholeOptimizer.cpp
+++ b/lib/CodeGen/PeepholeOptimizer.cpp
@@ -472,6 +472,7 @@ bool PeepholeOptimizer::runOnMachineFunction(MachineFunction &MF) {
if (SeenMoveImm)
Changed |= foldImmediate(MI, MBB, ImmDefRegs, ImmDefMIs);
}
+ Changed |= TII->OptimizeSubInstr(MI, MRI);
First = false;
PMII = MII;
diff --git a/lib/Target/X86/X86InstrInfo.cpp b/lib/Target/X86/X86InstrInfo.cpp
index 7254ddf..2dd5c12 100644
--- a/lib/Target/X86/X86InstrInfo.cpp
+++ b/lib/Target/X86/X86InstrInfo.cpp
@@ -2709,6 +2709,44 @@ void X86InstrInfo::loadRegFromAddr(MachineFunction &MF, unsigned DestReg,
NewMIs.push_back(MIB);
}
+bool X86InstrInfo::
+OptimizeSubInstr(MachineInstr *SubInstr, const MachineRegisterInfo *MRI) const {
+ // If destination is a memory operand, do not perform this optimization.
+ if ((SubInstr->getOpcode() != X86::SUB64rr) &&
+ (SubInstr->getOpcode() != X86::SUB32rr) &&
+ (SubInstr->getOpcode() != X86::SUB16rr) &&
+ (SubInstr->getOpcode() != X86::SUB8rr) &&
+ (SubInstr->getOpcode() != X86::SUB64ri32) &&
+ (SubInstr->getOpcode() != X86::SUB64ri8) &&
+ (SubInstr->getOpcode() != X86::SUB32ri) &&
+ (SubInstr->getOpcode() != X86::SUB32ri8) &&
+ (SubInstr->getOpcode() != X86::SUB16ri) &&
+ (SubInstr->getOpcode() != X86::SUB16ri8) &&
+ (SubInstr->getOpcode() != X86::SUB8ri))
+ return false;
+ unsigned DestReg = SubInstr->getOperand(0).getReg();
+ if (MRI->use_begin(DestReg) != MRI->use_end())
+ return false;
+
+ // There is no use of the destination register, we can replace SUB with CMP.
+ switch (SubInstr->getOpcode()) {
+ default: break;
+ case X86::SUB64rr: SubInstr->setDesc(get(X86::CMP64rr)); break;
+ case X86::SUB32rr: SubInstr->setDesc(get(X86::CMP32rr)); break;
+ case X86::SUB16rr: SubInstr->setDesc(get(X86::CMP16rr)); break;
+ case X86::SUB8rr: SubInstr->setDesc(get(X86::CMP8rr)); break;
+ case X86::SUB64ri32: SubInstr->setDesc(get(X86::CMP64ri32)); break;
+ case X86::SUB64ri8: SubInstr->setDesc(get(X86::CMP64ri8)); break;
+ case X86::SUB32ri: SubInstr->setDesc(get(X86::CMP32ri)); break;
+ case X86::SUB32ri8: SubInstr->setDesc(get(X86::CMP32ri8)); break;
+ case X86::SUB16ri: SubInstr->setDesc(get(X86::CMP16ri)); break;
+ case X86::SUB16ri8: SubInstr->setDesc(get(X86::CMP16ri8)); break;
+ case X86::SUB8ri: SubInstr->setDesc(get(X86::CMP8ri)); break;
+ }
+ SubInstr->RemoveOperand(0);
+ return true;
+}
+
/// Expand2AddrUndef - Expand a single-def pseudo instruction to a two-addr
/// instruction with two undef reads of the register being defined. This is
/// used for mapping:
diff --git a/lib/Target/X86/X86InstrInfo.h b/lib/Target/X86/X86InstrInfo.h
index 856f3be..9c4d465 100644
--- a/lib/Target/X86/X86InstrInfo.h
+++ b/lib/Target/X86/X86InstrInfo.h
@@ -365,6 +365,9 @@ public:
const MachineInstr *DefMI, unsigned DefIdx,
const MachineInstr *UseMI, unsigned UseIdx) const;
+ virtual bool OptimizeSubInstr(MachineInstr *SubInstr,
+ const MachineRegisterInfo *MRI) const;
+
private:
MachineInstr * convertToThreeAddressWithLEA(unsigned MIOpc,
MachineFunction::iterator &MFI,