Crate gemachain_rbpf[][src]

Expand description

Virtual machine and JIT compiler for eBPF programs.

Modules

Aligned memory

This module translates eBPF assembly language to binary.

Call frame handler

Functions in this module are used to handle eBPF programs with a higher level representation, for example to disassemble the code into a human-readable format.

This module contains all the definitions related to eBPF, and some functions permitting to manipulate eBPF instructions.

This module relocates a BPF ELF

This module contains all the definitions related to eBPF, and some functions permitting to manipulate eBPF instructions.

This module defines memory regions

Module provides API to create eBPF programs by Rust programming language

This module defines memory regions

Static Byte Code Analysis

This module implements some built-in syscalls that can be called from within an eBPF program.

This module defines an example user error definition

This “verifier” performs simple checks when the eBPF program is loaded into the VM (before it is interpreted or JIT-compiled). It has nothing to do with the much more elaborated verifier inside Linux kernel. There is no verification regarding the program flow control (should be a Direct Acyclic Graph) or the consistency for registers usage (the verifier of the kernel assigns types to the registers and is much stricter).

Virtual machine and JIT compiler for eBPF programs.

Macros

Error handling for SyscallObject::call methods