//=- HexagonMachineFunctionInfo.h - Hexagon machine function info -*- C++ -*-=// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// #ifndef LLVM_LIB_TARGET_HEXAGON_HEXAGONMACHINEFUNCTIONINFO_H #define LLVM_LIB_TARGET_HEXAGON_HEXAGONMACHINEFUNCTIONINFO_H #include "llvm/CodeGen/MachineFunction.h" #include namespace llvm { namespace Hexagon { const unsigned int StartPacket = 0x1; const unsigned int EndPacket = 0x2; } // end namespace Hexagon /// Hexagon target-specific information for each MachineFunction. class HexagonMachineFunctionInfo : public MachineFunctionInfo { // SRetReturnReg - Some subtargets require that sret lowering includes // returning the value of the returned struct in a register. This field // holds the virtual register into which the sret argument is passed. unsigned SRetReturnReg = 0; unsigned StackAlignBaseVReg = 0; // Aligned-stack base register (virtual) unsigned StackAlignBasePhysReg = 0; // (physical) int VarArgsFrameIndex; int RegSavedAreaStartFrameIndex; int FirstNamedArgFrameIndex; int LastNamedArgFrameIndex; bool HasClobberLR = false; bool HasEHReturn = false; std::map PacketInfo; virtual void anchor(); public: HexagonMachineFunctionInfo() = default; HexagonMachineFunctionInfo(MachineFunction &MF) {} MachineFunctionInfo * clone(BumpPtrAllocator &Allocator, MachineFunction &DestMF, const DenseMap &Src2DstMBB) const override; unsigned getSRetReturnReg() const { return SRetReturnReg; } void setSRetReturnReg(unsigned Reg) { SRetReturnReg = Reg; } void setVarArgsFrameIndex(int v) { VarArgsFrameIndex = v; } int getVarArgsFrameIndex() { return VarArgsFrameIndex; } void setRegSavedAreaStartFrameIndex(int v) { RegSavedAreaStartFrameIndex = v;} int getRegSavedAreaStartFrameIndex() { return RegSavedAreaStartFrameIndex; } void setFirstNamedArgFrameIndex(int v) { FirstNamedArgFrameIndex = v; } int getFirstNamedArgFrameIndex() { return FirstNamedArgFrameIndex; } void setLastNamedArgFrameIndex(int v) { LastNamedArgFrameIndex = v; } int getLastNamedArgFrameIndex() { return LastNamedArgFrameIndex; } void setStartPacket(MachineInstr* MI) { PacketInfo[MI] |= Hexagon::StartPacket; } void setEndPacket(MachineInstr* MI) { PacketInfo[MI] |= Hexagon::EndPacket; } bool isStartPacket(const MachineInstr* MI) const { return (PacketInfo.count(MI) && (PacketInfo.find(MI)->second & Hexagon::StartPacket)); } bool isEndPacket(const MachineInstr* MI) const { return (PacketInfo.count(MI) && (PacketInfo.find(MI)->second & Hexagon::EndPacket)); } void setHasClobberLR(bool v) { HasClobberLR = v; } bool hasClobberLR() const { return HasClobberLR; } bool hasEHReturn() const { return HasEHReturn; }; void setHasEHReturn(bool H = true) { HasEHReturn = H; }; void setStackAlignBaseVReg(unsigned R) { StackAlignBaseVReg = R; } unsigned getStackAlignBaseVReg() const { return StackAlignBaseVReg; } void setStackAlignBasePhysReg(unsigned R) { StackAlignBasePhysReg = R; } unsigned getStackAlignBasePhysReg() const { return StackAlignBasePhysReg; } }; } // end namespace llvm #endif // LLVM_LIB_TARGET_HEXAGON_HEXAGONMACHINEFUNCTIONINFO_H