mirror of
https://github.com/rust-lang/rust.git
synced 2025-10-02 18:27:37 +00:00
101 lines
3.3 KiB
Bash
Executable File
101 lines
3.3 KiB
Bash
Executable File
#!/usr/bin/env sh
|
|
|
|
set -ex
|
|
|
|
: "${TARGET?The TARGET environment variable must be set.}"
|
|
|
|
# Tests are all super fast anyway, and they fault often enough on travis that
|
|
# having only one thread increases debuggability to be worth it.
|
|
#export RUST_BACKTRACE=full
|
|
#export RUST_TEST_NOCAPTURE=1
|
|
|
|
RUSTFLAGS="$RUSTFLAGS --cfg stdsimd_strict"
|
|
|
|
case ${TARGET} in
|
|
# On 32-bit use a static relocation model which avoids some extra
|
|
# instructions when dealing with static data, notably allowing some
|
|
# instruction assertion checks to pass below the 20 instruction limit. If
|
|
# this is the default, dynamic, then too many instructions are generated
|
|
# when we assert the instruction for a function and it causes tests to fail.
|
|
#
|
|
# It's not clear why `-Z plt=yes` is required here. Probably a bug in LLVM.
|
|
# If you can remove it and CI passes, please feel free to do so!
|
|
i686-* | i586-*)
|
|
export RUSTFLAGS="${RUSTFLAGS} -C relocation-model=static -Z plt=yes"
|
|
;;
|
|
#Unoptimized build uses fast-isel which breaks with msa
|
|
mips-* | mipsel-*)
|
|
export RUSTFLAGS="${RUSTFLAGS} -C llvm-args=-fast-isel=false"
|
|
;;
|
|
esac
|
|
|
|
echo "RUSTFLAGS=${RUSTFLAGS}"
|
|
echo "FEATURES=${FEATURES}"
|
|
echo "OBJDUMP=${OBJDUMP}"
|
|
echo "STDSIMD_DISABLE_ASSERT_INSTR=${STDSIMD_DISABLE_ASSERT_INSTR}"
|
|
echo "STDSIMD_TEST_EVERYTHING=${STDSIMD_TEST_EVERYTHING}"
|
|
|
|
cargo_test() {
|
|
cmd="cargo"
|
|
subcmd="test"
|
|
if [ "$NORUN" = "1" ]; then
|
|
export subcmd="build"
|
|
fi
|
|
cmd="$cmd ${subcmd} --target=$TARGET $1"
|
|
cmd="$cmd -- $2"
|
|
$cmd
|
|
}
|
|
|
|
CORE_ARCH="--manifest-path=crates/core_arch/Cargo.toml"
|
|
STD_DETECT="--manifest-path=crates/std_detect/Cargo.toml"
|
|
STDSIMD_EXAMPLES="--manifest-path=examples/Cargo.toml"
|
|
cargo_test "${CORE_ARCH}"
|
|
cargo_test "${CORE_ARCH} --release"
|
|
if [ "$NOSTD" != "1" ]; then
|
|
cargo_test "${STD_DETECT}"
|
|
cargo_test "${STD_DETECT} --release"
|
|
|
|
cargo_test "${STD_DETECT} --no-default-features"
|
|
cargo_test "${STD_DETECT} --no-default-features --features=std_detect_file_io"
|
|
cargo_test "${STD_DETECT} --no-default-features --features=std_detect_dlsym_getauxval"
|
|
cargo_test "${STD_DETECT} --no-default-features --features=std_detect_dlsym_getauxval,std_detect_file_io"
|
|
|
|
cargo_test "${STDSIMD_EXAMPLES}"
|
|
cargo_test "${STDSIMD_EXAMPLES} --release"
|
|
fi
|
|
|
|
# Test targets compiled with extra features.
|
|
case ${TARGET} in
|
|
x86*)
|
|
export STDSIMD_DISABLE_ASSERT_INSTR=1
|
|
export RUSTFLAGS="${RUSTFLAGS} -C target-feature=+avx"
|
|
cargo_test "--release"
|
|
;;
|
|
wasm32-unknown-unknown*)
|
|
# There's no node or other runtime which supports the most recent SIMD
|
|
# proposal, but hopefully that's coming soon! For now just test that we
|
|
# can codegen with no LLVM faults, and we'll remove `--no-run` at a
|
|
# later date.
|
|
export RUSTFLAGS="${RUSTFLAGS} -C target-feature=+simd128,+unimplemented-simd128"
|
|
cargo_test "--release --no-run"
|
|
;;
|
|
mips-*gnu* | mipsel-*gnu*)
|
|
export RUSTFLAGS="${RUSTFLAGS} -C target-feature=+msa,+fp64,+mips32r5"
|
|
;;
|
|
mips64*)
|
|
export RUSTFLAGS="${RUSTFLAGS} -C target-feature=+msa"
|
|
;;
|
|
*)
|
|
;;
|
|
|
|
esac
|
|
|
|
if [ "$NORUN" != "1" ] && [ "$NOSTD" != 1 ] && [ "$TARGET" != "wasm32-unknown-unknown" ]; then
|
|
# Test examples
|
|
(
|
|
cd examples
|
|
cargo test --target "$TARGET"
|
|
echo test | cargo run --release hex
|
|
)
|
|
fi
|