[X86] Disable mul -> shl + lea combine when compiling for minsize
authorMichael Kuperstein <michael.m.kuperstein@intel.com>
Wed, 12 Aug 2015 11:27:26 +0000 (11:27 +0000)
committerMichael Kuperstein <michael.m.kuperstein@intel.com>
Wed, 12 Aug 2015 11:27:26 +0000 (11:27 +0000)
Differential Revision: http://reviews.llvm.org/D11904

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@244740 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Target/X86/X86ISelLowering.cpp
test/CodeGen/X86/imul.ll

index 4da5851fc060656ba410272663e39eaf0b8deff8..986646a404c3701a65df8356a57605b9c18fc22e 100644 (file)
@@ -23436,6 +23436,10 @@ static SDValue PerformCMOVCombine(SDNode *N, SelectionDAG &DAG,
 /// LEA + SHL, LEA + LEA.
 static SDValue PerformMulCombine(SDNode *N, SelectionDAG &DAG,
                                  TargetLowering::DAGCombinerInfo &DCI) {
+  // An imul is usually smaller than the alternative sequence.
+  if (DAG.getMachineFunction().getFunction()->optForMinSize())
+    return SDValue();
+
   if (DCI.isBeforeLegalize() || DCI.isCalledByLegalizer())
     return SDValue();
 
index c64b4e302b9211c13966f69dd604791c573a0c7a..99a4690a0094f9097fbcbe2e779a88a2233c7d05 100644 (file)
@@ -108,3 +108,21 @@ define i64 @mul40_64(i64 %A) {
     %mul = mul i64 %A, 40
     ret i64 %mul
 }
+
+define i32 @mul4_32_minsize(i32 %A) minsize {
+; X64-LABEL: mul4_32_minsize:
+; X64: leal
+; X86-LABEL: mul4_32_minsize:
+; X86: shll
+    %mul = mul i32 %A, 4
+    ret i32 %mul
+}
+
+define i32 @mul40_32_minsize(i32 %A) minsize {
+; X64-LABEL: mul40_32_minsize:
+; X64: imull
+; X86-LABEL: mul40_32_minsize:
+; X86: imull
+    %mul = mul i32 %A, 40
+    ret i32 %mul
+}