CC=gcc
#FIXME: -Ibertos/emul should not be needed
-CFLAGS="-W -Wall -Wextra -O0 -g3 -ggdb -Ibertos -Ibertos/emul -std=gnu99 -fno-builtin -D_DEBUG -DARCH=(ARCH_EMUL|ARCH_UNITTEST)"
+CFLAGS="-W -Wall -Wextra -Wundef -Wpointer-arith -Wcast-qual -Wcast-align -Wwrite-strings -Wsign-compare -Wmissing-noreturn \
+-O0 -g3 -ggdb -Ibertos -Ibertos/emul -std=gnu99 -fno-builtin -D_DEBUG -DARCH=(ARCH_EMUL|ARCH_UNITTEST) \
+-DCPU_FREQ=(12288000UL) -ffunction-sections -fdata-sections -Wl,--gc-sections"
CXX=g++
CXXFLAGS="$CFLAGS"
TESTS=${TESTS:-`find . \
\( -name .svn -prune -o -name .git -prune -o -name .hg -prune \) \
- -o -name "*_test.c*" -print` }
+ -o -name "*_test.c" -print` }
TESTOUT="testout"
-SRC_LIST="bertos/algo/ramp.c bertos/drv/kdebug.c bertos/drv/timer.c bertos/fs/battfs.c bertos/kern/coop.c bertos/kern/idle.c bertos/kern/kfile.c bertos/kern/monitor.c bertos/kern/proc.c bertos/kern/signal.c bertos/kern/sem.c bertos/mware/event.c bertos/mware/formatwr.c bertos/mware/hex.c bertos/mware/sprintf.c bertos/os/hptime.c bertos/emul/switch.S"
+SRC_LIST="
+ bertos/algo/ramp.c
+ bertos/drv/kdebug.c
+ bertos/drv/timer.c
+ bertos/fs/battfs.c
+ bertos/kern/coop.c
+ bertos/kern/idle.c
+ bertos/kern/kfile.c
+ bertos/kern/monitor.c
+ bertos/kern/proc.c
+ bertos/kern/signal.c
+ bertos/kern/sem.c
+ bertos/mware/event.c
+ bertos/mware/formatwr.c
+ bertos/mware/hex.c
+ bertos/mware/sprintf.c
+ bertos/os/hptime.c
+ bertos/struct/kfile_fifo.c
+ bertos/fs/fatfs/ff.c
+ bertos/emul/diskio_emul.c
+ bertos/fs/fat.c
+ bertos/emul/switch_ctx_emul.S
+ bertos/mware/ini_reader.c
+ bertos/emul/kfile_posix.c
+ bertos/algo/crc_ccitt.c
+ bertos/algo/crc.c
+ bertos/struct/kfile_mem.c
+ bertos/net/ax25.c
+ bertos/net/afsk.c
+ bertos/net/nmeap/src/nmeap01.c
+ bertos/net/nmea.c
+"
buildout='/dev/null'
runout='/dev/null'
set -o pipefail
rm -rf "${TESTOUT}.old"
-mv -f "${TESTOUT}" "$TESTOUT.old"
+if [ -d "${TESTOUT}" ] ; then
+ mv -f "${TESTOUT}" "$TESTOUT.old"
+fi
mkdir -p "$TESTOUT"
for src in $TESTS; do