diff --git a/Makefile.buildtests b/Makefile.buildtests index bc0f7e26e2cef5467a1ee009fab4ef3ed49ed032..6a705b39009e8c0611f9693dddfda8fc9e29c991 100644 --- a/Makefile.buildtests +++ b/Makefile.buildtests @@ -42,7 +42,10 @@ buildtest: \ rm -rf "$$BINDIRBASE"; \ for BOARD in $${BOARDS}; do \ - $${ECHO} -n "Building for $${BOARD} .. "; \ + RIOTNOLINK=$$(case ' $(BOARD_INSUFFICIENT_RAM) ' in *" $${BOARD} "*) echo 1; esac); \ + $${ECHO} -n "Building for $${BOARD} "; \ + [ -n "$${RIOTNOLINK}" ] && $${ECHO} -n "(no linking) "; \ + $${ECHO} -n ".. "; \ LOG=$$(env -i \ HOME=$${HOME} \ PATH=$${PATH} \ @@ -51,6 +54,7 @@ buildtest: RIOTBOARD=$${RIOTBOARD} \ RIOTCPU=$${RIOTCPU} \ BINDIRBASE=$${BINDIRBASE} \ + RIOTNOLINK=$${RIOTNOLINK} \ $(MAKE) -j$(NPROC) 2>&1 >/dev/null) ; \ if [ "$${?}" = "0" ]; then \ $${ECHO} "$${GREEN}success$${RESET}"; \ diff --git a/Makefile.include b/Makefile.include index c943b5d1f146c35a041263f1a774c767662c5262..fc209e41fe281a19f5015844b4e897ba8cdeacca 100644 --- a/Makefile.include +++ b/Makefile.include @@ -60,7 +60,7 @@ endif # Feature test default CFLAGS and LINKFLAGS for the set compiled. include $(RIOTBASE)/Makefile.cflags -# your binaries to link +# the binaries to link BASELIBS += $(BINDIR)$(BOARD)_base.a BASELIBS += $(BINDIR)${PROJECT}.a BASELIBS += $(USEPKG:%=${BINDIR}%.a) @@ -70,11 +70,12 @@ BASELIBS += $(USEPKG:%=${BINDIR}%.a) export ELFFILE ?= $(BINDIR)$(PROJECT).elf export HEXFILE ?= $(ELFFILE:.elf=.hex) -## make script for your application. Build RIOT-base here! +## make script for the application all: $(BINDIR)$(PROJECT).a @echo "Building application $(PROJECT) for $(BOARD) w/ MCU $(MCU)." "$(MAKE)" -C $(RIOTBOARD)/$(BOARD) "$(MAKE)" -C $(RIOTBASE) +ifeq (,$(RIOTNOLINK)) ifeq ($(BUILDOSXNATIVE),1) $(AD)$(LINK) $(UNDEF) -o $(ELFFILE) $(BASELIBS) $(LINKFLAGS) -Wl,-no_pie else @@ -82,11 +83,7 @@ else endif $(AD)$(SIZE) $(ELFFILE) $(AD)$(OBJCOPY) $(OFLAGS) $(ELFFILE) $(HEXFILE) - -## your make rules -## Only basic example - modify it for larger applications!! -#$(BINDIR)/$(PROJECT).a: $(BINDIR)/$(PROJECT).o -# $(AR) -rc $(BINDIR)/project.a $(BINDIR)/$(PROJECT).o +endif # string array of all names of c files in dir SRC = $(wildcard *.c) diff --git a/examples/ccn-lite-client/Makefile b/examples/ccn-lite-client/Makefile index af7720508a092dd75e256e80d4db3e707ca05e78..549b353e2424e0720516b74d3858ce2d499097b6 100644 --- a/examples/ccn-lite-client/Makefile +++ b/examples/ccn-lite-client/Makefile @@ -27,17 +27,12 @@ export RIOTBASE ?= $(CURDIR)/../.. # Change this to 0 show compiler invocation lines by default: export QUIET ?= 1 -BOARD_BLACKLIST := arduino-due chronos mbed_lpc1768 msb-430 msb-430h pttu \ - redbee-econotag telosb udoo wsn430-v1_3b wsn430-v1_4 z1 -# chronos: not enough RAM +BOARD_INSUFFICIENT_RAM := chronos msb-430h telosb wsn430-v1_3b wsn430-v1_4 +BOARD_BLACKLIST := arduino-due mbed_lpc1768 msb-430 pttu redbee-econotag udoo z1 # mbed_lpc1768: see https://github.com/RIOT-OS/RIOT/issues/675 # msb-430: see https://github.com/RIOT-OS/RIOT/issues/658 -# msb-430h: not enough RAM # pttu: see https://github.com/RIOT-OS/RIOT/issues/659 # redbee-econotag: see https://github.com/RIOT-OS/RIOT/issues/676 -# telosb: not enough RAM -# wsn430-v1_3b: not enough RAM -# wsn430-v1_4: not enough RAM # z1: lacks RTC features # Modules to include: diff --git a/examples/ccn-lite-relay/Makefile b/examples/ccn-lite-relay/Makefile index 2a26611304093e285dee0e9f387fe56cc6cb4272..cfe811eafab7fe1b3882cc5d1cdd07b1054e5e5b 100644 --- a/examples/ccn-lite-relay/Makefile +++ b/examples/ccn-lite-relay/Makefile @@ -27,17 +27,12 @@ export RIOTBASE ?= $(CURDIR)/../.. # Change this to 0 show compiler invocation lines by default: export QUIET ?= 1 -BOARD_BLACKLIST := arduino-due chronos mbed_lpc1768 msb-430 msb-430h \ - pttu redbee-econotag telosb udoo wsn430-v1_3b wsn430-v1_4 z1 -# chronos: not enough RAM +BOARD_INSUFFICIENT_RAM := chronos msb-430h telosb wsn430-v1_3b wsn430-v1_4 +BOARD_BLACKLIST := arduino-due mbed_lpc1768 msb-430 pttu redbee-econotag udoo z1 # mbed_lpc1768: see https://github.com/RIOT-OS/RIOT/issues/675 # msb-430: see https://github.com/RIOT-OS/RIOT/issues/658 -# msb-430h: not enough RAM # pttu: see https://github.com/RIOT-OS/RIOT/issues/659 # redbee-econotag: see https://github.com/RIOT-OS/RIOT/issues/676 -# telosb: not enough RAM -# wsn430-v1_3b: not enough RAM -# wsn430-v1_4: not enough RAM # z1: lacks RTC features # Modules to include: diff --git a/examples/rpl_udp/Makefile b/examples/rpl_udp/Makefile index 90ece78634422b9f9b05c5e9c2a3103077015f9e..c56154bc2192402674a388d56941f5ba91767c20 100644 --- a/examples/rpl_udp/Makefile +++ b/examples/rpl_udp/Makefile @@ -34,18 +34,11 @@ ifeq ($(shell $(CC) -Wno-cpp -E - 2>/dev/null >/dev/null dev/null ; echo $$?),0) endif endif -BOARD_BLACKLIST := arduino-due chronos mbed_lpc1768 msb-430 msb-430h \ - pttu redbee-econotag telosb udoo wsn430-v1_3b wsn430-v1_4 z1 -# chronos: not enough RAM +BOARD_INSUFFICIENT_RAM := chronos msb-430h redbee-econotag telosb wsn430-v1_3b wsn430-v1_4 z1 +BOARD_BLACKLIST := arduino-due mbed_lpc1768 msb-430 pttu udoo # mbed_lpc1768: see https://github.com/RIOT-OS/RIOT/issues/675 # msb-430: see https://github.com/RIOT-OS/RIOT/issues/658 -# msb-430h: not enough RAM # pttu: see https://github.com/RIOT-OS/RIOT/issues/659 -# redbee-econotag: not enough RAM -# telosb: not enough RAM -# wsn430-v1_3b: not enough RAM -# wsn430-v1_4: not enough RAM -# z1: not enough RAM # Modules to include: diff --git a/tests/test_bloom/Makefile b/tests/test_bloom/Makefile index 3ee58e7e94f3c6f3477aac47a8fc466d9238ec2d..c119c007e87fdfdad8a493d3e171b9a37ddcc876 100644 --- a/tests/test_bloom/Makefile +++ b/tests/test_bloom/Makefile @@ -1,17 +1,8 @@ export PROJECT = test_bloom include ../Makefile.tests_common -BOARD_BLACKLIST := chronos mbed_lpc1768 msb-430 msb-430h redbee-econotag \ - telosb wsn430-v1_3b wsn430-v1_4 z1 -# chronos: not enough RAM -# mbed_lpc1768: not enough RAM -# msb-430: not enough RAM -# msb-430h: not enough RAM -# redbee-econotag: not enough RAM -# telosb: not enough RAM -# wsn430-v1_3b: not enough RAM -# wsn430-v1_4: not enough RAM -# z1: not enough RAM +BOARD_INSUFFICIENT_RAM := chronos mbed_lpc1768 msb-430 msb-430h redbee-econotag \ + telosb wsn430-v1_3b wsn430-v1_4 z1 USEMODULE += hashes USEMODULE += bloom diff --git a/tests/test_pnet/Makefile b/tests/test_pnet/Makefile index d30e961db317245420064aceaaa7af33d43b9189..41a00176f04d743de7198f533085c231e7c74b39 100644 --- a/tests/test_pnet/Makefile +++ b/tests/test_pnet/Makefile @@ -1,17 +1,10 @@ export PROJECT = test_pnet include ../Makefile.tests_common -BOARD_BLACKLIST := arduino-due chronos mbed_lpc1768 msb-430 msb-430h \ - redbee-econotag telosb udoo wsn430-v1_3b wsn430-v1_4 z1 -# chronos: not enough RAM +BOARD_INSUFFICIENT_RAM := chronos msb-430h redbee-econotag telosb wsn430-v1_3b wsn430-v1_4 z1 +BOARD_BLACKLIST := arduino-due mbed_lpc1768 msb-430 udoo # mbed_lpc1768: see https://github.com/RIOT-OS/RIOT/issues/675 # msb-430: see https://github.com/RIOT-OS/RIOT/issues/658 -# msb-430h: not enough RAM -# redbee-econotag: not enough RAM -# telosb: not enough RAM -# wsn430-v1_3b: not enough RAM -# wsn430-v1_4: not enough RAM -# z1: not enough RAM USEMODULE += posix USEMODULE += pnet diff --git a/tests/test_posix_semaphore/Makefile b/tests/test_posix_semaphore/Makefile index 3940ad0eb96191531555acf368494a3a9dc02217..b4c1f03f1b8e0c7b1018e266d689a34455765084 100644 --- a/tests/test_posix_semaphore/Makefile +++ b/tests/test_posix_semaphore/Makefile @@ -1,10 +1,7 @@ export PROJECT = test_posix_semaphore include ../Makefile.tests_common -BOARD_BLACKLIST := mbed_lpc1768 redbee-econotag chronos -# mbed_lpc1768: not enough RAM -# redbee-econotag: not enough RAM -# chronos: not enough RAM +BOARD_INSUFFICIENT_RAM := mbed_lpc1768 redbee-econotag chronos USEMODULE += posix diff --git a/tests/test_pthread_rwlock/Makefile b/tests/test_pthread_rwlock/Makefile index 4cb40dfe58416e1440040519035e7117ddc9477b..bdd41fff3b6f77490c54dc276dd6eb5958fe8234 100644 --- a/tests/test_pthread_rwlock/Makefile +++ b/tests/test_pthread_rwlock/Makefile @@ -9,10 +9,6 @@ DISABLE_MODULE += auto_init CFLAGS += -DNATIVE_AUTO_EXIT -# these boards provide too little RAM for the example to run -BOARD_BLACKLIST += chronos -BOARD_BLACKLIST += mbed_lpc1768 -BOARD_BLACKLIST += msb-430 -BOARD_BLACKLIST += msb-430h +BOARD_INSUFFICIENT_RAM += chronos mbed_lpc1768 msb-430 msb-430h include $(RIOTBASE)/Makefile.include diff --git a/tests/test_thread_cooperation/Makefile b/tests/test_thread_cooperation/Makefile index 0ef7411c4594f8e95662af0a0e6e6ab8b830112f..f7cc70779f42e0888d019594bbc1c12951da8d30 100644 --- a/tests/test_thread_cooperation/Makefile +++ b/tests/test_thread_cooperation/Makefile @@ -1,12 +1,7 @@ export PROJECT = test_thread_cooperation include ../Makefile.tests_common -BOARD_BLACKLIST := chronos msb-430 msb-430h mbed_lpc1768 redbee-econotag -# chronos: not enough RAM -# mbed_lpc1768: not enough RAM -# msb-430: not enough RAM -# msb-430h: not enough RAM -# redbee-econotag: not enough RAM +BOARD_INSUFFICIENT_RAM := chronos msb-430 msb-430h mbed_lpc1768 redbee-econotag DISABLE_MODULE += auto_init