[llvm] r244740 - [X86] Disable mul -> shl + lea combine when compiling for minsize
Michael Kuperstein via llvm-commits
llvm-commits at lists.llvm.org
Wed Aug 12 04:27:27 PDT 2015
Author: mkuper
Date: Wed Aug 12 06:27:26 2015
New Revision: 244740
URL: http://llvm.org/viewvc/llvm-project?rev=244740&view=rev
Log:
[X86] Disable mul -> shl + lea combine when compiling for minsize
Differential Revision: http://reviews.llvm.org/D11904
Modified:
llvm/trunk/lib/Target/X86/X86ISelLowering.cpp
llvm/trunk/test/CodeGen/X86/imul.ll
Modified: llvm/trunk/lib/Target/X86/X86ISelLowering.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Target/X86/X86ISelLowering.cpp?rev=244740&r1=244739&r2=244740&view=diff
==============================================================================
--- llvm/trunk/lib/Target/X86/X86ISelLowering.cpp (original)
+++ llvm/trunk/lib/Target/X86/X86ISelLowering.cpp Wed Aug 12 06:27:26 2015
@@ -23436,6 +23436,10 @@ static SDValue PerformCMOVCombine(SDNode
/// 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();
Modified: llvm/trunk/test/CodeGen/X86/imul.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/CodeGen/X86/imul.ll?rev=244740&r1=244739&r2=244740&view=diff
==============================================================================
--- llvm/trunk/test/CodeGen/X86/imul.ll (original)
+++ llvm/trunk/test/CodeGen/X86/imul.ll Wed Aug 12 06:27:26 2015
@@ -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
+}
More information about the llvm-commits
mailing list