mirror of
https://github.com/RPCS3/llvm.git
synced 2025-02-13 14:46:15 +00:00
[AArch64] Prevent nested ADDs from address calc in splitStoreSplat. NFC
In preparation for late-stage store merging. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@303800 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
fee7735cee
commit
ccbb5fab9c
@ -9222,16 +9222,26 @@ static SDValue splitStoreSplat(SelectionDAG &DAG, StoreSDNode &St,
|
||||
// instructions (stp).
|
||||
SDLoc DL(&St);
|
||||
SDValue BasePtr = St.getBasePtr();
|
||||
int64_t BaseOffset = 0;
|
||||
|
||||
const MachinePointerInfo &PtrInfo = St.getPointerInfo();
|
||||
SDValue NewST1 =
|
||||
DAG.getStore(St.getChain(), DL, SplatVal, BasePtr, PtrInfo,
|
||||
OrigAlignment, St.getMemOperand()->getFlags());
|
||||
|
||||
// As this in ISel, we will not merge this add which may degrate results.
|
||||
if (BasePtr->getOpcode() == ISD::ADD &&
|
||||
isa<ConstantSDNode>(BasePtr->getOperand(1))) {
|
||||
BaseOffset = cast<ConstantSDNode>(BasePtr->getOperand(1))->getSExtValue();
|
||||
BasePtr = BasePtr->getOperand(0);
|
||||
}
|
||||
|
||||
unsigned Offset = EltOffset;
|
||||
while (--NumVecElts) {
|
||||
unsigned Alignment = MinAlign(OrigAlignment, Offset);
|
||||
SDValue OffsetPtr = DAG.getNode(ISD::ADD, DL, MVT::i64, BasePtr,
|
||||
DAG.getConstant(Offset, DL, MVT::i64));
|
||||
SDValue OffsetPtr = DAG.getNode(
|
||||
ISD::ADD, DL, MVT::i64, BasePtr,
|
||||
DAG.getConstant(BaseOffset + ((int64_t)Offset), DL, MVT::i64));
|
||||
NewST1 = DAG.getStore(NewST1.getValue(0), DL, SplatVal, OffsetPtr,
|
||||
PtrInfo.getWithOffset(Offset), Alignment,
|
||||
St.getMemOperand()->getFlags());
|
||||
|
Loading…
x
Reference in New Issue
Block a user