diff --git a/Makefile.buildtests b/Makefile.buildtests index f87a19cfacb84367726fa0eb6f9b2c5d59638a31..0a9594fe5dbea68b98ac42bd1bba389cc71aec88 100644 --- a/Makefile.buildtests +++ b/Makefile.buildtests @@ -31,11 +31,6 @@ endif info-buildsizes-diff info-build info-boards-supported \ info-features-missing info-boards-features-missing -# Make buildtests error out on warnings by adding -Werror -ifeq (, $(filter buildtest, $(MAKECMDGOALS))) - CFLAGS+=-Werror -endif - ifeq ($(BUILD_IN_DOCKER),1) buildtest: ..in-docker-container else @@ -63,6 +58,7 @@ buildtest: BINDIRBASE=$${BINDIRBASE} \ RIOTNOLINK=$${RIOTNOLINK} \ RIOT_VERSION=$${RIOT_VERSION} \ + WERROR=$${WERROR} \ $(MAKE) -j$(NPROC) 2>&1) ; \ if [ "$${?}" = "0" ]; then \ ${COLOR_ECHO} "${COLOR_GREEN}success${COLOR_RESET}"; \ diff --git a/Makefile.docker b/Makefile.docker index 464e1dff2f4a9ff1b546cde78c47c3a563f53501..02b087b1ded254e0c600a2407ab72e2f9a8838d0 100644 --- a/Makefile.docker +++ b/Makefile.docker @@ -50,6 +50,7 @@ export DOCKER_ENV_VARS = \ OFLAGS \ PREFIX \ QUIET \ + WERROR \ RIOT_VERSION \ SCANBUILD_ARGS \ SCANBUILD_OUTPUTDIR \ diff --git a/Makefile.include b/Makefile.include index c2bb0fb0574e2a717da6710b90cc924a89624f32..1b72b3137729c834f7e28ea86d7708df2cde2709 100644 --- a/Makefile.include +++ b/Makefile.include @@ -64,10 +64,17 @@ else endif ifeq ($(QUIET),1) - AD=@ - MAKEFLAGS += --no-print-directory + AD=@ + MAKEFLAGS += --no-print-directory else - AD= + AD= +endif + +# Fail on warnings. Can be overridden by `make WERROR=0`. +WERROR ?= 1 +export WERROR +ifeq ($(WERROR),1) + CFLAGS += -Werror endif ifneq (10,$(if ${RIOT_VERSION},1,0)$(if ${__RIOTBUILD_FLAG},1,0)) diff --git a/Makefile.scan-build b/Makefile.scan-build index 5137d05a2ca90c672537e9243d69d93901ea9803..a12faf29dce4a903ff24c3e7ab899aedf8634c72 100644 --- a/Makefile.scan-build +++ b/Makefile.scan-build @@ -25,6 +25,7 @@ SCANBUILD_ENV_VARS := \ PATH \ PREFIX \ QUIET \ + WERROR \ RIOT_VERSION \ SIZE \ TOOLCHAIN \ diff --git a/Makefile.vars b/Makefile.vars index 49fca3116cb33cc958eeb24b02da27298c1003e2..2b67ff7fe731f6c640c9c5a309017501ea8078e4 100644 --- a/Makefile.vars +++ b/Makefile.vars @@ -37,6 +37,7 @@ export OBJCOPY # The command used to create the HEXFILE. export OFLAGS # The parameter for OBJCOPY, e.g. to strip the debug information. export SIZE # The command to read to size of the ELF sections. export UNDEF # Set by the BOARD's and CPU's Makefile.include, this contains object files with must not be used in the ELFFILE even if the if no call to the functions. +export WERROR # Treat all compiler warnings as errors if set to 1 (see -Werror flag in GCC manual) export FLASHER # The command to call on "make flash". export FFLAGS # The parameters to supply to FLASHER.