mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-25 20:23:11 +01:00
bcf6ba62a2
Expose bpf pseudo load instruction via intrinsic. It is used by front-ends that can encode file descriptors directly into IR instead of relying on relocations. llvm-svn: 233396
25 lines
1.1 KiB
TableGen
25 lines
1.1 KiB
TableGen
//===- IntrinsicsBPF.td - Defines BPF intrinsics -----------*- tablegen -*-===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// This file defines all of the BPF-specific intrinsics.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
// Specialized loads from packet
|
|
let TargetPrefix = "bpf" in { // All intrinsics start with "llvm.bpf."
|
|
def int_bpf_load_byte : GCCBuiltin<"__builtin_bpf_load_byte">,
|
|
Intrinsic<[llvm_i64_ty], [llvm_ptr_ty, llvm_i64_ty], [IntrReadMem]>;
|
|
def int_bpf_load_half : GCCBuiltin<"__builtin_bpf_load_half">,
|
|
Intrinsic<[llvm_i64_ty], [llvm_ptr_ty, llvm_i64_ty], [IntrReadMem]>;
|
|
def int_bpf_load_word : GCCBuiltin<"__builtin_bpf_load_word">,
|
|
Intrinsic<[llvm_i64_ty], [llvm_ptr_ty, llvm_i64_ty], [IntrReadMem]>;
|
|
def int_bpf_pseudo : GCCBuiltin<"__builtin_bpf_pseudo">,
|
|
Intrinsic<[llvm_i64_ty], [llvm_i64_ty, llvm_i64_ty]>;
|
|
}
|