From 74881908fec5de98175d41d6fa065971736b2119 Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Sun, 19 Mar 2006 05:46:04 +0000 Subject: [PATCH] Don't bother storing undef elements of BUILD_VECTOR's git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@26858 91177308-0d34-0410-b5e6-96231b3b80d8 --- lib/CodeGen/SelectionDAG/LegalizeDAG.cpp | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp b/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp index a0c10a09f72..d594cfe7efa 100644 --- a/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp +++ b/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp @@ -794,6 +794,9 @@ SDOperand SelectionDAGLegalize::LegalizeOp(SDOperand Op) { unsigned VectorSize = MVT::getSizeInBits(VT)/8; // Store (in the right endianness) the elements to memory. for (unsigned i = 0, e = Node->getNumOperands(); i != e; ++i) { + // Ignore undef elements. + if (Node->getOperand(i).getOpcode() == ISD::UNDEF) continue; + unsigned Offset; if (isLittleEndian) Offset = TypeByteSize*i; @@ -807,7 +810,12 @@ SDOperand SelectionDAGLegalize::LegalizeOp(SDOperand Op) { Node->getOperand(i), Idx, DAG.getSrcValue(NULL))); } - SDOperand StoreChain = DAG.getNode(ISD::TokenFactor, MVT::Other, Stores); + + SDOperand StoreChain; + if (!Stores.empty()) // Not all undef elements? + StoreChain = DAG.getNode(ISD::TokenFactor, MVT::Other, Stores); + else + StoreChain = DAG.getEntryNode(); // Result is a load from the stack slot. Result = DAG.getLoad(VT, StoreChain, FIPtr, DAG.getSrcValue(0));