diff options
author | Krzysztof Parzyszek <kparzysz@quicinc.com> | 2019-11-08 19:07:02 -0600 |
---|---|---|
committer | Krzysztof Parzyszek <kparzysz@quicinc.com> | 2019-11-12 09:43:21 -0600 |
commit | 67294c97fbfde6541b5f89d9d83c7fcba31c5f3b (patch) | |
tree | a6be2c073dfd8ab0f17c7324428c044ec72c044e | |
parent | 0a58ef5eb5e1a243756f649f82834281ac3dd7ff (diff) | |
download | bcm5719-llvm-67294c97fbfde6541b5f89d9d83c7fcba31c5f3b.tar.gz bcm5719-llvm-67294c97fbfde6541b5f89d9d83c7fcba31c5f3b.zip |
[Hexagon] Handle stack realignment in hexagon-vextract
-rw-r--r-- | llvm/lib/Target/Hexagon/HexagonVExtract.cpp | 44 |
1 files changed, 37 insertions, 7 deletions
diff --git a/llvm/lib/Target/Hexagon/HexagonVExtract.cpp b/llvm/lib/Target/Hexagon/HexagonVExtract.cpp index 0c0266a6839..b7d6dbe21c7 100644 --- a/llvm/lib/Target/Hexagon/HexagonVExtract.cpp +++ b/llvm/lib/Target/Hexagon/HexagonVExtract.cpp @@ -11,6 +11,7 @@ #include "Hexagon.h" #include "HexagonInstrInfo.h" +#include "HexagonMachineFunctionInfo.h" #include "HexagonRegisterInfo.h" #include "HexagonSubtarget.h" #include "llvm/ADT/SmallVector.h" @@ -103,7 +104,10 @@ bool HexagonVExtract::runOnMachineFunction(MachineFunction &MF) { const auto &HRI = *HST->getRegisterInfo(); MachineRegisterInfo &MRI = MF.getRegInfo(); MachineFrameInfo &MFI = MF.getFrameInfo(); + Register AR = + MF.getInfo<HexagonMachineFunctionInfo>()->getStackAlignBaseVReg(); std::map<unsigned, SmallVector<MachineInstr*,4>> VExtractMap; + unsigned MaxAlign = 0; bool Changed = false; for (MachineBasicBlock &MBB : MF) { @@ -116,22 +120,41 @@ bool HexagonVExtract::runOnMachineFunction(MachineFunction &MF) { } } + auto EmitAddr = [&] (MachineBasicBlock &BB, MachineBasicBlock::iterator At, + DebugLoc dl, int FI, unsigned Offset) { + Register AddrR = MRI.createVirtualRegister(&Hexagon::IntRegsRegClass); + unsigned FiOpc = AR != 0 ? Hexagon::PS_fia : Hexagon::PS_fi; + auto MIB = BuildMI(BB, At, dl, HII->get(FiOpc), AddrR); + if (AR) + MIB.addReg(AR); + MIB.addFrameIndex(FI).addImm(Offset); + return AddrR; + }; + for (auto &P : VExtractMap) { unsigned VecR = P.first; if (P.second.size() <= VExtractThreshold) continue; const auto &VecRC = *MRI.getRegClass(VecR); - int FI = MFI.CreateSpillStackObject(HRI.getSpillSize(VecRC), - HRI.getSpillAlignment(VecRC)); + unsigned Align = HRI.getSpillAlignment(VecRC); + MaxAlign = std::max(MaxAlign, Align); + // Make sure this is not a spill slot: spill slots cannot be aligned + // if there are variable-sized objects on the stack. They must be + // accessible via FP (which is not aligned), because SP is unknown, + // and AP may not be available at the location of the load/store. + int FI = MFI.CreateStackObject(HRI.getSpillSize(VecRC), Align, + /*isSpillSlot*/false); + MachineInstr *DefI = MRI.getVRegDef(VecR); MachineBasicBlock::iterator At = std::next(DefI->getIterator()); MachineBasicBlock &DefB = *DefI->getParent(); unsigned StoreOpc = VecRC.getID() == Hexagon::HvxVRRegClassID ? Hexagon::V6_vS32b_ai : Hexagon::PS_vstorerw_ai; + Register AddrR = EmitAddr(DefB, At, DefI->getDebugLoc(), FI, 0); BuildMI(DefB, At, DefI->getDebugLoc(), HII->get(StoreOpc)) - .addFrameIndex(FI) + .addReg(AddrR) .addImm(0) .addReg(VecR); @@ -144,10 +167,8 @@ bool HexagonVExtract::runOnMachineFunction(MachineFunction &MF) { MachineBasicBlock &ExtB = *ExtI->getParent(); DebugLoc DL = ExtI->getDebugLoc(); - Register BaseR = MRI.createVirtualRegister(&Hexagon::IntRegsRegClass); - BuildMI(ExtB, ExtI, DL, HII->get(Hexagon::PS_fi), BaseR) - .addFrameIndex(FI) - .addImm(SR == 0 ? 0 : VecSize/2); + Register BaseR = EmitAddr(ExtB, ExtI, ExtI->getDebugLoc(), FI, + SR == 0 ? 0 : VecSize/2); unsigned ElemR = genElemLoad(ExtI, BaseR, MRI); Register ExtR = ExtI->getOperand(0).getReg(); @@ -157,6 +178,15 @@ bool HexagonVExtract::runOnMachineFunction(MachineFunction &MF) { } } + if (AR) { + // Update the required stack alignment. + MachineInstr *AlignaI = MRI.getVRegDef(AR); + assert(AlignaI->getOpcode() == Hexagon::PS_aligna); + MachineOperand &Op = AlignaI->getOperand(1); + if (MaxAlign > Op.getImm()) + Op.setImm(MaxAlign); + } + return Changed; } |