Spdk/scripts/autotest_common.sh
Daniel Verkamp f0b3db3f1e autobuild: FreeBSD portability fixes
Change-Id: Id6db5d80ee7fa602da8763372f92555e7e299445
Signed-off-by: Daniel Verkamp <daniel.verkamp@intel.com>
2015-10-06 09:09:00 -07:00

80 lines
1.5 KiB
Bash
Executable File

set -xe
ulimit -c unlimited
case `uname` in
FreeBSD)
DPDK_DIR=/usr/local/share/dpdk/x86_64-native-bsdapp-clang
MAKE=gmake
;;
Linux)
DPDK_DIR=/usr/local/dpdk-2.1.0/x86_64-native-linuxapp-gcc
MAKE=make
;;
*)
echo "Unknown OS in $0"
exit 1
;;
esac
MAKEFLAGS=${MAKEFLAGS:--j16}
if [ -z "$rootdir" ] || [ ! -d "$rootdir/../output" ]; then
output_dir=.
else
output_dir=$rootdir/../output
fi
if hash valgrind &> /dev/null; then
# TODO: add --error-exitcode=2 when all Valgrind warnings are fixed
valgrind='valgrind --leak-check=full'
else
valgrind=''
fi
function timing() {
direction="$1"
testname="$2"
now=$(date +%s)
if [ "$direction" = "enter" ]; then
export timing_stack="${timing_stack}/${now}"
export test_stack="${test_stack}/${testname}"
else
start_time=$(echo "$timing_stack" | sed -e 's@^.*/@@')
timing_stack=$(echo "$timing_stack" | sed -e 's@/[^/]*$@@')
elapsed=$((now - start_time))
echo "$elapsed $test_stack" >> $output_dir/timing.txt
test_stack=$(echo "$test_stack" | sed -e 's@/[^/]*$@@')
fi
}
function timing_enter() {
timing "enter" "$1"
}
function timing_exit() {
timing "exit" "$1"
}
function process_core() {
ret=0
for core in $(find . -type f -name 'core*'); do
exe=$(eu-readelf -n "$core" | grep psargs | awk '{ print $2 }')
echo "exe for $core is $exe"
if [[ ! -z "$exe" ]]; then
if hash gdb; then
gdb -batch -ex "bt" $exe $core
fi
cp $exe $output_dir
fi
mv $core $output_dir
chmod a+r $output_dir/$core
ret=1
done
return $ret
}