rust/test.sh

57 lines
2.1 KiB
Bash
Raw Normal View History

2018-08-10 12:09:21 -05:00
#!/bin/bash
source config.sh
2018-08-31 12:50:26 -05:00
build_example_bin() {
$RUSTC $2 --crate-name $1 --crate-type bin
2018-11-09 11:38:30 -06:00
sh -c ./target/out/$1 || true
2018-08-31 12:50:26 -05:00
}
rm -r target/out || true
2018-08-15 09:17:59 -05:00
mkdir -p target/out/clif
2018-09-09 07:45:23 -05:00
echo "[BUILD] mini_core"
2018-11-02 14:09:52 -05:00
$RUSTC example/mini_core.rs --crate-name mini_core --crate-type lib
2018-11-02 14:09:52 -05:00
echo "[BUILD] example"
$RUSTC example/example.rs --crate-type lib
2018-09-09 07:45:23 -05:00
echo "[JIT] mini_core_hello_world"
2018-11-02 14:09:52 -05:00
SHOULD_RUN=1 $RUSTC --crate-type bin example/mini_core_hello_world.rs --cfg jit
2018-09-09 07:45:23 -05:00
echo "[AOT] mini_core_hello_world"
build_example_bin mini_core_hello_world example/mini_core_hello_world.rs
2018-08-15 08:23:28 -05:00
2018-10-08 12:40:06 -05:00
pushd xargo
rm -r ~/.xargo/HOST || true
2018-11-03 09:04:27 -05:00
rm -r target || true
2018-11-05 11:42:43 -06:00
time xargo build
2018-10-08 12:40:06 -05:00
popd
2018-11-05 11:42:43 -06:00
# TODO linux linker doesn't accept duplicate definitions
#$RUSTC --sysroot ~/.xargo/HOST example/alloc_example.rs --crate-type bin
#./target/out/alloc_example
2018-11-05 11:42:43 -06:00
$RUSTC --sysroot ~/.xargo/HOST example/mod_bench.rs --crate-type bin
echo "[BUILD] RUSTFLAGS=-Zmir-opt-level=3"
pushd xargo
rm -r ~/.xargo/HOST || true
rm -r target || true
time RUSTFLAGS="-Zmir-opt-level=3 $RUSTFLAGS" xargo build
popd
2018-11-16 11:39:31 -06:00
COMPILE_MOD_BENCH_INLINE="$RUSTC --sysroot ~/.xargo/HOST example/mod_bench.rs --crate-type bin -Zmir-opt-level=3 -Og --crate-name mod_bench_inline"
COMPILE_MOD_BENCH_LLVM_0="rustc example/mod_bench.rs --crate-type bin -Copt-level=0 -o target/out/mod_bench_llvm_0 -Cpanic=abort"
COMPILE_MOD_BENCH_LLVM_1="rustc example/mod_bench.rs --crate-type bin -Copt-level=1 -o target/out/mod_bench_llvm_1 -Cpanic=abort"
COMPILE_MOD_BENCH_LLVM_2="rustc example/mod_bench.rs --crate-type bin -Copt-level=2 -o target/out/mod_bench_llvm_2 -Cpanic=abort"
COMPILE_MOD_BENCH_LLVM_3="rustc example/mod_bench.rs --crate-type bin -Copt-level=3 -o target/out/mod_bench_llvm_3 -Cpanic=abort"
# Use 100 runs, because a single compilations doesn't take more than ~150ms, so it isn't very slow
hyperfine --runs 100 "$COMPILE_MOD_BENCH_INLINE" "$COMPILE_MOD_BENCH_LLVM_0" "$COMPILE_MOD_BENCH_LLVM_1" "$COMPILE_MOD_BENCH_LLVM_2" "$COMPILE_MOD_BENCH_LLVM_3"
2018-11-05 11:42:43 -06:00
echo
echo "[Bench] mod_bench"
2018-11-09 11:38:30 -06:00
hyperfine ./target/out/mod_bench{,_inline} ./target/out/mod_bench_llvm_*
2018-11-05 11:42:43 -06:00
2018-08-23 04:03:43 -05:00
cat target/out/log.txt | sort | uniq -c