diff options
| author | Craig Topper <craig.topper@intel.com> | 2018-10-01 17:10:50 +0000 | 
|---|---|---|
| committer | Craig Topper <craig.topper@intel.com> | 2018-10-01 17:10:50 +0000 | 
| commit | aa84e1bba2671e7e640d45e8cb167be01292db70 (patch) | |
| tree | e1901eb9d1c61b8c6560923a85703b89f54bfab5 /llvm | |
| parent | 2b587ad0712408f6aa8bc48c34496386fd81edab (diff) | |
| download | bcm5719-llvm-aa84e1bba2671e7e640d45e8cb167be01292db70.tar.gz bcm5719-llvm-aa84e1bba2671e7e640d45e8cb167be01292db70.zip  | |
[X86] Enable load folding in the test shrinking code
This patch adds load folding support to the test shrinking code. This was noticed missing in the review for D52669
Differential Revision: https://reviews.llvm.org/D52699
llvm-svn: 343499
Diffstat (limited to 'llvm')
| -rw-r--r-- | llvm/lib/Target/X86/X86ISelDAGToDAG.cpp | 34 | ||||
| -rw-r--r-- | llvm/test/CodeGen/X86/test-shrink.ll | 12 | 
2 files changed, 29 insertions, 17 deletions
diff --git a/llvm/lib/Target/X86/X86ISelDAGToDAG.cpp b/llvm/lib/Target/X86/X86ISelDAGToDAG.cpp index 91c906c25ec..0c676603049 100644 --- a/llvm/lib/Target/X86/X86ISelDAGToDAG.cpp +++ b/llvm/lib/Target/X86/X86ISelDAGToDAG.cpp @@ -3412,7 +3412,7 @@ void X86DAGToDAGISel::Select(SDNode *Node) {        MVT VT;        int SubRegOp; -      unsigned Op; +      unsigned ROpc, MOpc;        // For each of these checks we need to be careful if the sign flag is        // being used. It is only safe to use the sign flag in two conditions, @@ -3425,7 +3425,8 @@ void X86DAGToDAGISel::Select(SDNode *Node) {          // For example, convert "testl %eax, $8" to "testb %al, $8"          VT = MVT::i8;          SubRegOp = X86::sub_8bit; -        Op = X86::TEST8ri; +        ROpc = X86::TEST8ri; +        MOpc = X86::TEST8mi;        } else if (OptForMinSize && isUInt<16>(Mask) &&                   (!(Mask & 0x8000) || CmpVT == MVT::i16 ||                    hasNoSignedComparisonUses(Node))) { @@ -3435,7 +3436,8 @@ void X86DAGToDAGISel::Select(SDNode *Node) {          // changing prefix penalty in the decoders.          VT = MVT::i16;          SubRegOp = X86::sub_16bit; -        Op = X86::TEST16ri; +        ROpc = X86::TEST16ri; +        MOpc = X86::TEST16mi;        } else if (isUInt<32>(Mask) && N0.getValueType() != MVT::i16 &&                   (!(Mask & 0x80000000) || CmpVT == MVT::i32 ||                    hasNoSignedComparisonUses(Node))) { @@ -3446,7 +3448,8 @@ void X86DAGToDAGISel::Select(SDNode *Node) {          // they had a good reason not to and do not promote here.          VT = MVT::i32;          SubRegOp = X86::sub_32bit; -        Op = X86::TEST32ri; +        ROpc = X86::TEST32ri; +        MOpc = X86::TEST32mi;        } else {          // No eligible transformation was found.          break; @@ -3457,12 +3460,25 @@ void X86DAGToDAGISel::Select(SDNode *Node) {        SDValue Imm = CurDAG->getTargetConstant(Mask, dl, VT);        SDValue Reg = N0.getOperand(0); -      // Extract the subregister if necessary. -      if (N0.getValueType() != VT) -        Reg = CurDAG->getTargetExtractSubreg(SubRegOp, dl, VT, Reg); -        // Emit a testl or testw. -      SDNode *NewNode = CurDAG->getMachineNode(Op, dl, MVT::i32, Reg, Imm); +      MachineSDNode *NewNode; +      SDValue Tmp0, Tmp1, Tmp2, Tmp3, Tmp4; +      if (tryFoldLoad(Node, N0.getNode(), Reg, Tmp0, Tmp1, Tmp2, Tmp3, Tmp4)) { +        SDValue Ops[] = { Tmp0, Tmp1, Tmp2, Tmp3, Tmp4, Imm, +                          Reg.getOperand(0) }; +        NewNode = CurDAG->getMachineNode(MOpc, dl, MVT::i32, MVT::Other, Ops); +        // Update the chain. +        ReplaceUses(Reg.getValue(1), SDValue(NewNode, 1)); +        // Record the mem-refs +        CurDAG->setNodeMemRefs(NewNode, +                               {cast<LoadSDNode>(Reg)->getMemOperand()}); +      } else { +        // Extract the subregister if necessary. +        if (N0.getValueType() != VT) +          Reg = CurDAG->getTargetExtractSubreg(SubRegOp, dl, VT, Reg); + +        NewNode = CurDAG->getMachineNode(ROpc, dl, MVT::i32, Reg, Imm); +      }        // Replace CMP with TEST.        ReplaceNode(Node, NewNode);        return; diff --git a/llvm/test/CodeGen/X86/test-shrink.ll b/llvm/test/CodeGen/X86/test-shrink.ll index e0351452bd8..63d4f6b2ecd 100644 --- a/llvm/test/CodeGen/X86/test-shrink.ll +++ b/llvm/test/CodeGen/X86/test-shrink.ll @@ -645,8 +645,7 @@ define void @and32_trunc_8_sign(i32 %x) nounwind {  ;  ; CHECK-X86-LABEL: and32_trunc_8_sign:  ; CHECK-X86:       # %bb.0: -; CHECK-X86-NEXT:    movl {{[0-9]+}}(%esp), %eax -; CHECK-X86-NEXT:    testb $-128, %al +; CHECK-X86-NEXT:    testb $-128, {{[0-9]+}}(%esp)  ; CHECK-X86-NEXT:    jg .LBB14_2  ; CHECK-X86-NEXT:  # %bb.1: # %yes  ; CHECK-X86-NEXT:    calll bar @@ -689,8 +688,7 @@ define void @and64_trunc_8_sign(i64 %x) nounwind {  ;  ; CHECK-X86-LABEL: and64_trunc_8_sign:  ; CHECK-X86:       # %bb.0: -; CHECK-X86-NEXT:    movl {{[0-9]+}}(%esp), %eax -; CHECK-X86-NEXT:    testb $-128, %al +; CHECK-X86-NEXT:    testb $-128, {{[0-9]+}}(%esp)  ; CHECK-X86-NEXT:    jg .LBB15_2  ; CHECK-X86-NEXT:  # %bb.1: # %yes  ; CHECK-X86-NEXT:    calll bar @@ -733,8 +731,7 @@ define void @and32_trunc_16_sign(i32 %x) minsize nounwind {  ;  ; CHECK-X86-LABEL: and32_trunc_16_sign:  ; CHECK-X86:       # %bb.0: -; CHECK-X86-NEXT:    movl {{[0-9]+}}(%esp), %eax -; CHECK-X86-NEXT:    testw $-32768, %ax # imm = 0x8000 +; CHECK-X86-NEXT:    testw $-32768, {{[0-9]+}}(%esp) # imm = 0x8000  ; CHECK-X86-NEXT:    jg .LBB16_2  ; CHECK-X86-NEXT:  # %bb.1: # %yes  ; CHECK-X86-NEXT:    calll bar @@ -777,8 +774,7 @@ define void @and64_trunc_32_sign(i64 %x) minsize nounwind {  ;  ; CHECK-X86-LABEL: and64_trunc_32_sign:  ; CHECK-X86:       # %bb.0: -; CHECK-X86-NEXT:    movl {{[0-9]+}}(%esp), %eax -; CHECK-X86-NEXT:    testw $-32768, %ax # imm = 0x8000 +; CHECK-X86-NEXT:    testw $-32768, {{[0-9]+}}(%esp) # imm = 0x8000  ; CHECK-X86-NEXT:    jg .LBB17_2  ; CHECK-X86-NEXT:  # %bb.1: # %yes  ; CHECK-X86-NEXT:    calll bar  | 

