1//===-- BPFInstrFormats.td - BPF Instruction Formats -------*- tablegen -*-===// 2// 3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. 4// See https://llvm.org/LICENSE.txt for license information. 5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception 6// 7//===----------------------------------------------------------------------===// 8 9class BPFOpClass<bits<3> val> { 10 bits<3> Value = val; 11} 12 13def BPF_LD : BPFOpClass<0x0>; 14def BPF_LDX : BPFOpClass<0x1>; 15def BPF_ST : BPFOpClass<0x2>; 16def BPF_STX : BPFOpClass<0x3>; 17def BPF_ALU : BPFOpClass<0x4>; 18def BPF_JMP : BPFOpClass<0x5>; 19def BPF_JMP32 : BPFOpClass<0x6>; 20def BPF_ALU64 : BPFOpClass<0x7>; 21 22class BPFSrcType<bits<1> val> { 23 bits<1> Value = val; 24} 25 26def BPF_K : BPFSrcType<0x0>; 27def BPF_X : BPFSrcType<0x1>; 28 29class BPFArithOp<bits<4> val> { 30 bits<4> Value = val; 31} 32 33def BPF_ADD : BPFArithOp<0x0>; 34def BPF_SUB : BPFArithOp<0x1>; 35def BPF_MUL : BPFArithOp<0x2>; 36def BPF_DIV : BPFArithOp<0x3>; 37def BPF_OR : BPFArithOp<0x4>; 38def BPF_AND : BPFArithOp<0x5>; 39def BPF_LSH : BPFArithOp<0x6>; 40def BPF_RSH : BPFArithOp<0x7>; 41def BPF_NEG : BPFArithOp<0x8>; 42def BPF_MOD : BPFArithOp<0x9>; 43def BPF_XOR : BPFArithOp<0xa>; 44def BPF_MOV : BPFArithOp<0xb>; 45def BPF_ARSH : BPFArithOp<0xc>; 46def BPF_END : BPFArithOp<0xd>; 47 48def BPF_XCHG : BPFArithOp<0xe>; 49def BPF_CMPXCHG : BPFArithOp<0xf>; 50 51class BPFAtomicOp<bits<5> val> { 52 bits<5> Value = val; 53} 54 55def BPF_LOAD_ACQ : BPFAtomicOp<0x10>; 56def BPF_STORE_REL : BPFAtomicOp<0x11>; 57 58class BPFEndDir<bits<1> val> { 59 bits<1> Value = val; 60} 61 62def BPF_TO_LE : BPFSrcType<0x0>; 63def BPF_TO_BE : BPFSrcType<0x1>; 64 65class BPFJumpOp<bits<4> val> { 66 bits<4> Value = val; 67} 68 69def BPF_JA : BPFJumpOp<0x0>; 70def BPF_JEQ : BPFJumpOp<0x1>; 71def BPF_JGT : BPFJumpOp<0x2>; 72def BPF_JGE : BPFJumpOp<0x3>; 73def BPF_JSET : BPFJumpOp<0x4>; 74def BPF_JNE : BPFJumpOp<0x5>; 75def BPF_JSGT : BPFJumpOp<0x6>; 76def BPF_JSGE : BPFJumpOp<0x7>; 77def BPF_CALL : BPFJumpOp<0x8>; 78def BPF_EXIT : BPFJumpOp<0x9>; 79def BPF_JLT : BPFJumpOp<0xa>; 80def BPF_JLE : BPFJumpOp<0xb>; 81def BPF_JSLT : BPFJumpOp<0xc>; 82def BPF_JSLE : BPFJumpOp<0xd>; 83def BPF_JCOND : BPFJumpOp<0xe>; 84 85class BPFWidthModifer<bits<2> val> { 86 bits<2> Value = val; 87} 88 89def BPF_W : BPFWidthModifer<0x0>; 90def BPF_H : BPFWidthModifer<0x1>; 91def BPF_B : BPFWidthModifer<0x2>; 92def BPF_DW : BPFWidthModifer<0x3>; 93 94class BPFModeModifer<bits<3> val> { 95 bits<3> Value = val; 96} 97 98def BPF_IMM : BPFModeModifer<0x0>; 99def BPF_ABS : BPFModeModifer<0x1>; 100def BPF_IND : BPFModeModifer<0x2>; 101def BPF_MEM : BPFModeModifer<0x3>; 102def BPF_MEMSX : BPFModeModifer<0x4>; 103def BPF_ATOMIC : BPFModeModifer<0x6>; 104 105class BPFAtomicFlag<bits<4> val> { 106 bits<4> Value = val; 107} 108 109def BPF_FETCH : BPFAtomicFlag<0x1>; 110 111class InstBPF<dag outs, dag ins, string asmstr, list<dag> pattern> 112 : Instruction { 113 field bits<64> Inst; 114 field bits<64> SoftFail = 0; 115 let Size = 8; 116 117 let Namespace = "BPF"; 118 let DecoderNamespace = "BPF"; 119 120 BPFOpClass BPFClass; 121 let Inst{58-56} = BPFClass.Value; 122 123 dag OutOperandList = outs; 124 dag InOperandList = ins; 125 let AsmString = asmstr; 126 let Pattern = pattern; 127} 128 129// Pseudo instructions 130class Pseudo<dag outs, dag ins, string asmstr, list<dag> pattern> 131 : InstBPF<outs, ins, asmstr, pattern> { 132 let Inst{63-0} = 0; 133 let isPseudo = 1; 134} 135