mirror of
https://github.com/RPCSX/llvm.git
synced 2024-12-13 14:46:53 +00:00
bc5bb8c0ae
since bpf instruction set was introduced people learned to read and understand kernel verifier output whereas llvm asm output stayed obscure and unknown. Convert llvm to emit assembler text similar to kernel to avoid this discrepancy Signed-off-by: Alexei Starovoitov <ast@kernel.org> git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@287300 91177308-0d34-0410-b5e6-96231b3b80d8
45 lines
1.1 KiB
TableGen
45 lines
1.1 KiB
TableGen
//===-- BPF.td - Describe the BPF Target Machine -----------*- tablegen -*-===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
include "llvm/Target/Target.td"
|
|
|
|
include "BPFRegisterInfo.td"
|
|
include "BPFCallingConv.td"
|
|
include "BPFInstrInfo.td"
|
|
|
|
def BPFInstrInfo : InstrInfo;
|
|
|
|
class Proc<string Name, list<SubtargetFeature> Features>
|
|
: Processor<Name, NoItineraries, Features>;
|
|
|
|
def : Proc<"generic", []>;
|
|
|
|
def BPFInstPrinter : AsmWriter {
|
|
string AsmWriterClassName = "InstPrinter";
|
|
bit isMCAsmWriter = 1;
|
|
}
|
|
|
|
def BPFAsmParser : AsmParser {
|
|
bit HasMnemonicFirst = 0;
|
|
}
|
|
|
|
def BPFAsmParserVariant : AsmParserVariant {
|
|
int Variant = 0;
|
|
string Name = "BPF";
|
|
string BreakCharacters = ".";
|
|
string TokenizingCharacters = "#()[]=:.<>!+*";
|
|
}
|
|
|
|
def BPF : Target {
|
|
let InstructionSet = BPFInstrInfo;
|
|
let AssemblyWriters = [BPFInstPrinter];
|
|
let AssemblyParsers = [BPFAsmParser];
|
|
let AssemblyParserVariants = [BPFAsmParserVariant];
|
|
}
|