From 2fe4352691bf4b80517ee36730cfddfb719d79fc Mon Sep 17 00:00:00 2001 From: Dan Gohman Date: Wed, 30 Jul 2008 18:36:51 +0000 Subject: Don't look for leaf values to store when lowering stores of empty structs. This fixes PR2612. llvm-svn: 54226 --- llvm/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) (limited to 'llvm/lib/CodeGen/SelectionDAG') diff --git a/llvm/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp b/llvm/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp index 65753e53446..6267eb9fea8 100644 --- a/llvm/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp +++ b/llvm/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp @@ -2928,9 +2928,7 @@ void SelectionDAGLowering::visitLoad(LoadInst &I) { void SelectionDAGLowering::visitStore(StoreInst &I) { Value *SrcV = I.getOperand(0); - SDValue Src = getValue(SrcV); Value *PtrV = I.getOperand(1); - SDValue Ptr = getValue(PtrV); SmallVector ValueVTs; SmallVector Offsets; @@ -2939,6 +2937,12 @@ void SelectionDAGLowering::visitStore(StoreInst &I) { if (NumValues == 0) return; + // Get the lowered operands. Note that we do this after + // checking if NumResults is zero, because with zero results + // the operands won't have values in the map. + SDValue Src = getValue(SrcV); + SDValue Ptr = getValue(PtrV); + SDValue Root = getRoot(); SmallVector Chains(NumValues); MVT PtrVT = Ptr.getValueType(); -- cgit v1.2.3