1 //=- HexagonMachineFunctionInfo.h - Hexagon machine function info -*- C++ -*-=// 2 // 3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. 4 // See https://llvm.org/LICENSE.txt for license information. 5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception 6 // 7 //===----------------------------------------------------------------------===// 8 9 #ifndef LLVM_LIB_TARGET_HEXAGON_HEXAGONMACHINEFUNCTIONINFO_H 10 #define LLVM_LIB_TARGET_HEXAGON_HEXAGONMACHINEFUNCTIONINFO_H 11 12 #include "llvm/CodeGen/MachineFunction.h" 13 #include <map> 14 15 namespace llvm { 16 17 namespace Hexagon { 18 19 const unsigned int StartPacket = 0x1; 20 const unsigned int EndPacket = 0x2; 21 22 } // end namespace Hexagon 23 24 /// Hexagon target-specific information for each MachineFunction. 25 class HexagonMachineFunctionInfo : public MachineFunctionInfo { 26 // SRetReturnReg - Some subtargets require that sret lowering includes 27 // returning the value of the returned struct in a register. This field 28 // holds the virtual register into which the sret argument is passed. 29 unsigned SRetReturnReg = 0; 30 Register StackAlignBaseReg = 0; // Aligned-stack base register 31 int VarArgsFrameIndex; 32 int RegSavedAreaStartFrameIndex; 33 int FirstNamedArgFrameIndex; 34 int LastNamedArgFrameIndex; 35 bool HasClobberLR = false; 36 bool HasEHReturn = false; 37 std::map<const MachineInstr*, unsigned> PacketInfo; 38 virtual void anchor(); 39 40 public: 41 HexagonMachineFunctionInfo() = default; 42 HexagonMachineFunctionInfo(const Function & F,const TargetSubtargetInfo * STI)43 HexagonMachineFunctionInfo(const Function &F, 44 const TargetSubtargetInfo *STI) {} 45 46 MachineFunctionInfo * 47 clone(BumpPtrAllocator &Allocator, MachineFunction &DestMF, 48 const DenseMap<MachineBasicBlock *, MachineBasicBlock *> &Src2DstMBB) 49 const override; 50 getSRetReturnReg()51 unsigned getSRetReturnReg() const { return SRetReturnReg; } setSRetReturnReg(unsigned Reg)52 void setSRetReturnReg(unsigned Reg) { SRetReturnReg = Reg; } 53 setVarArgsFrameIndex(int v)54 void setVarArgsFrameIndex(int v) { VarArgsFrameIndex = v; } getVarArgsFrameIndex()55 int getVarArgsFrameIndex() { return VarArgsFrameIndex; } 56 setRegSavedAreaStartFrameIndex(int v)57 void setRegSavedAreaStartFrameIndex(int v) { RegSavedAreaStartFrameIndex = v;} getRegSavedAreaStartFrameIndex()58 int getRegSavedAreaStartFrameIndex() { return RegSavedAreaStartFrameIndex; } 59 setFirstNamedArgFrameIndex(int v)60 void setFirstNamedArgFrameIndex(int v) { FirstNamedArgFrameIndex = v; } getFirstNamedArgFrameIndex()61 int getFirstNamedArgFrameIndex() { return FirstNamedArgFrameIndex; } 62 setLastNamedArgFrameIndex(int v)63 void setLastNamedArgFrameIndex(int v) { LastNamedArgFrameIndex = v; } getLastNamedArgFrameIndex()64 int getLastNamedArgFrameIndex() { return LastNamedArgFrameIndex; } 65 setStartPacket(MachineInstr * MI)66 void setStartPacket(MachineInstr* MI) { 67 PacketInfo[MI] |= Hexagon::StartPacket; 68 } setEndPacket(MachineInstr * MI)69 void setEndPacket(MachineInstr* MI) { 70 PacketInfo[MI] |= Hexagon::EndPacket; 71 } isStartPacket(const MachineInstr * MI)72 bool isStartPacket(const MachineInstr* MI) const { 73 return (PacketInfo.count(MI) && 74 (PacketInfo.find(MI)->second & Hexagon::StartPacket)); 75 } isEndPacket(const MachineInstr * MI)76 bool isEndPacket(const MachineInstr* MI) const { 77 return (PacketInfo.count(MI) && 78 (PacketInfo.find(MI)->second & Hexagon::EndPacket)); 79 } setHasClobberLR(bool v)80 void setHasClobberLR(bool v) { HasClobberLR = v; } hasClobberLR()81 bool hasClobberLR() const { return HasClobberLR; } 82 hasEHReturn()83 bool hasEHReturn() const { return HasEHReturn; }; 84 void setHasEHReturn(bool H = true) { HasEHReturn = H; }; 85 setStackAlignBaseReg(Register R)86 void setStackAlignBaseReg(Register R) { StackAlignBaseReg = R; } getStackAlignBaseReg()87 Register getStackAlignBaseReg() const { return StackAlignBaseReg; } 88 }; 89 90 } // end namespace llvm 91 92 #endif // LLVM_LIB_TARGET_HEXAGON_HEXAGONMACHINEFUNCTIONINFO_H 93