- stable rust toolchains: rustup toolchain install stable
- nightly rust toolchains: rustup toolchain install nightly --component rust-src
- (if cross-compiling) rustup target: rustup target add ${ARCH}-unknown-linux-musl
- (if cross-compiling) LLVM: (e.g.) brew install llvm(on macOS)
- (if cross-compiling) C toolchain: (e.g.) brew install filosottile/musl-cross/musl-cross(on macOS)
- bpf-linker: cargo install bpf-linker(--no-default-featureson macOS)
$ AYA_BUILD_EBPF=true cargo build --releaseor
$ makeCross compilation should work on both Intel and Apple Silicon Macs.
AYA_BUILD_EBPF=true CC=${ARCH}-linux-musl-gcc cargo build --package rust-memleak --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/rust-memleak can be
copied to a Linux server or VM and run there.
The target Rust application needs to enable stack frame compilation:
$ RUSTFLAGS="-C force-frame-pointers=yes" cargo build
Usage: rust-memleak [OPTIONS] --pid <PID>
Options:
  -p, --pid <PID>            pid of the process
  -b, --bin <BIN>            binary path [optional]
  -t, --timeout <TIMEOUT>    timeout in seconds [default: 30]
  -o, --output <OUTPUT>      output file [default: /tmp/memleak.out]
  -v, --verbose              verbose mode
  -h, --help                 Print help# ./target/debug/rust-memleak --pid 20088Generating flame graphs:
# ./FlameGraph/flamegraph.pl /tmp/memleak.out > /tmp/1.svgFlame graph:
https://github.com/rust-lang/rust/blob/master/library/alloc/src/alloc.rs#L16-L38
https://github.com/iovisor/bcc/blob/master/libbpf-tools/memleak.bpf.c