compiler-builtins-zynq/ci/run.sh

108 lines
2.8 KiB
Bash
Raw Normal View History

set -ex
2019-04-03 02:44:28 +08:00
cargo=cargo
2017-06-24 12:36:36 +08:00
2016-09-30 07:50:04 +08:00
# Test our implementation
2019-04-03 02:44:28 +08:00
if [ "$XARGO" = "1" ]; then
# FIXME: currently these tests don't work...
echo nothing to do
2019-04-03 02:44:28 +08:00
else
run="cargo test --manifest-path testcrate/Cargo.toml --target $1"
$run
$run --release
$run --features c
$run --features c --release
fi
2016-09-30 07:50:04 +08:00
cargo build --target $1
cargo build --target $1 --release
cargo build --target $1 --features c
cargo build --target $1 --release --features c
PREFIX=$(echo $1 | sed -e 's/unknown-//')-
2016-09-30 07:50:04 +08:00
case $1 in
armv7-*)
PREFIX=arm-linux-gnueabihf-
;;
thumb*)
PREFIX=arm-none-eabi-
;;
*86*-*)
2016-09-30 07:50:04 +08:00
PREFIX=
;;
esac
NM=$(find $(rustc --print sysroot) -name llvm-nm)
if [ "$NM" = "" ]; then
NM=${PREFIX}nm
fi
2016-09-30 07:50:04 +08:00
2017-06-24 12:23:52 +08:00
if [ -d /target ]; then
path=/target/${1}/debug/deps/libcompiler_builtins-*.rlib
2017-06-24 12:23:52 +08:00
else
path=target/${1}/debug/deps/libcompiler_builtins-*.rlib
2016-10-08 03:29:34 +08:00
fi
2017-06-24 02:52:22 +08:00
# Look out for duplicated symbols when we include the compiler-rt (C) implementation
for rlib in $(echo $path); do
2017-06-24 01:44:29 +08:00
set +x
echo "================================================================"
echo checking $rlib for duplicate symbols
echo "================================================================"
stdout=$($NM -g --defined-only $rlib 2>&1)
2017-06-25 01:12:17 +08:00
# NOTE On i586, It's normal that the get_pc_thunk symbol appears several
# times so ignore it
#
# FIXME(#167) - we shouldn't ignore `__builtin_cl` style symbols here.
set +e
2017-06-25 01:12:17 +08:00
echo "$stdout" | \
sort | \
uniq -d | \
grep -v __x86.get_pc_thunk | \
grep -v __builtin_cl | \
2017-07-08 02:20:04 +08:00
grep -v __builtin_ctz | \
2017-06-25 01:12:17 +08:00
grep 'T __'
2016-09-30 07:50:04 +08:00
if test $? = 0; then
exit 1
fi
2017-06-24 01:44:29 +08:00
set -ex
done
rm -f $path
# Verify that we haven't drop any intrinsic/symbol
build_intrinsics="$cargo build --target $1 -v --example intrinsics"
RUSTFLAGS="-C debug-assertions=no" $build_intrinsics
RUSTFLAGS="-C debug-assertions=no" $build_intrinsics --release
RUSTFLAGS="-C debug-assertions=no" $build_intrinsics --features c
RUSTFLAGS="-C debug-assertions=no" $build_intrinsics --features c --release
# Verify that there are no undefined symbols to `panic` within our
# implementations
#
# TODO(#79) fix the undefined references problem for debug-assertions+lto
2017-06-24 12:36:36 +08:00
if [ -z "$DEBUG_LTO_BUILD_DOESNT_WORK" ]; then
RUSTFLAGS="-C debug-assertions=no" \
CARGO_INCREMENTAL=0 \
CARGO_PROFILE_DEV_LTO=true \
$cargo rustc --features "$INTRINSICS_FEATURES" --target $1 --example intrinsics
2017-06-24 12:36:36 +08:00
fi
CARGO_PROFILE_RELEASE_LTO=true \
$cargo rustc --features "$INTRINSICS_FEATURES" --target $1 --example intrinsics --release
2017-06-24 02:52:22 +08:00
# Ensure no references to a panicking function
for rlib in $(echo $path); do
set +ex
$NM -u $rlib 2>&1 | grep panicking
2017-06-24 02:52:22 +08:00
if test $? = 0; then
exit 1
fi
set -ex
done
true