diff --git a/Makefile b/Makefile index 2d016480574fb8be7461b5b8fb52251af7d2680e..9525d411a388706e37acf9dfe381f5329fdac945 100644 --- a/Makefile +++ b/Makefile @@ -188,8 +188,50 @@ TF_CFLAGS_aarch64 += -mgeneral-regs-only -mstrict-align ASFLAGS_aarch32 = $(march32-directive) ASFLAGS_aarch64 = -march=armv8-a +WARNING1 := -Wextra +WARNING1 += -Wunused -Wno-unused-parameter +WARNING1 += -Wmissing-declarations +WARNING1 += -Wmissing-format-attribute +WARNING1 += -Wmissing-prototypes +WARNING1 += -Wold-style-definition +WARNING1 += -Wunused-but-set-variable +WARNING1 += -Wunused-const-variable + +WARNING2 := -Waggregate-return +WARNING2 += -Wcast-align +WARNING2 += -Wdisabled-optimization +WARNING2 += -Wnested-externs +WARNING2 += -Wshadow +WARNING2 += -Wlogical-op +WARNING2 += -Wmissing-field-initializers +WARNING2 += -Wsign-compare +WARNING2 += -Wmaybe-uninitialized + +WARNING3 := -Wbad-function-cast +WARNING3 += -Wcast-qual +WARNING3 += -Wconversion +WARNING3 += -Wpacked +WARNING3 += -Wpadded +WARNING3 += -Wpointer-arith +WARNING3 += -Wredundant-decls +WARNING3 += -Wswitch-default +WARNING3 += -Wpacked-bitfield-compat +WARNING3 += -Wvla + +ifeq (${W},1) +WARNINGS := $(WARNING1) +else ifeq (${W},2) +WARNINGS := $(WARNING1) $(WARNING2) +else ifeq (${W},3) +WARNINGS := $(WARNING1) $(WARNING2) $(WARNING3) +endif + +ifneq (${E},0) +ERRORS := -Werror +endif + CPPFLAGS = ${DEFINES} ${INCLUDES} ${MBEDTLS_INC} -nostdinc \ - -Wmissing-include-dirs -Werror + -Wmissing-include-dirs $(ERRORS) $(WARNINGS) ASFLAGS += $(CPPFLAGS) $(ASFLAGS_$(ARCH)) \ -D__ASSEMBLY__ -ffreestanding \ -Wa,--fatal-warnings diff --git a/bl2/aarch32/bl2_arch_setup.c b/bl2/aarch32/bl2_arch_setup.c index db8a068a1ae3b16805e100f6df8eaec9e4e07caf..4fd8d0725e44aadc552920996b05e42ccdd6c015 100644 --- a/bl2/aarch32/bl2_arch_setup.c +++ b/bl2/aarch32/bl2_arch_setup.c @@ -4,6 +4,7 @@ * SPDX-License-Identifier: BSD-3-Clause */ +#include "../bl2_private.h" /******************************************************************************* * Place holder function to perform any Secure SVC specific architectural diff --git a/bl2/bl2_private.h b/bl2/bl2_private.h index 7fd17bfe474fdb564e7aed2a0a7730d7ae48d554..01f6c6bd2c83c3150d00add303bbbf7df9abe4ae 100644 --- a/bl2/bl2_private.h +++ b/bl2/bl2_private.h @@ -8,6 +8,9 @@ #define BL2_PRIVATE_H #if BL2_IN_XIP_MEM + +#include <stdint.h> + /******************************************************************************* * Declarations of linker defined symbols which will tell us where BL2 lives * in Trusted ROM and RAM diff --git a/drivers/io/io_block.c b/drivers/io/io_block.c index 8226554d92eb9bbb6ab6d870228bc1fae1399a2d..ff13113afb45a5fdd37c5e9264a2fbfd1d1edb5f 100644 --- a/drivers/io/io_block.c +++ b/drivers/io/io_block.c @@ -67,8 +67,10 @@ io_type_t device_type_block(void) static int find_first_block_state(const io_block_dev_spec_t *dev_spec, unsigned int *index_out) { + unsigned int index; int result = -ENOENT; - for (int index = 0; index < MAX_IO_BLOCK_DEVICES; ++index) { + + for (index = 0U; index < MAX_IO_BLOCK_DEVICES; ++index) { /* dev_spec is used as identifier since it's unique */ if (state_pool[index].dev_spec == dev_spec) { result = 0; diff --git a/plat/common/plat_log_common.c b/plat/common/plat_log_common.c index 49e1c152fd09b90a5add003f079cdb14081f49e3..c757c6bf1a375f7f7f38c1fb3b71f573104fe87e 100644 --- a/plat/common/plat_log_common.c +++ b/plat/common/plat_log_common.c @@ -5,6 +5,7 @@ */ #include <debug.h> +#include <platform.h> /* Allow platforms to override the log prefix string */ #pragma weak plat_log_get_prefix diff --git a/plat/hisilicon/hikey/include/platform_def.h b/plat/hisilicon/hikey/include/platform_def.h index f2d358a7ba45313b24b817817160340fce9ecbd6..485eb380041c51a6b5066c95933a22a9a57e2596 100644 --- a/plat/hisilicon/hikey/include/platform_def.h +++ b/plat/hisilicon/hikey/include/platform_def.h @@ -41,7 +41,7 @@ #define MAX_IO_DEVICES 3 #define MAX_IO_HANDLES 4 /* eMMC RPMB and eMMC User Data */ -#define MAX_IO_BLOCK_DEVICES 2 +#define MAX_IO_BLOCK_DEVICES U(2) /* GIC related constants (no GICR in GIC-400) */ #define PLAT_ARM_GICD_BASE 0xF6801000 diff --git a/plat/hisilicon/hikey960/include/platform_def.h b/plat/hisilicon/hikey960/include/platform_def.h index 3717ff8afad47eacba8d556c749a1b2be6534f94..427a1e7596efe7bb5fa88350b83fd1962e96d9da 100644 --- a/plat/hisilicon/hikey960/include/platform_def.h +++ b/plat/hisilicon/hikey960/include/platform_def.h @@ -38,7 +38,7 @@ #define MAX_IO_DEVICES 3 #define MAX_IO_HANDLES 4 /* UFS RPMB and UFS User Data */ -#define MAX_IO_BLOCK_DEVICES 2 +#define MAX_IO_BLOCK_DEVICES U(2) /* diff --git a/plat/hisilicon/poplar/include/platform_def.h b/plat/hisilicon/poplar/include/platform_def.h index 6287a76aade17fac83f31a29f0b70af408ee6c0d..e39d94471a019b738dd75341f91a5b2b35e331af 100644 --- a/plat/hisilicon/poplar/include/platform_def.h +++ b/plat/hisilicon/poplar/include/platform_def.h @@ -40,7 +40,7 @@ /* IO framework user */ #define MAX_IO_DEVICES (4) #define MAX_IO_HANDLES (4) -#define MAX_IO_BLOCK_DEVICES (2) +#define MAX_IO_BLOCK_DEVICES U(2) /* Memory size options */ #define POPLAR_DRAM_SIZE_1G 0 diff --git a/plat/imx/imx7/warp7/include/platform_def.h b/plat/imx/imx7/warp7/include/platform_def.h index d0148f42230bae5bfbdfaa2d03fcc221a2f34830..4ee6fd37deb49fac52cb19fdec52093636848b09 100644 --- a/plat/imx/imx7/warp7/include/platform_def.h +++ b/plat/imx/imx7/warp7/include/platform_def.h @@ -169,7 +169,7 @@ #define MAX_XLAT_TABLES 6 #define MAX_IO_DEVICES 2 #define MAX_IO_HANDLES 3 -#define MAX_IO_BLOCK_DEVICES 1 +#define MAX_IO_BLOCK_DEVICES 1U /* UART defines */ #if PLAT_WARP7_UART == 1 diff --git a/plat/socionext/uniphier/include/platform_def.h b/plat/socionext/uniphier/include/platform_def.h index 3d71db20537cb78f6f8e7f0fe2c9da779ea5f7b1..6e9b98edb1ce169bbffb053ba2c27a4b735dfa31 100644 --- a/plat/socionext/uniphier/include/platform_def.h +++ b/plat/socionext/uniphier/include/platform_def.h @@ -53,7 +53,7 @@ #define MAX_IO_HANDLES 2 #define MAX_IO_DEVICES 2 -#define MAX_IO_BLOCK_DEVICES 1 +#define MAX_IO_BLOCK_DEVICES U(1) #define TSP_SEC_MEM_BASE (BL32_BASE) #define TSP_SEC_MEM_SIZE ((BL32_LIMIT) - (BL32_BASE))