diff options
| author | Chris Lattner <sabre@nondot.org> | 2006-03-31 17:37:22 +0000 |
|---|---|---|
| committer | Chris Lattner <sabre@nondot.org> | 2006-03-31 17:37:22 +0000 |
| commit | 8e1fcab2bcb4cf1ac2b65f68041513dd92e79d55 (patch) | |
| tree | cffea68ab68fe667c2126d0953c5738fc0da5580 /llvm | |
| parent | e45355218fe1c3d9e29686ad10fdd68304027ea6 (diff) | |
| download | bcm5719-llvm-8e1fcab2bcb4cf1ac2b65f68041513dd92e79d55.tar.gz bcm5719-llvm-8e1fcab2bcb4cf1ac2b65f68041513dd92e79d55.zip | |
Scalarized vector stores need not be legal, e.g. if the vector element type
needs to be promoted or expanded. Relegalize the scalar store once created.
This fixes CodeGen/Generic/vector.ll:test1 on non-SSE x86 targets.
llvm-svn: 27293
Diffstat (limited to 'llvm')
| -rw-r--r-- | llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp b/llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp index 93b0d9b1cce..3fe984ebcc6 100644 --- a/llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp +++ b/llvm/lib/CodeGen/SelectionDAG/LegalizeDAG.cpp @@ -1477,6 +1477,9 @@ SDOperand SelectionDAGLegalize::LegalizeOp(SDOperand Op) { Tmp3 = PackVectorOp(Node->getOperand(1), EVT); Result = DAG.UpdateNodeOperands(Result, Tmp1, Tmp3, Tmp2, Node->getOperand(3)); + // The scalarized value type may not be legal, e.g. it might require + // promotion or expansion. Relegalize the scalar store. + Result = LegalizeOp(Result); break; } else { SplitVectorOp(Node->getOperand(1), Lo, Hi); |

