1*0b57cec5SDimitry Andric //===-- BPFFrameLowering.cpp - BPF Frame Information ----------------------===//
2*0b57cec5SDimitry Andric //
3*0b57cec5SDimitry Andric // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4*0b57cec5SDimitry Andric // See https://llvm.org/LICENSE.txt for license information.
5*0b57cec5SDimitry Andric // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6*0b57cec5SDimitry Andric //
7*0b57cec5SDimitry Andric //===----------------------------------------------------------------------===//
8*0b57cec5SDimitry Andric //
9*0b57cec5SDimitry Andric // This file contains the BPF implementation of TargetFrameLowering class.
10*0b57cec5SDimitry Andric //
11*0b57cec5SDimitry Andric //===----------------------------------------------------------------------===//
12*0b57cec5SDimitry Andric
13*0b57cec5SDimitry Andric #include "BPFFrameLowering.h"
14*0b57cec5SDimitry Andric #include "BPFInstrInfo.h"
15*0b57cec5SDimitry Andric #include "BPFSubtarget.h"
16*0b57cec5SDimitry Andric #include "llvm/CodeGen/MachineFrameInfo.h"
17*0b57cec5SDimitry Andric #include "llvm/CodeGen/MachineFunction.h"
18*0b57cec5SDimitry Andric #include "llvm/CodeGen/MachineInstrBuilder.h"
19*0b57cec5SDimitry Andric #include "llvm/CodeGen/MachineRegisterInfo.h"
20*0b57cec5SDimitry Andric
21*0b57cec5SDimitry Andric using namespace llvm;
22*0b57cec5SDimitry Andric
hasFP(const MachineFunction & MF) const23*0b57cec5SDimitry Andric bool BPFFrameLowering::hasFP(const MachineFunction &MF) const { return true; }
24*0b57cec5SDimitry Andric
emitPrologue(MachineFunction & MF,MachineBasicBlock & MBB) const25*0b57cec5SDimitry Andric void BPFFrameLowering::emitPrologue(MachineFunction &MF,
26*0b57cec5SDimitry Andric MachineBasicBlock &MBB) const {}
27*0b57cec5SDimitry Andric
emitEpilogue(MachineFunction & MF,MachineBasicBlock & MBB) const28*0b57cec5SDimitry Andric void BPFFrameLowering::emitEpilogue(MachineFunction &MF,
29*0b57cec5SDimitry Andric MachineBasicBlock &MBB) const {}
30*0b57cec5SDimitry Andric
determineCalleeSaves(MachineFunction & MF,BitVector & SavedRegs,RegScavenger * RS) const31*0b57cec5SDimitry Andric void BPFFrameLowering::determineCalleeSaves(MachineFunction &MF,
32*0b57cec5SDimitry Andric BitVector &SavedRegs,
33*0b57cec5SDimitry Andric RegScavenger *RS) const {
34*0b57cec5SDimitry Andric TargetFrameLowering::determineCalleeSaves(MF, SavedRegs, RS);
35*0b57cec5SDimitry Andric SavedRegs.reset(BPF::R6);
36*0b57cec5SDimitry Andric SavedRegs.reset(BPF::R7);
37*0b57cec5SDimitry Andric SavedRegs.reset(BPF::R8);
38*0b57cec5SDimitry Andric SavedRegs.reset(BPF::R9);
39*0b57cec5SDimitry Andric }
40