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: BPFInstrFormats.td
//===-- BPFInstrFormats.td - BPF Instruction Formats -------*- tablegen -*-===// // // 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 // //===----------------------------------------------------------------------===// class BPFOpClass<bits<3> val> { bits<3> Value = val; } def BPF_LD : BPFOpClass<0x0>; def BPF_LDX : BPFOpClass<0x1>; def BPF_ST : BPFOpClass<0x2>; def BPF_STX : BPFOpClass<0x3>; def BPF_ALU : BPFOpClass<0x4>; def BPF_JMP : BPFOpClass<0x5>; def BPF_JMP32 : BPFOpClass<0x6>; def BPF_ALU64 : BPFOpClass<0x7>; class BPFSrcType<bits<1> val> { bits<1> Value = val; } def BPF_K : BPFSrcType<0x0>; def BPF_X : BPFSrcType<0x1>; class BPFArithOp<bits<4> val> { bits<4> Value = val; } def BPF_ADD : BPFArithOp<0x0>; def BPF_SUB : BPFArithOp<0x1>; def BPF_MUL : BPFArithOp<0x2>; def BPF_DIV : BPFArithOp<0x3>; def BPF_OR : BPFArithOp<0x4>; def BPF_AND : BPFArithOp<0x5>; def BPF_LSH : BPFArithOp<0x6>; def BPF_RSH : BPFArithOp<0x7>; def BPF_NEG : BPFArithOp<0x8>; def BPF_XOR : BPFArithOp<0xa>; def BPF_MOV : BPFArithOp<0xb>; def BPF_ARSH : BPFArithOp<0xc>; def BPF_END : BPFArithOp<0xd>; class BPFEndDir<bits<1> val> { bits<1> Value = val; } def BPF_TO_LE : BPFSrcType<0x0>; def BPF_TO_BE : BPFSrcType<0x1>; class BPFJumpOp<bits<4> val> { bits<4> Value = val; } def BPF_JA : BPFJumpOp<0x0>; def BPF_JEQ : BPFJumpOp<0x1>; def BPF_JGT : BPFJumpOp<0x2>; def BPF_JGE : BPFJumpOp<0x3>; def BPF_JNE : BPFJumpOp<0x5>; def BPF_JSGT : BPFJumpOp<0x6>; def BPF_JSGE : BPFJumpOp<0x7>; def BPF_CALL : BPFJumpOp<0x8>; def BPF_EXIT : BPFJumpOp<0x9>; def BPF_JLT : BPFJumpOp<0xa>; def BPF_JLE : BPFJumpOp<0xb>; def BPF_JSLT : BPFJumpOp<0xc>; def BPF_JSLE : BPFJumpOp<0xd>; class BPFWidthModifer<bits<2> val> { bits<2> Value = val; } def BPF_W : BPFWidthModifer<0x0>; def BPF_H : BPFWidthModifer<0x1>; def BPF_B : BPFWidthModifer<0x2>; def BPF_DW : BPFWidthModifer<0x3>; class BPFModeModifer<bits<3> val> { bits<3> Value = val; } def BPF_IMM : BPFModeModifer<0x0>; def BPF_ABS : BPFModeModifer<0x1>; def BPF_IND : BPFModeModifer<0x2>; def BPF_MEM : BPFModeModifer<0x3>; def BPF_XADD : BPFModeModifer<0x6>; class InstBPF<dag outs, dag ins, string asmstr, list<dag> pattern> : Instruction { field bits<64> Inst; field bits<64> SoftFail = 0; let Size = 8; let Namespace = "BPF"; let DecoderNamespace = "BPF"; BPFOpClass BPFClass; let Inst{58-56} = BPFClass.Value; dag OutOperandList = outs; dag InOperandList = ins; let AsmString = asmstr; let Pattern = pattern; } // Pseudo instructions class Pseudo<dag outs, dag ins, string asmstr, list<dag> pattern> : InstBPF<outs, ins, asmstr, pattern> { let Inst{63-0} = 0; let isPseudo = 1; }
Upload File
Create Folder