1*9880d681SAndroid Build Coastguard Worker //===-- BPFMCTargetDesc.h - BPF Target Descriptions -------------*- 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 provides BPF specific target descriptions. 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_MCTARGETDESC_BPFMCTARGETDESC_H 15*9880d681SAndroid Build Coastguard Worker #define LLVM_LIB_TARGET_BPF_MCTARGETDESC_BPFMCTARGETDESC_H 16*9880d681SAndroid Build Coastguard Worker 17*9880d681SAndroid Build Coastguard Worker #include "llvm/Support/DataTypes.h" 18*9880d681SAndroid Build Coastguard Worker #include "llvm/Config/config.h" 19*9880d681SAndroid Build Coastguard Worker 20*9880d681SAndroid Build Coastguard Worker namespace llvm { 21*9880d681SAndroid Build Coastguard Worker class MCAsmBackend; 22*9880d681SAndroid Build Coastguard Worker class MCCodeEmitter; 23*9880d681SAndroid Build Coastguard Worker class MCContext; 24*9880d681SAndroid Build Coastguard Worker class MCInstrInfo; 25*9880d681SAndroid Build Coastguard Worker class MCObjectWriter; 26*9880d681SAndroid Build Coastguard Worker class MCRegisterInfo; 27*9880d681SAndroid Build Coastguard Worker class MCSubtargetInfo; 28*9880d681SAndroid Build Coastguard Worker class StringRef; 29*9880d681SAndroid Build Coastguard Worker class Target; 30*9880d681SAndroid Build Coastguard Worker class Triple; 31*9880d681SAndroid Build Coastguard Worker class raw_ostream; 32*9880d681SAndroid Build Coastguard Worker class raw_pwrite_stream; 33*9880d681SAndroid Build Coastguard Worker 34*9880d681SAndroid Build Coastguard Worker extern Target TheBPFleTarget; 35*9880d681SAndroid Build Coastguard Worker extern Target TheBPFbeTarget; 36*9880d681SAndroid Build Coastguard Worker extern Target TheBPFTarget; 37*9880d681SAndroid Build Coastguard Worker 38*9880d681SAndroid Build Coastguard Worker MCCodeEmitter *createBPFMCCodeEmitter(const MCInstrInfo &MCII, 39*9880d681SAndroid Build Coastguard Worker const MCRegisterInfo &MRI, 40*9880d681SAndroid Build Coastguard Worker MCContext &Ctx); 41*9880d681SAndroid Build Coastguard Worker MCCodeEmitter *createBPFbeMCCodeEmitter(const MCInstrInfo &MCII, 42*9880d681SAndroid Build Coastguard Worker const MCRegisterInfo &MRI, 43*9880d681SAndroid Build Coastguard Worker MCContext &Ctx); 44*9880d681SAndroid Build Coastguard Worker 45*9880d681SAndroid Build Coastguard Worker MCAsmBackend *createBPFAsmBackend(const Target &T, const MCRegisterInfo &MRI, 46*9880d681SAndroid Build Coastguard Worker const Triple &TT, StringRef CPU); 47*9880d681SAndroid Build Coastguard Worker MCAsmBackend *createBPFbeAsmBackend(const Target &T, const MCRegisterInfo &MRI, 48*9880d681SAndroid Build Coastguard Worker const Triple &TT, StringRef CPU); 49*9880d681SAndroid Build Coastguard Worker 50*9880d681SAndroid Build Coastguard Worker MCObjectWriter *createBPFELFObjectWriter(raw_pwrite_stream &OS, 51*9880d681SAndroid Build Coastguard Worker uint8_t OSABI, bool IsLittleEndian); 52*9880d681SAndroid Build Coastguard Worker } 53*9880d681SAndroid Build Coastguard Worker 54*9880d681SAndroid Build Coastguard Worker // Defines symbolic names for BPF registers. This defines a mapping from 55*9880d681SAndroid Build Coastguard Worker // register name to register number. 56*9880d681SAndroid Build Coastguard Worker // 57*9880d681SAndroid Build Coastguard Worker #define GET_REGINFO_ENUM 58*9880d681SAndroid Build Coastguard Worker #include "BPFGenRegisterInfo.inc" 59*9880d681SAndroid Build Coastguard Worker 60*9880d681SAndroid Build Coastguard Worker // Defines symbolic names for the BPF instructions. 61*9880d681SAndroid Build Coastguard Worker // 62*9880d681SAndroid Build Coastguard Worker #define GET_INSTRINFO_ENUM 63*9880d681SAndroid Build Coastguard Worker #include "BPFGenInstrInfo.inc" 64*9880d681SAndroid Build Coastguard Worker 65*9880d681SAndroid Build Coastguard Worker #define GET_SUBTARGETINFO_ENUM 66*9880d681SAndroid Build Coastguard Worker #include "BPFGenSubtargetInfo.inc" 67*9880d681SAndroid Build Coastguard Worker 68*9880d681SAndroid Build Coastguard Worker #endif 69