You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
Thomas Eizinger 8e746d08cd
Use `target_arch = "bpf"` for `panic_handler`-cfg
The `panic_handler` defined in the eBPF crate is only required if we are
compiling for the bpf target. When compiling for the host-system, be it to
run tests or by compiling the entire workspace with `cargo check --workspace`
we don't want to define the `panic_handler`, otherwise it will clash with
the one defined by the standard library.

Related: https://github.com/aya-rs/book/issues/214
7 months ago
.github ci: use latest stable rust 10 months ago
{{project-name}} Use aya-build 11 months ago
{{project-name}}-common Move dependencies to workspace 1 year ago
{{project-name}}-ebpf Use `target_arch = "bpf"` for `panic_handler`-cfg 7 months ago
.gitignore chore: remove Cargo.lock from .gitignore (#113) 1 year ago
Cargo.toml Use aya-build 11 months ago
README.md Always build eBPF; remove xtask 12 months ago
cargo-generate.toml docs: update LSM hook prompt to reference lsm_hook_defs.h 9 months ago
pre-script.rhai include and use clap only if needed 3 years ago
rustfmt.toml Add rustfmt to CI 1 year ago
test.sh Enable unwinding in userspace 11 months ago

README.md

{{project-name}}

Prerequisites

  1. stable rust toolchains: rustup toolchain install stable
  2. nightly rust toolchains: rustup toolchain install nightly --component rust-src
  3. (if cross-compiling) rustup target: rustup target add ${ARCH}-unknown-linux-musl
  4. (if cross-compiling) LLVM: (e.g.) brew install llvm (on macOS)
  5. (if cross-compiling) C toolchain: (e.g.) brew install filosottile/musl-cross/musl-cross (on macOS)
  6. bpf-linker: cargo install bpf-linker (--no-default-features on macOS)

Build & Run

Use cargo build, cargo check, etc. as normal. Run your program with:

cargo run --release --config 'target."cfg(all())".runner="sudo -E"'

Cargo build scripts are used to automatically build the eBPF correctly and include it in the program.

Cross-compiling on macOS

Cross compilation should work on both Intel and Apple Silicon Macs.

CC=${ARCH}-linux-musl-gcc cargo build --package {{project-name}} --release \
  --target=${ARCH}-unknown-linux-musl \
  --config=target.${ARCH}-unknown-linux-musl.linker=\"${ARCH}-linux-musl-gcc\"

The cross-compiled program target/${ARCH}-unknown-linux-musl/release/{{project-name}} can be copied to a Linux server or VM and run there.