mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-03-30 20:34:21 +00:00
Fix ExpandVectorBuildThroughStack for the case where the
operands are themselves vectors. Based on a patch by Micah Villmow for PR6338. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@97165 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
6341c5a4c4
commit
9949dd612c
@ -1539,7 +1539,6 @@ SDValue SelectionDAGLegalize::ExpandVectorBuildThroughStack(SDNode* Node) {
|
||||
// the result as a vector.
|
||||
// Create the stack frame object.
|
||||
EVT VT = Node->getValueType(0);
|
||||
EVT OpVT = Node->getOperand(0).getValueType();
|
||||
EVT EltVT = VT.getVectorElementType();
|
||||
DebugLoc dl = Node->getDebugLoc();
|
||||
SDValue FIPtr = DAG.CreateStackTemporary(VT);
|
||||
@ -1559,8 +1558,9 @@ SDValue SelectionDAGLegalize::ExpandVectorBuildThroughStack(SDNode* Node) {
|
||||
SDValue Idx = DAG.getConstant(Offset, FIPtr.getValueType());
|
||||
Idx = DAG.getNode(ISD::ADD, dl, FIPtr.getValueType(), FIPtr, Idx);
|
||||
|
||||
// If EltVT smaller than OpVT, only store the bits necessary.
|
||||
if (!OpVT.isVector() && EltVT.bitsLT(OpVT)) {
|
||||
// If the destination vector element type is narrower than the source
|
||||
// element type, only store the bits necessary.
|
||||
if (EltVT.bitsLT(Node->getOperand(i).getValueType().getScalarType())) {
|
||||
Stores.push_back(DAG.getTruncStore(DAG.getEntryNode(), dl,
|
||||
Node->getOperand(i), Idx, SV, Offset,
|
||||
EltVT, false, false, 0));
|
||||
|
Loading…
x
Reference in New Issue
Block a user