ardupilot/Tools/scripts/build_binaries.sh

519 lines
15 KiB
Bash
Executable File

#!/bin/bash
# script to build the latest binaries for each vehicle type, ready to upload
# Andrew Tridgell, March 2013
export PATH=$PATH:/bin:/usr/bin
export TMPDIR=$PWD/build.tmp.binaries
echo $TMDIR
rm -rf $TMPDIR
echo "Building in $TMPDIR"
date
git checkout -f master
githash=$(git rev-parse HEAD)
hdate=$(date +"%Y-%m/%Y-%m-%d-%H:%m")
mkdir -p binaries/$hdate
binaries=$PWD/../buildlogs/binaries
BASEDIR=$PWD
error_count=0
. config.mk
board_branch() {
board="$1"
case $board in
apm1|apm2)
echo "-AVR"
;;
*)
echo ""
;;
esac
}
# add board specific options
board_options() {
board="$1"
case $board in
bebop)
# bebop needs a static build
echo "--static"
;;
*)
echo ""
;;
esac
}
waf() {
if [ -x ./waf ]; then
./waf "$@"
else
./modules/waf/waf-light "$@"
fi
}
# checkout the right version of the tree
checkout() {
vehicle="$1"
tag="$2"
board="$3"
frame="$4"
echo "Trying checkout $vehicle $tag $board $frame"
git stash
if [ "$tag" = "latest" ]; then
vtag="master"
else
vtag="$vehicle-$tag"
fi
# try frame specific tag
if [ -n "$frame" ]; then
vtag2="$vtag-$frame"
git checkout -f "$vtag2" && {
echo "Using frame specific tag $vtag2"
[ -f $BASEDIR/.gitmodules ] && git submodule update --recursive -f
git log -1
return 0
}
fi
# try board type specific branch extension
vtag2="$vtag"$(board_branch $board)
git checkout -f "$vtag2" && {
echo "Using board specific tag $vtag2"
[ -f $BASEDIR/.gitmodules ] && git submodule update --recursive -f
git log -1
return 0
}
git checkout -f "$vtag" && {
echo "Using generic tag $vtag"
[ -f $BASEDIR/.gitmodules ] && git submodule update --recursive -f
git log -1
return 0
}
echo "Failed to find tag for $vehicle $tag $board $frame"
return 1
}
# check if we should skip this build because we don't
# support the board in this release
skip_board() {
b="$1"
if grep -q "$b" ../mk/targets.mk; then
return 1
fi
echo "Skipping unsupported board $b"
return 0
}
# check if we should skip this build because we don't
# support the board in this release
skip_board_waf() {
b="$1"
if grep -q "$b" $BASEDIR/Tools/ardupilotwaf/boards.py; then
return 1
fi
echo "Skipping unsupported board $b"
return 0
}
skip_frame() {
board=$1
frame=$2
if [ "$board" = "bebop" ]; then
if [ "$frame" != "quad" ]; then
return 0
fi
fi
return 1
}
# check if we should skip this build because we have already
# built this version
skip_build() {
[ "$FORCE_BUILD" = "1" ] && return 1
tag="$1"
ddir="$2"
bname=$(basename $ddir)
ldir=$(dirname $(dirname $(dirname $ddir)))/$tag/$bname
[ -f $BASEDIR/.gitmodules ] || {
echo "Skipping build without submodules"
return 0
}
[ -d "$ldir" ] || {
echo "$ldir doesn't exist - building"
return 1
}
oldversion=$(cat "$ldir/git-version.txt" | head -1)
newversion=$(git log -1 | head -1)
[ "$oldversion" = "$newversion" ] && {
echo "Skipping build - version match $newversion"
return 0
}
echo "$ldir needs rebuild"
return 1
}
addfwversion() {
destdir="$1"
src="$2"
git log -1 > "$destdir/git-version.txt"
versionfile="$src/version.h"
[ -f $versionfile ] && {
shopt -s nullglob
version=$(grep 'define.THISFIRMWARE' $versionfile 2> /dev/null | cut -d'"' -f2)
echo >> "$destdir/git-version.txt"
echo "APMVERSION: $version" >> "$destdir/git-version.txt"
python $BASEDIR/Tools/PrintVersion.py $src >"$destdir/firmware-version.txt"
}
}
# copy the built firmware to the right directory
copyit() {
file="$1"
dir="$2"
tag="$3"
src="${4:-.}"
bname=$(basename $dir)
tdir=$(dirname $(dirname $(dirname $dir)))/$tag/$bname
if [ "$tag" = "latest" ]; then
mkdir -p "$dir"
/bin/cp "$file" "$dir"
addfwversion "$dir" "$src"
fi
echo "Copying $file to $tdir"
mkdir -p "$tdir"
addfwversion "$tdir" "$src"
rsync "$file" "$tdir"
}
board_extension() {
board="$1"
case $board in
apm1|apm2)
echo "hex"
;;
*)
echo "elf"
;;
esac
}
# build plane binaries
build_arduplane() {
tag="$1"
echo "Building ArduPlane $tag binaries from $(pwd)"
pushd ArduPlane
for b in apm1 apm2; do
checkout ArduPlane $tag $b "" || {
echo "Failed checkout of ArduPlane $b $tag"
error_count=$((error_count+1))
continue
}
skip_board $b && continue
echo "Building ArduPlane $b binaries"
ddir=$binaries/Plane/$hdate/$b
skip_build $tag $ddir && continue
make clean || continue
make $b -j4 || {
echo "Failed build of ArduPlane $b $tag"
error_count=$((error_count+1))
continue
}
extension=$(board_extension $b)
copyit $BUILDROOT/ArduPlane.$extension $ddir $tag
touch $binaries/Plane/$tag
done
popd
for b in erlebrain2 navio navio2 pxf pxfmini disco; do
checkout ArduPlane $tag $b "" || {
echo "Failed checkout of ArduPlane $b $tag"
error_count=$((error_count+1))
continue
}
skip_board_waf $b && continue
echo "Building ArduPlane $b binaries"
ddir=$binaries/Plane/$hdate/$b
skip_build $tag $ddir && continue
waf configure --board $b --out $BUILDROOT clean plane || {
echo "Failed build of ArduPlane $b $tag"
error_count=$((error_count+1))
continue
}
copyit $BUILDROOT/$b/bin/arduplane $ddir $tag "ArduPlane"
touch $binaries/Plane/$tag
done
pushd ArduPlane
echo "Building ArduPlane PX4 binaries"
ddir=$binaries/Plane/$hdate/PX4
checkout ArduPlane $tag PX4 "" || {
echo "Failed checkout of ArduPlane PX4 $tag"
error_count=$((error_count+1))
checkout ArduPlane "latest" "" ""
popd
return
}
skip_build $tag $ddir || {
for v in v1 v2 v3 v4; do
make px4-clean
make px4-$v -j2 || {
echo "Failed build of ArduPlane PX4 $tag for $v"
error_count=$((error_count+1))
checkout ArduPlane "latest" "" ""
popd
return
}
done
copyit ArduPlane-v1.px4 $ddir $tag &&
copyit ArduPlane-v2.px4 $ddir $tag &&
test ! -f ArduPlane-v3.px4 || copyit ArduPlane-v3.px4 $ddir $tag &&
test ! -f ArduPlane-v4.px4 || copyit ArduPlane-v4.px4 $ddir $tag
if [ "$tag" = "latest" ]; then
copyit px4io-v1.bin $binaries/PX4IO/$hdate/PX4IO $tag
copyit px4io-v1.elf $binaries/PX4IO/$hdate/PX4IO $tag
copyit px4io-v2.bin $binaries/PX4IO/$hdate/PX4IO $tag
copyit px4io-v2.elf $binaries/PX4IO/$hdate/PX4IO $tag
fi
}
checkout ArduPlane "latest" "" ""
popd
}
# build copter binaries
build_arducopter() {
tag="$1"
echo "Building ArduCopter $tag binaries from $(pwd)"
if grep -q FRAME_CLASS ArduCopter/Parameters.cpp; then
frames="quad tri heli"
else
frames="quad tri hexa y6 octa octa-quad heli"
fi
for b in erlebrain2 navio navio2 pxf pxfmini bebop; do
for f in $frames; do
checkout ArduCopter $tag $b $f || {
echo "Failed checkout of ArduCopter $b $tag $f"
error_count=$((error_count+1))
continue
}
skip_board_waf $b && continue
echo "Building ArduCopter $b binaries $f"
ddir=$binaries/Copter/$hdate/$b-$f
skip_build $tag $ddir && continue
skip_frame $b $f && continue
options=$(board_options $b)
waf configure --board $b $options --out $BUILDROOT clean \
build --targets bin/arducopter-$f || {
echo "Failed build of ArduCopter $b-$f $tag"
error_count=$((error_count+1))
continue
}
copyit $BUILDROOT/$b/bin/arducopter-$f $ddir $tag "ArduCopter"
touch $binaries/Copter/$tag
done
done
pushd ArduCopter
for f in $frames; do
checkout ArduCopter $tag PX4 $f || {
echo "Failed checkout of ArduCopter PX4 $tag $f"
error_count=$((error_count+1))
checkout ArduCopter "latest" "" ""
continue
}
rm -rf ../Build.ArduCopter
echo "Building ArduCopter PX4-$f binaries"
ddir="$binaries/Copter/$hdate/PX4-$f"
skip_build $tag $ddir && continue
for v in v1 v2 v3 v4; do
make px4-clean
make px4-$v-$f -j2 || {
echo "Failed build of ArduCopter PX4 $tag for $v"
error_count=$((error_count+1))
continue
}
done
copyit ArduCopter-v1.px4 $ddir $tag &&
copyit ArduCopter-v2.px4 $ddir $tag &&
test ! -f ArduCopter-v3.px4 || copyit ArduCopter-v3.px4 $ddir $tag &&
test ! -f ArduCopter-v4.px4 || copyit ArduCopter-v4.px4 $ddir $tag
done
checkout ArduCopter "latest" "" ""
popd
}
# build rover binaries
build_rover() {
tag="$1"
echo "Building APMrover2 $tag binaries from $(pwd)"
pushd APMrover2
for b in apm1 apm2; do
echo "Building APMrover2 $b binaries"
checkout APMrover2 $tag $b "" || continue
skip_board $b && continue
ddir=$binaries/Rover/$hdate/$b
skip_build $tag $ddir && continue
make clean || continue
make $b -j4 || {
echo "Failed build of APMrover2 $b $tag"
error_count=$((error_count+1))
continue
}
extension=$(board_extension $b)
copyit $BUILDROOT/APMrover2.$extension $ddir $tag
touch $binaries/Rover/$tag
done
popd
for b in erlebrain2 navio navio2 pxf pxfmini; do
echo "Building APMrover2 $b binaries"
checkout APMrover2 $tag $b "" || continue
skip_board_waf $b && continue
ddir=$binaries/Rover/$hdate/$b
skip_build $tag $ddir && continue
waf configure --board $b --out $BUILDROOT clean rover || {
echo "Failed build of APMrover2 $b $tag"
error_count=$((error_count+1))
continue
}
copyit $BUILDROOT/$b/bin/ardurover $ddir $tag "APMRover2"
touch $binaries/Rover/$tag
done
pushd APMrover2
echo "Building APMrover2 PX4 binaries"
ddir=$binaries/Rover/$hdate/PX4
checkout APMrover2 $tag PX4 "" || {
checkout APMrover2 "latest" "" ""
popd
return
}
skip_build $tag $ddir || {
for v in v1 v2 v3 v4; do
make px4-clean
make px4-$v -j2 || {
echo "Failed build of APMrover2 PX4 $tag"
error_count=$((error_count+1))
checkout APMrover2 "latest" "" ""
popd
return
}
done
copyit APMrover2-v1.px4 $binaries/Rover/$hdate/PX4 $tag &&
copyit APMrover2-v2.px4 $binaries/Rover/$hdate/PX4 $tag &&
test ! -f APMrover2-v3.px4 || copyit APMrover2-v3.px4 $binaries/Rover/$hdate/PX4 $tag &&
test ! -f APMrover2-v4.px4 || copyit APMrover2-v4.px4 $binaries/Rover/$hdate/PX4 $tag
}
checkout APMrover2 "latest" "" ""
popd
}
# build antenna tracker binaries
build_antennatracker() {
tag="$1"
echo "Building AntennaTracker $tag binaries from $(pwd)"
pushd AntennaTracker
for b in apm2; do
echo "Building AntennaTracker $b binaries"
checkout AntennaTracker $tag $b "" || continue
ddir=$binaries/AntennaTracker/$hdate/$b
skip_build $tag $ddir && continue
make clean || continue
make $b -j4 || {
echo "Failed build of AntennaTracker $b $tag"
error_count=$((error_count+1))
continue
}
extension=$(board_extension $b)
copyit $BUILDROOT/AntennaTracker.$extension $ddir $tag
touch $binaries/AntennaTracker/$tag
done
popd
for b in navio navio2; do
checkout AntennaTracker $tag $b "" || {
echo "Failed checkout of AntennaTracker $b $tag"
error_count=$((error_count+1))
continue
}
skip_board_waf $b && continue
echo "Building AntennaTracker $b binaries"
ddir=$binaries/AntennaTracker/$hdate/$b
skip_build $tag $ddir && continue
waf configure --board $b --out $BUILDROOT clean antennatracker || {
echo "Failed build of AntennaTracker $b $tag"
error_count=$((error_count+1))
continue
}
copyit $BUILDROOT/$b/bin/antennatracker $ddir $tag "AntennaTracker"
touch $binaries/AntennaTracker/$tag
done
pushd AntennaTracker
echo "Building AntennaTracker PX4 binaries"
ddir=$binaries/AntennaTracker/$hdate/PX4
checkout AntennaTracker $tag PX4 "" || {
checkout AntennaTracker "latest" "" ""
popd
return
}
skip_build $tag $ddir || {
for v in v1 v2 v3 v4; do
make px4-clean
make px4-$v -j2 || {
echo "Failed build of AntennaTracker PX4 $tag"
error_count=$((error_count+1))
checkout AntennaTracker "latest" "" ""
popd
return
}
done
copyit AntennaTracker-v1.px4 $binaries/AntennaTracker/$hdate/PX4 $tag &&
copyit AntennaTracker-v2.px4 $binaries/AntennaTracker/$hdate/PX4 $tag &&
test ! -f AntennaTracker-v3.px4 || copyit AntennaTracker-v3.px4 $binaries/AntennaTracker/$hdate/PX4 $tag &&
test ! -f AntennaTracker-v4.px4 || copyit AntennaTracker-v4.px4 $binaries/AntennaTracker/$hdate/PX4 $tag
}
checkout AntennaTracker "latest" "" ""
popd
}
[ -f .gitmodules ] && {
git submodule init
git submodule update --recursive -f
}
export BUILDROOT="$TMPDIR/binaries.build"
rm -rf $BUILDROOT
# make sure PX4 is rebuilt from scratch
for d in ArduPlane ArduCopter APMrover2 AntennaTracker; do
pushd $d
make px4-clean || exit 1
popd
done
for build in stable beta latest; do
build_arduplane $build
build_arducopter $build
build_rover $build
build_antennatracker $build
done
rm -rf $TMPDIR
if ./Tools/scripts/generate-manifest.py $binaries http://firmware.ardupilot.org >$binaries/manifest.json.new; then
echo "Manifest generation succeeded"
# provide a pre-compressed manifest. For reference, a 7M manifest
# "gzip -9"s to 300k in 1 second, "xz -e"s to 80k in 26 seconds
gzip -9 <$binaries/manifest.json.new >$binaries/manifest.json.gz.new
mv $binaries/manifest.json.new $binaries/manifest.json
mv $binaries/manifest.json.gz.new $binaries/manifest.json.gz
else
echo "Manifest generation failed"
fi
exit $error_count