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/lib/CodeGen | |
| 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/lib/CodeGen')
| -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); | 

