003 File Manager
Current Path:
/usr/src/contrib/llvm-project/llvm/lib/Target/BPF
usr
/
src
/
contrib
/
llvm-project
/
llvm
/
lib
/
Target
/
BPF
/
📁
..
📁
AsmParser
📄
BPF.h
(1.33 KB)
📄
BPF.td
(1.63 KB)
📄
BPFAbstractMemberAccess.cpp
(33.35 KB)
📄
BPFAsmPrinter.cpp
(5.11 KB)
📄
BPFCORE.h
(1.16 KB)
📄
BPFCallingConv.td
(1.79 KB)
📄
BPFFrameLowering.cpp
(1.49 KB)
📄
BPFFrameLowering.h
(1.46 KB)
📄
BPFISelDAGToDAG.cpp
(16.73 KB)
📄
BPFISelLowering.cpp
(28.04 KB)
📄
BPFISelLowering.h
(5.33 KB)
📄
BPFInstrFormats.td
(2.81 KB)
📄
BPFInstrInfo.cpp
(8.23 KB)
📄
BPFInstrInfo.h
(2.43 KB)
📄
BPFInstrInfo.td
(30.55 KB)
📄
BPFMCInstLower.cpp
(2.62 KB)
📄
BPFMCInstLower.h
(1.17 KB)
📄
BPFMIChecking.cpp
(6.54 KB)
📄
BPFMIPeephole.cpp
(15.45 KB)
📄
BPFMISimplifyPatchable.cpp
(10.86 KB)
📄
BPFPreserveDIType.cpp
(3.93 KB)
📄
BPFRegisterInfo.cpp
(3.96 KB)
📄
BPFRegisterInfo.h
(1.23 KB)
📄
BPFRegisterInfo.td
(1.51 KB)
📄
BPFSelectionDAGInfo.cpp
(1.63 KB)
📄
BPFSelectionDAGInfo.h
(1.24 KB)
📄
BPFSubtarget.cpp
(1.84 KB)
📄
BPFSubtarget.h
(2.83 KB)
📄
BPFTargetMachine.cpp
(4.43 KB)
📄
BPFTargetMachine.h
(1.41 KB)
📄
BTF.def
(1015 B)
📄
BTF.h
(8.27 KB)
📄
BTFDebug.cpp
(41.2 KB)
📄
BTFDebug.h
(11.66 KB)
📁
Disassembler
📁
MCTargetDesc
📁
TargetInfo
Editing: BPFRegisterInfo.cpp
//===-- BPFRegisterInfo.cpp - BPF Register Information ----------*- 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 // //===----------------------------------------------------------------------===// // // This file contains the BPF implementation of the TargetRegisterInfo class. // //===----------------------------------------------------------------------===// #include "BPFRegisterInfo.h" #include "BPF.h" #include "BPFSubtarget.h" #include "llvm/CodeGen/MachineFrameInfo.h" #include "llvm/CodeGen/MachineFunction.h" #include "llvm/CodeGen/MachineInstrBuilder.h" #include "llvm/CodeGen/RegisterScavenging.h" #include "llvm/CodeGen/TargetFrameLowering.h" #include "llvm/CodeGen/TargetInstrInfo.h" #include "llvm/IR/DiagnosticInfo.h" #include "llvm/Support/ErrorHandling.h" #define GET_REGINFO_TARGET_DESC #include "BPFGenRegisterInfo.inc" using namespace llvm; BPFRegisterInfo::BPFRegisterInfo() : BPFGenRegisterInfo(BPF::R0) {} const MCPhysReg * BPFRegisterInfo::getCalleeSavedRegs(const MachineFunction *MF) const { return CSR_SaveList; } BitVector BPFRegisterInfo::getReservedRegs(const MachineFunction &MF) const { BitVector Reserved(getNumRegs()); markSuperRegs(Reserved, BPF::W10); // [W|R]10 is read only frame pointer markSuperRegs(Reserved, BPF::W11); // [W|R]11 is pseudo stack pointer return Reserved; } static void WarnSize(int Offset, MachineFunction &MF, DebugLoc& DL) { if (Offset <= -512) { const Function &F = MF.getFunction(); DiagnosticInfoUnsupported DiagStackSize(F, "Looks like the BPF stack limit of 512 bytes is exceeded. " "Please move large on stack variables into BPF per-cpu array map.\n", DL); F.getContext().diagnose(DiagStackSize); } } void BPFRegisterInfo::eliminateFrameIndex(MachineBasicBlock::iterator II, int SPAdj, unsigned FIOperandNum, RegScavenger *RS) const { assert(SPAdj == 0 && "Unexpected"); unsigned i = 0; MachineInstr &MI = *II; MachineBasicBlock &MBB = *MI.getParent(); MachineFunction &MF = *MBB.getParent(); DebugLoc DL = MI.getDebugLoc(); if (!DL) /* try harder to get some debug loc */ for (auto &I : MBB) if (I.getDebugLoc()) { DL = I.getDebugLoc(); break; } while (!MI.getOperand(i).isFI()) { ++i; assert(i < MI.getNumOperands() && "Instr doesn't have FrameIndex operand!"); } Register FrameReg = getFrameRegister(MF); int FrameIndex = MI.getOperand(i).getIndex(); const TargetInstrInfo &TII = *MF.getSubtarget().getInstrInfo(); if (MI.getOpcode() == BPF::MOV_rr) { int Offset = MF.getFrameInfo().getObjectOffset(FrameIndex); WarnSize(Offset, MF, DL); MI.getOperand(i).ChangeToRegister(FrameReg, false); Register reg = MI.getOperand(i - 1).getReg(); BuildMI(MBB, ++II, DL, TII.get(BPF::ADD_ri), reg) .addReg(reg) .addImm(Offset); return; } int Offset = MF.getFrameInfo().getObjectOffset(FrameIndex) + MI.getOperand(i + 1).getImm(); if (!isInt<32>(Offset)) llvm_unreachable("bug in frame offset"); WarnSize(Offset, MF, DL); if (MI.getOpcode() == BPF::FI_ri) { // architecture does not really support FI_ri, replace it with // MOV_rr <target_reg>, frame_reg // ADD_ri <target_reg>, imm Register reg = MI.getOperand(i - 1).getReg(); BuildMI(MBB, ++II, DL, TII.get(BPF::MOV_rr), reg) .addReg(FrameReg); BuildMI(MBB, II, DL, TII.get(BPF::ADD_ri), reg) .addReg(reg) .addImm(Offset); // Remove FI_ri instruction MI.eraseFromParent(); } else { MI.getOperand(i).ChangeToRegister(FrameReg, false); MI.getOperand(i + 1).ChangeToImmediate(Offset); } } Register BPFRegisterInfo::getFrameRegister(const MachineFunction &MF) const { return BPF::R10; }
Upload File
Create Folder