mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-09-26 09:18:56 +00:00
[ARM][ISel] Improve the lowering of vector loads.
When vectors are built from a single value, the ARM lowering issues a scalar_to_vector node. This node is then always morphed into a move from the general purpose unit to the vector unit. When the value comes from a load, this can be simplified into a vector load to the right lane. This patch changes the lowering of insert_vector_elt to expose a vector friendly pattern in this situation. This is a step toward fixing <rdar://problem/14170854>. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@186999 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@@ -4674,7 +4674,9 @@ SDValue ARMTargetLowering::LowerBUILD_VECTOR(SDValue Op, SelectionDAG &DAG,
|
||||
if (ValueCounts.size() == 0)
|
||||
return DAG.getUNDEF(VT);
|
||||
|
||||
if (isOnlyLowElement)
|
||||
// Loads are better lowered with insert_vector_elt/ARMISD::BUILD_VECTOR.
|
||||
// Keep going if we are hitting this case.
|
||||
if (isOnlyLowElement && !ISD::isNormalLoad(Value.getNode()))
|
||||
return DAG.getNode(ISD::SCALAR_TO_VECTOR, dl, VT, Value);
|
||||
|
||||
unsigned EltSize = VT.getVectorElementType().getSizeInBits();
|
||||
|
Reference in New Issue
Block a user