1*9880d681SAndroid Build Coastguard Worker //===-- BPFInstrInfo.h - BPF Instruction Information ------------*- C++ -*-===// 2*9880d681SAndroid Build Coastguard Worker // 3*9880d681SAndroid Build Coastguard Worker // The LLVM Compiler Infrastructure 4*9880d681SAndroid Build Coastguard Worker // 5*9880d681SAndroid Build Coastguard Worker // This file is distributed under the University of Illinois Open Source 6*9880d681SAndroid Build Coastguard Worker // License. See LICENSE.TXT for details. 7*9880d681SAndroid Build Coastguard Worker // 8*9880d681SAndroid Build Coastguard Worker //===----------------------------------------------------------------------===// 9*9880d681SAndroid Build Coastguard Worker // 10*9880d681SAndroid Build Coastguard Worker // This file contains the BPF implementation of the TargetInstrInfo class. 11*9880d681SAndroid Build Coastguard Worker // 12*9880d681SAndroid Build Coastguard Worker //===----------------------------------------------------------------------===// 13*9880d681SAndroid Build Coastguard Worker 14*9880d681SAndroid Build Coastguard Worker #ifndef LLVM_LIB_TARGET_BPF_BPFINSTRINFO_H 15*9880d681SAndroid Build Coastguard Worker #define LLVM_LIB_TARGET_BPF_BPFINSTRINFO_H 16*9880d681SAndroid Build Coastguard Worker 17*9880d681SAndroid Build Coastguard Worker #include "BPFRegisterInfo.h" 18*9880d681SAndroid Build Coastguard Worker #include "llvm/Target/TargetInstrInfo.h" 19*9880d681SAndroid Build Coastguard Worker 20*9880d681SAndroid Build Coastguard Worker #define GET_INSTRINFO_HEADER 21*9880d681SAndroid Build Coastguard Worker #include "BPFGenInstrInfo.inc" 22*9880d681SAndroid Build Coastguard Worker 23*9880d681SAndroid Build Coastguard Worker namespace llvm { 24*9880d681SAndroid Build Coastguard Worker 25*9880d681SAndroid Build Coastguard Worker class BPFInstrInfo : public BPFGenInstrInfo { 26*9880d681SAndroid Build Coastguard Worker const BPFRegisterInfo RI; 27*9880d681SAndroid Build Coastguard Worker 28*9880d681SAndroid Build Coastguard Worker public: 29*9880d681SAndroid Build Coastguard Worker BPFInstrInfo(); 30*9880d681SAndroid Build Coastguard Worker getRegisterInfo()31*9880d681SAndroid Build Coastguard Worker const BPFRegisterInfo &getRegisterInfo() const { return RI; } 32*9880d681SAndroid Build Coastguard Worker 33*9880d681SAndroid Build Coastguard Worker void copyPhysReg(MachineBasicBlock &MBB, MachineBasicBlock::iterator I, 34*9880d681SAndroid Build Coastguard Worker const DebugLoc &DL, unsigned DestReg, unsigned SrcReg, 35*9880d681SAndroid Build Coastguard Worker bool KillSrc) const override; 36*9880d681SAndroid Build Coastguard Worker 37*9880d681SAndroid Build Coastguard Worker void storeRegToStackSlot(MachineBasicBlock &MBB, 38*9880d681SAndroid Build Coastguard Worker MachineBasicBlock::iterator MBBI, unsigned SrcReg, 39*9880d681SAndroid Build Coastguard Worker bool isKill, int FrameIndex, 40*9880d681SAndroid Build Coastguard Worker const TargetRegisterClass *RC, 41*9880d681SAndroid Build Coastguard Worker const TargetRegisterInfo *TRI) const override; 42*9880d681SAndroid Build Coastguard Worker 43*9880d681SAndroid Build Coastguard Worker void loadRegFromStackSlot(MachineBasicBlock &MBB, 44*9880d681SAndroid Build Coastguard Worker MachineBasicBlock::iterator MBBI, unsigned DestReg, 45*9880d681SAndroid Build Coastguard Worker int FrameIndex, const TargetRegisterClass *RC, 46*9880d681SAndroid Build Coastguard Worker const TargetRegisterInfo *TRI) const override; 47*9880d681SAndroid Build Coastguard Worker bool analyzeBranch(MachineBasicBlock &MBB, MachineBasicBlock *&TBB, 48*9880d681SAndroid Build Coastguard Worker MachineBasicBlock *&FBB, 49*9880d681SAndroid Build Coastguard Worker SmallVectorImpl<MachineOperand> &Cond, 50*9880d681SAndroid Build Coastguard Worker bool AllowModify) const override; 51*9880d681SAndroid Build Coastguard Worker 52*9880d681SAndroid Build Coastguard Worker unsigned RemoveBranch(MachineBasicBlock &MBB) const override; 53*9880d681SAndroid Build Coastguard Worker unsigned InsertBranch(MachineBasicBlock &MBB, MachineBasicBlock *TBB, 54*9880d681SAndroid Build Coastguard Worker MachineBasicBlock *FBB, ArrayRef<MachineOperand> Cond, 55*9880d681SAndroid Build Coastguard Worker const DebugLoc &DL) const override; 56*9880d681SAndroid Build Coastguard Worker }; 57*9880d681SAndroid Build Coastguard Worker } 58*9880d681SAndroid Build Coastguard Worker 59*9880d681SAndroid Build Coastguard Worker #endif 60