LLVM 19.0.0git
Mips16FrameLowering.cpp
Go to the documentation of this file.
1//===- Mips16FrameLowering.cpp - Mips16 Frame Information -----------------===//
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// This file contains the Mips16 implementation of TargetFrameLowering class.
10//
11//===----------------------------------------------------------------------===//
12
13#include "Mips16FrameLowering.h"
15#include "Mips16InstrInfo.h"
16#include "MipsInstrInfo.h"
17#include "MipsRegisterInfo.h"
18#include "MipsSubtarget.h"
19#include "llvm/ADT/BitVector.h"
26#include "llvm/IR/DebugLoc.h"
27#include "llvm/MC/MCContext.h"
28#include "llvm/MC/MCDwarf.h"
33#include <cstdint>
34#include <vector>
35
36using namespace llvm;
37
39 : MipsFrameLowering(STI, STI.getStackAlignment()) {}
40
42 MachineBasicBlock &MBB) const {
44 const Mips16InstrInfo &TII =
45 *static_cast<const Mips16InstrInfo *>(STI.getInstrInfo());
47
48 // Debug location must be unknown since the first debug location is used
49 // to determine the end of the prologue.
50 DebugLoc dl;
51
52 uint64_t StackSize = MFI.getStackSize();
53
54 // No need to allocate space on the stack.
55 if (StackSize == 0 && !MFI.adjustsStack()) return;
56
57 MachineModuleInfo &MMI = MF.getMMI();
59
60 // Adjust stack.
61 TII.makeFrame(Mips::SP, StackSize, MBB, MBBI);
62
63 // emit ".cfi_def_cfa_offset StackSize"
64 unsigned CFIIndex =
65 MF.addFrameInst(MCCFIInstruction::cfiDefCfaOffset(nullptr, StackSize));
66 BuildMI(MBB, MBBI, dl, TII.get(TargetOpcode::CFI_INSTRUCTION))
67 .addCFIIndex(CFIIndex);
68
69 const std::vector<CalleeSavedInfo> &CSI = MFI.getCalleeSavedInfo();
70
71 if (!CSI.empty()) {
72 const std::vector<CalleeSavedInfo> &CSI = MFI.getCalleeSavedInfo();
73
74 for (const CalleeSavedInfo &I : CSI) {
75 int64_t Offset = MFI.getObjectOffset(I.getFrameIdx());
76 Register Reg = I.getReg();
77 unsigned DReg = MRI->getDwarfRegNum(Reg, true);
78 unsigned CFIIndex = MF.addFrameInst(
80 BuildMI(MBB, MBBI, dl, TII.get(TargetOpcode::CFI_INSTRUCTION))
81 .addCFIIndex(CFIIndex);
82 }
83 }
84 if (hasFP(MF))
85 BuildMI(MBB, MBBI, dl, TII.get(Mips::MoveR3216), Mips::S0)
87}
88
90 MachineBasicBlock &MBB) const {
93 const Mips16InstrInfo &TII =
94 *static_cast<const Mips16InstrInfo *>(STI.getInstrInfo());
95 DebugLoc dl = MBBI != MBB.end() ? MBBI->getDebugLoc() : DebugLoc();
96 uint64_t StackSize = MFI.getStackSize();
97
98 if (!StackSize)
99 return;
100
101 if (hasFP(MF))
102 BuildMI(MBB, MBBI, dl, TII.get(Mips::Move32R16), Mips::SP)
103 .addReg(Mips::S0);
104
105 // Adjust stack.
106 // assumes stacksize multiple of 8
107 TII.restoreFrame(Mips::SP, StackSize, MBB, MBBI);
108}
109
114
115 //
116 // Registers RA, S0,S1 are the callee saved registers and they
117 // will be saved with the "save" instruction
118 // during emitPrologue
119 //
120 for (const CalleeSavedInfo &I : CSI) {
121 // Add the callee-saved register as live-in. Do not add if the register is
122 // RA and return address is taken, because it has already been added in
123 // method MipsTargetLowering::lowerRETURNADDR.
124 // It's killed at the spill, unless the register is RA and return address
125 // is taken.
126 Register Reg = I.getReg();
127 bool IsRAAndRetAddrIsTaken = (Reg == Mips::RA)
129 if (!IsRAAndRetAddrIsTaken)
130 MBB.addLiveIn(Reg);
131 }
132
133 return true;
134}
135
139 //
140 // Registers RA,S0,S1 are the callee saved registers and they will be restored
141 // with the restore instruction during emitEpilogue.
142 // We need to override this virtual function, otherwise llvm will try and
143 // restore the registers on it's on from the stack.
144 //
145
146 return true;
147}
148
149bool
151 const MachineFrameInfo &MFI = MF.getFrameInfo();
152 // Reserve call frame if the size of the maximum call frame fits into 15-bit
153 // immediate field and there are no variable sized objects on the stack.
154 return isInt<15>(MFI.getMaxCallFrameSize()) && !MFI.hasVarSizedObjects();
155}
156
158 BitVector &SavedRegs,
159 RegScavenger *RS) const {
161 const Mips16InstrInfo &TII =
162 *static_cast<const Mips16InstrInfo *>(STI.getInstrInfo());
163 const MipsRegisterInfo &RI = TII.getRegisterInfo();
164 const BitVector Reserved = RI.getReservedRegs(MF);
165 bool SaveS2 = Reserved[Mips::S2];
166 if (SaveS2)
167 SavedRegs.set(Mips::S2);
168 if (hasFP(MF))
169 SavedRegs.set(Mips::S0);
170}
171
172const MipsFrameLowering *
174 return new Mips16FrameLowering(ST);
175}
unsigned const MachineRegisterInfo * MRI
MachineBasicBlock & MBB
MachineBasicBlock MachineBasicBlock::iterator MBBI
This file implements the BitVector class.
const HexagonInstrInfo * TII
IRTranslator LLVM IR MI
#define I(x, y, z)
Definition: MD5.cpp:58
unsigned const TargetRegisterInfo * TRI
ArrayRef - Represent a constant reference to an array (0 or more elements consecutively in memory),...
Definition: ArrayRef.h:41
BitVector & set()
Definition: BitVector.h:351
The CalleeSavedInfo class tracks the information need to locate where a callee saved register is in t...
A debug info location.
Definition: DebugLoc.h:33
static MCCFIInstruction createOffset(MCSymbol *L, unsigned Register, int Offset, SMLoc Loc={})
.cfi_offset Previous value of Register is saved at offset Offset from CFA.
Definition: MCDwarf.h:583
static MCCFIInstruction cfiDefCfaOffset(MCSymbol *L, int Offset, SMLoc Loc={})
.cfi_def_cfa_offset modifies a rule for computing CFA.
Definition: MCDwarf.h:556
const MCRegisterInfo * getRegisterInfo() const
Definition: MCContext.h:455
MCRegisterInfo base class - We assume that the target defines a static array of MCRegisterDesc object...
iterator getFirstTerminator()
Returns an iterator to the first terminator instruction of this basic block.
void addLiveIn(MCRegister PhysReg, LaneBitmask LaneMask=LaneBitmask::getAll())
Adds the specified register as a live in.
const MachineFunction * getParent() const
Return the MachineFunction containing this basic block.
The MachineFrameInfo class represents an abstract stack frame until prolog/epilog code is inserted.
bool hasVarSizedObjects() const
This method may be called any time after instruction selection is complete to determine if the stack ...
uint64_t getStackSize() const
Return the number of bytes that must be allocated to hold all of the fixed size frame objects.
bool adjustsStack() const
Return true if this function adjusts the stack – e.g., when calling another function.
bool isReturnAddressTaken() const
This method may be called any time after instruction selection is complete to determine if there is a...
const std::vector< CalleeSavedInfo > & getCalleeSavedInfo() const
Returns a reference to call saved info vector for the current function.
unsigned getMaxCallFrameSize() const
Return the maximum size of a call frame that must be allocated for an outgoing function call.
int64_t getObjectOffset(int ObjectIdx) const
Return the assigned stack offset of the specified object from the incoming stack pointer.
unsigned addFrameInst(const MCCFIInstruction &Inst)
MachineFrameInfo & getFrameInfo()
getFrameInfo - Return the frame info object for the current function.
MachineModuleInfo & getMMI() const
const MachineInstrBuilder & addCFIIndex(unsigned CFIIndex) const
const MachineInstrBuilder & setMIFlag(MachineInstr::MIFlag Flag) const
const MachineInstrBuilder & addReg(Register RegNo, unsigned flags=0, unsigned SubReg=0) const
Add a new virtual register operand.
This class contains meta information specific to a module.
const MCContext & getContext() const
void determineCalleeSaves(MachineFunction &MF, BitVector &SavedRegs, RegScavenger *RS) const override
This method determines which of the registers reported by TargetRegisterInfo::getCalleeSavedRegs() sh...
void emitEpilogue(MachineFunction &MF, MachineBasicBlock &MBB) const override
bool spillCalleeSavedRegisters(MachineBasicBlock &MBB, MachineBasicBlock::iterator MI, ArrayRef< CalleeSavedInfo > CSI, const TargetRegisterInfo *TRI) const override
spillCalleeSavedRegisters - Issues instruction(s) to spill all callee saved registers and returns tru...
bool hasReservedCallFrame(const MachineFunction &MF) const override
hasReservedCallFrame - Under normal circumstances, when a frame pointer is not required,...
Mips16FrameLowering(const MipsSubtarget &STI)
bool restoreCalleeSavedRegisters(MachineBasicBlock &MBB, MachineBasicBlock::iterator MI, MutableArrayRef< CalleeSavedInfo > CSI, const TargetRegisterInfo *TRI) const override
restoreCalleeSavedRegisters - Issues instruction(s) to restore all callee saved registers and returns...
void emitPrologue(MachineFunction &MF, MachineBasicBlock &MBB) const override
emitProlog/emitEpilog - These methods insert prolog and epilog code into the function.
bool hasFP(const MachineFunction &MF) const override
hasFP - Return true if the specified function should have a dedicated frame pointer register.
const MipsSubtarget & STI
BitVector getReservedRegs(const MachineFunction &MF) const override
const MipsInstrInfo * getInstrInfo() const override
MutableArrayRef - Represent a mutable reference to an array (0 or more elements consecutively in memo...
Definition: ArrayRef.h:307
Wrapper class representing virtual and physical registers.
Definition: Register.h:19
virtual void determineCalleeSaves(MachineFunction &MF, BitVector &SavedRegs, RegScavenger *RS=nullptr) const
This method determines which of the registers reported by TargetRegisterInfo::getCalleeSavedRegs() sh...
TargetRegisterInfo base class - We assume that the target defines a static array of TargetRegisterDes...
This is an optimization pass for GlobalISel generic memory operations.
Definition: AddressRanges.h:18
@ Offset
Definition: DWP.cpp:456
MachineInstrBuilder BuildMI(MachineFunction &MF, const MIMetadata &MIMD, const MCInstrDesc &MCID)
Builder interface. Specify how to create the initial instruction itself.
const MipsFrameLowering * createMips16FrameLowering(const MipsSubtarget &ST)
Create MipsFrameLowering objects.