Skip to content

Commit

Permalink
Add cargo-build-bpf
Browse files Browse the repository at this point in the history
  • Loading branch information
mvines committed Oct 21, 2020
1 parent 46d0019 commit 600050d
Show file tree
Hide file tree
Showing 9 changed files with 167 additions and 46 deletions.
2 changes: 2 additions & 0 deletions Xargo.toml
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
[target.bpfel-unknown-unknown.dependencies.std]
features = []
40 changes: 40 additions & 0 deletions cargo-build-bpf
Original file line number Diff line number Diff line change
@@ -0,0 +1,40 @@
#!/usr/bin/env bash

usage() {
cat <<EOF
cargo-build-bpf
Compile a local package and all of its dependencies as Solana BPF
USAGE:
cargo build-bpf [OPTIONS]
OPTIONS:
-h, --help Prints help information
... All other options are passed verbatum to "xargo build"
EOF
exit 0
}

if [[ $1 = build-bpf ]]; then
# When run as `cargo build-bpf`, "build-bpf" is set as arg 1. Remove it
shift
fi

bpf_sdk=$(cd "$(dirname "$0")"/sdk/bpf && pwd)

args=()
while [[ -n $1 ]]; do
if [[ $1 = -h ]] || [[ $1 = --help ]]; then
usage
fi
args+=("$1")
shift 1
done

if [[ ! -d $bpf_sdk ]]; then
echo "Error: not a directory: $bpf_sdk"
exit 1
fi

exec "$bpf_sdk"/rust/xargo-build.sh "${args[@]}"
1 change: 1 addition & 0 deletions ci/publish-tarball.sh
Original file line number Diff line number Diff line change
Expand Up @@ -87,6 +87,7 @@ echo --- Creating release tarball

mkdir -p "${RELEASE_BASENAME}"/bin/sdk/bpf
cp -a sdk/bpf/* "${RELEASE_BASENAME}"/bin/sdk/bpf
cp cargo-build-bpf "${RELEASE_BASENAME}"/bin/

tar cvf "${TARBALL_BASENAME}"-$TARGET.tar "${RELEASE_BASENAME}"
bzip2 "${TARBALL_BASENAME}"-$TARGET.tar
Expand Down
39 changes: 39 additions & 0 deletions sdk/bpf/env.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
#
# Configures the BPF SDK environment
#

if [ -z "$bpf_sdk" ]; then
bpf_sdk=.
fi

# Ensure the sdk is installed
"$bpf_sdk"/scripts/install.sh

# Use the SDK's version of llvm to build the compiler-builtins for BPF
export CC="$bpf_sdk/dependencies/llvm-native/bin/clang"
export AR="$bpf_sdk/dependencies/llvm-native/bin/llvm-ar"
export OBJDUMP="$bpf_sdk/dependencies/llvm-native/bin/llvm-objdump"
export OBJCOPY="$bpf_sdk/dependencies/llvm-native/bin/llvm-objcopy"

# Use the SDK's version of Rust to build for BPF
export RUSTUP_TOOLCHAIN=bpf
export RUSTFLAGS="
-C lto=no \
-C opt-level=2 \
-C link-arg=-z -C link-arg=notext \
-C link-arg=-T$bpf_sdk/rust/bpf.ld \
-C link-arg=--Bdynamic \
-C link-arg=-shared \
-C link-arg=--entry=entrypoint \
-C link-arg=-no-threads \
-C linker=$bpf_sdk/dependencies/llvm-native/bin/ld.lld"

# CARGO may be set if run from within cargo, causing
# incompatibilities between cargo and xargo versions
unset CARGO

export XARGO="$bpf_sdk"/dependencies/xargo/bin/xargo
export XARGO_TARGET=bpfel-unknown-unknown
export XARGO_HOME="$bpf_sdk/dependencies/xargo"
export XARGO_RUST_SRC="$bpf_sdk/dependencies/rust-bpf-sysroot/src"
export RUST_COMPILER_RT_ROOT="$bpf_sdk/dependencies/rust-bpf-sysroot/src/compiler-rt"
40 changes: 6 additions & 34 deletions sdk/bpf/rust/build.sh
Original file line number Diff line number Diff line change
@@ -1,49 +1,21 @@
#!/usr/bin/env bash

if [ "$#" -ne 1 ]; then
if [[ "$#" -ne 1 ]]; then
echo "Error: Must provide the full path to the project to build"
exit 1
fi
if [ ! -f "$1/Cargo.toml" ]; then
if [[ ! -f "$1/Cargo.toml" ]]; then
echo "Error: Cannot find project: $1"
exit 1
fi
bpf_sdk=$(cd "$(dirname "$0")/.." && pwd)

echo "Building $1"
set -e

bpf_sdk=$(cd "$(dirname "$0")/.." && pwd)

# Ensure the sdk is installed
"$bpf_sdk"/scripts/install.sh

# Use the SDK's version of llvm to build the compiler-builtins for BPF
export CC="$bpf_sdk/dependencies/llvm-native/bin/clang"
export AR="$bpf_sdk/dependencies/llvm-native/bin/llvm-ar"

# Use the SDK's version of Rust to build for BPF
export RUSTUP_TOOLCHAIN=bpf
export RUSTFLAGS="
-C lto=no \
-C opt-level=2 \
-C link-arg=-z -C link-arg=notext \
-C link-arg=-T$bpf_sdk/rust/bpf.ld \
-C link-arg=--Bdynamic \
-C link-arg=-shared \
-C link-arg=--entry=entrypoint \
-C link-arg=-no-threads \
-C linker=$bpf_sdk/dependencies/llvm-native/bin/ld.lld"

# CARGO may be set if build.sh is run from within cargo, causing
# incompatibilities between cargo and xargo versions
unset CARGO

# Setup xargo
export XARGO_HOME="$bpf_sdk/dependencies/xargo"
export XARGO_RUST_SRC="$bpf_sdk/dependencies/rust-bpf-sysroot/src"
export RUST_COMPILER_RT_ROOT="$bpf_sdk/dependencies/rust-bpf-sysroot/src/compiler-rt"
# shellcheck source=sdk/bpf/env.sh
source "$bpf_sdk"/env.sh

cd "$1"
xargo build --target bpfel-unknown-unknown --release --no-default-features --features program
"$XARGO" build --target "$XARGO_TARGET" --release --no-default-features --features program

{ { set +x; } 2>/dev/null; echo Success; }
7 changes: 7 additions & 0 deletions sdk/bpf/rust/xargo-build.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
#!/usr/bin/env bash

bpf_sdk=$(cd "$(dirname "$0")/.." && pwd)
# shellcheck source=sdk/bpf/env.sh
source "$bpf_sdk"/env.sh
set -x
exec "$XARGO" build --target "$XARGO_TARGET" --release "$@"
48 changes: 48 additions & 0 deletions sdk/bpf/scripts/dump.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,48 @@
#!/usr/bin/env bash

bpf_sdk=$(cd "$(dirname "$0")/.." && pwd)
# shellcheck source=sdk/bpf/env.sh
source "$bpf_sdk"/env.sh

so="$1"
if [[ -z $so ]]; then
echo "Usage: $0 bpf-program.so"
exit 1
fi

if [[ ! -r $so ]]; then
echo "Error: File not found or readable: $so"
exit 1
fi

if ! command -v rustfilt > /dev/null; then
echo "Error: rustfilt not found. It can be installed by running: cargo install rustfilt"
exit 1
fi
if ! command -v readelf > /dev/null; then
if [[ $(uname) = Darwin ]]; then
echo "Error: readelf not found. It can be installed by running: brew install binutils"
else
echo "Error: readelf not found."
fi
exit 1
fi

dump="${so%.*}"_dump.txt
dump_mangled=$(basename "$so")_dump-mangled.txt

(
set -ex
ls -la "$so" > "$dump_mangled"
readelf -aW "$so" >>"$dump_mangled"
"$OBJDUMP" -print-imm-hex --source --disassemble "$so" >> "$dump_mangled"
sed s/://g < "$dump_mangled" | rustfilt > "$dump"
)
rm -f "$dump_mangled"

if [[ ! -f "$dump" ]]; then
echo "Error: Failed to create $dump"
exit 1
fi

echo "Created $dump"
30 changes: 18 additions & 12 deletions sdk/bpf/scripts/install.sh
Original file line number Diff line number Diff line change
Expand Up @@ -84,19 +84,25 @@ clone() {
}

# Install xargo
(
set -ex
# shellcheck disable=SC2154
if [[ -n $rust_stable ]]; then
cargo +"$rust_stable" install xargo
else
cargo install xargo
version=0.3.22
if [[ ! -e xargo-$version.md ]]; then
(
args=()
# shellcheck disable=SC2154
if [[ -n $rust_stable ]]; then
args+=(+"$rust_stable")
fi
args+=(install xargo --version "$version" --root xargo)
set -ex
cargo "${args[@]}"
xargo --version >xargo-$version.md 2>&1
)
exitcode=$?
# shellcheck disable=SC2181
if [[ $exitcode -ne 0 ]]; then
rm -rf xargo-$version.md
exit 1
fi
xargo --version >xargo.md 2>&1
)
# shellcheck disable=SC2181
if [[ $? -ne 0 ]]; then
exit 1
fi

# Install Criterion
Expand Down
6 changes: 6 additions & 0 deletions sdk/bpf/scripts/objcopy.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
#!/usr/bin/env bash

bpf_sdk=$(cd "$(dirname "$0")/.." && pwd)
# shellcheck source=sdk/bpf/env.sh
source "$bpf_sdk"/env.sh
exec "$bpf_sdk"/dependencies/llvm-native/bin/llvm-objcopy "$@"

0 comments on commit 600050d

Please sign in to comment.