From fa8553b00d212afbb32ff5e1c607744b27b09940 Mon Sep 17 00:00:00 2001 From: Matthew Kennedy Date: Sat, 8 Feb 2020 03:05:40 -0800 Subject: [PATCH] Stricter compile options (#1132) * stricter * don't warn on that one * this code was dead --- firmware/Makefile | 8 +++----- firmware/controllers/core/common_headers.h | 2 ++ firmware/controllers/math/engine_math.cpp | 4 ++-- firmware/hw_layer/servo.cpp | 12 ------------ firmware/rusefi_rules.mk | 8 ++++---- 5 files changed, 11 insertions(+), 23 deletions(-) diff --git a/firmware/Makefile b/firmware/Makefile index d4b4afdcba..9342d8f8dd 100644 --- a/firmware/Makefile +++ b/firmware/Makefile @@ -37,21 +37,19 @@ endif # Compiler options here. ifeq ($(USE_OPT),) - USE_OPT = $(EXTRA_PARAMS) $(DEBUG_LEVEL_OPT) $(RFLAGS) -Wno-error=implicit-fallthrough -Wno-error=bool-operation -fomit-frame-pointer -falign-functions=16 -Werror=type-limits -Wno-error=strict-aliasing -Wno-error=attributes + USE_OPT = $(EXTRA_PARAMS) $(DEBUG_LEVEL_OPT) $(RFLAGS) -fomit-frame-pointer -falign-functions=16 endif - USE_OPT += $(RUSEFI_OPT) # C specific options here (added to USE_OPT). ifeq ($(USE_COPT),) - USE_COPT = -fgnu89-inline -std=gnu99 -Werror-implicit-function-declaration + USE_COPT = -fgnu89-inline -std=gnu99 -Wno-error=implicit-fallthrough endif # C++ specific options here (added to USE_OPT). ifeq ($(USE_CPPOPT),) - # constexpr float expf_taylor_impl probably needs just c++14 but why not go with 17? - USE_CPPOPT = -std=c++17 -Wno-register -fno-rtti -fno-threadsafe-statics -fno-exceptions -fno-use-cxa-atexit -Werror=write-strings -Werror=type-limits + USE_CPPOPT = -std=c++17 -Wno-register -fno-rtti -fno-threadsafe-statics -fno-exceptions -fno-use-cxa-atexit endif # Enable this if you want the linker to remove unused code and data diff --git a/firmware/controllers/core/common_headers.h b/firmware/controllers/core/common_headers.h index 8de9e5dbfe..ed1a2e6b40 100644 --- a/firmware/controllers/core/common_headers.h +++ b/firmware/controllers/core/common_headers.h @@ -88,6 +88,8 @@ #define EXPAND_Engine \ engine_configuration_s *engineConfiguration = engine->engineConfigurationPtr; \ persistent_config_s *config = engine->config; \ + (void)engineConfiguration; \ + (void)config; \ #ifndef EFI_ACTIVE_CONFIGURATION_IN_FLASH diff --git a/firmware/controllers/math/engine_math.cpp b/firmware/controllers/math/engine_math.cpp index 958188bdec..e97d11e4dc 100644 --- a/firmware/controllers/math/engine_math.cpp +++ b/firmware/controllers/math/engine_math.cpp @@ -65,8 +65,8 @@ float getEngineLoadT(DECLARE_ENGINE_PARAMETER_SIGNATURE) { } return getMafVoltage(PASS_ENGINE_PARAMETER_SIGNATURE); case LM_SPEED_DENSITY: - // SD engine load is used for timing lookup but not for fuel calculation - [[fallthrough]] + // SD engine load is used for timing lookup but not for fuel calculation, + // so fall thru to the MAP case. case LM_MAP: return getMap(PASS_ENGINE_PARAMETER_SIGNATURE); case LM_ALPHA_N: diff --git a/firmware/hw_layer/servo.cpp b/firmware/hw_layer/servo.cpp index fd864f8a2e..d90b3f2994 100644 --- a/firmware/hw_layer/servo.cpp +++ b/firmware/hw_layer/servo.cpp @@ -27,18 +27,6 @@ THD_WORKING_AREA(servoThreadStack, UTILITY_THREAD_STACK_SIZE * 3); static OutputPin pins[SERVO_COUNT]; -static int countServos() { - int result = 0; - - for (int i = 0; i < SERVO_COUNT; i++) { - if (engineConfiguration->servoOutputPins[i] != GPIO_UNASSIGNED) { - result++; - } - } - return result; - -} - static scheduling_s servoTurnSignalOff; // todo: extract common 'pin off' callback? diff --git a/firmware/rusefi_rules.mk b/firmware/rusefi_rules.mk index 4232098583..e23f9fb865 100644 --- a/firmware/rusefi_rules.mk +++ b/firmware/rusefi_rules.mk @@ -1,5 +1,5 @@ -RUSEFI_OPT=-Werror -Wno-error=pointer-sign -Wno-error=unused-function -Wno-error=unused-variable -Wno-error=sign-compare -Wno-error=unused-parameter -Werror=missing-field-initializers +# Warnings-as-errors... +RUSEFI_OPT = -Werror -RUSEFI_OPT+=-Wno-error=missing-prototypes - -RUSEFI_OPT+=-Werror=switch \ No newline at end of file +# ...except these few +RUSEFI_OPT += -Wno-error=unused-function -Wno-error=unused-variable -Wno-error=sign-compare -Wno-error=unused-parameter