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.
		
		
		
		
		
			| Doesn't make much sense in a workspace. | 11 months ago | |
|---|---|---|
| .github | 11 months ago | |
| {{project-name}} | 11 months ago | |
| {{project-name}}-common | 1 year ago | |
| {{project-name}}-ebpf | 11 months ago | |
| .gitignore | 1 year ago | |
| Cargo.toml | 11 months ago | |
| README.md | 12 months ago | |
| cargo-generate.toml | 2 years ago | |
| pre-script.rhai | 3 years ago | |
| rustfmt.toml | 1 year ago | |
| test.sh | 11 months ago | |
		
			
				
				README.md
			
		
		
			
			
		
	
	{{project-name}}
Prerequisites
- 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)
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.