[PATCH 00/18] Annotate switch/case fallthrough cases
Heinrich Schuchardt
xypron.glpk at gmx.de
Fri Mar 28 11:28:05 CET 2025
On 27.03.25 16:32, Andre Przywara wrote:
> C's implicit fallthrough behaviour in switch/case statements can lead to
> subtle bugs. Quite some while ago many compilers introduced warnings in
> those cases, requiring intentional fallthrough's to be annotated.
>
> So far we were not enabling that compiler option, so many ambiguities
> and some bugs in the code went unnoticed.
>
> This series adds the required annotations in code paths that the first
> stage of the U-Boot CI covers. There is a large number of cases left
> in the libbz2 code. The usage of switch/case is borderline insane there,
> labels are hidden in macros, and there are no breaks, but just goto's.
> Upstream still uses very similar code, without any annotations. I still
> am not 100% sure those are meant to fall through or not, and plan to do
> further investigations, but didn't want to hold the rest of the patches
> back. You can see for yourself by applying patch 18/18 and building for
> sandbox64, for instance.
Can we use something like
CFLAGS_REMOVE_bzlib.o = -Wimplicit-fallthrough
in the Makefile if that module is too hard to fix?
Best regards
Heinrich
>
> Because of this we cannot quite enable the warning in the Makefile yet,
> but those fixes are worth regardless, and be it to increase readability.
>
> Please not that those patches do not fix anything, really, they just add
> those fallthrough annotations, so the series is not really critical.
>
> Cheers,
> Andre
>
> Andre Przywara (18):
> spl: mmc: properly annotate fallthrough
> zlib: annotate switch/case fallthrough cases
> gadget: f_thor: annotate switch/case fallthrough
> use proper fallthrough annotations
> net/net: fix switch/case fallthrough annotations
> fastboot: annotate switch/case fallthrough case
> net: sun8i-emac: annotate fallthrough
> usb: ohci-hcd: annotate switch/case fallthrough
> usb: xhci: annotate switch/case fallthrough properly (TBF)
> video: annotate switch/case fall-through
> net: e1000: annotate switch/case fallthrough
> mtd: ubi: annotate fallthrough (TBF)
> arm: mach-k3: am62p: annotate switch/case fallthrough
> mtd: spi-nor-tiny: annotate switch/case fallthrough
> mtd: rawnand: nand_base: annotate switch/case fallthrough
> cmd: pmic: annotate switch/case fallthrough
> cmd: spl: annotate switch/case fallthrough
> [DO NOT MERGE] Makefile: enable switch/case fallthrough warnings
>
> Makefile | 1 +
> arch/arm/mach-k3/am62px/am62p5_init.c | 1 +
> cmd/pmic.c | 1 +
> cmd/spl.c | 2 ++
> common/command.c | 2 +-
> common/spl/spl_mmc.c | 1 +
> drivers/fastboot/fb_command.c | 1 +
> drivers/mtd/nand/raw/nand_base.c | 4 ++++
> drivers/mtd/spi/spi-nor-tiny.c | 1 +
> drivers/mtd/ubi/attach.c | 1 +
> drivers/mtd/ubi/build.c | 3 +++
> drivers/net/e1000.c | 2 ++
> drivers/net/sun8i_emac.c | 1 +
> drivers/usb/gadget/f_thor.c | 1 +
> drivers/usb/host/ohci-hcd.c | 3 ++-
> drivers/usb/host/xhci.c | 2 +-
> drivers/video/video-uclass.c | 2 ++
> lib/tiny-printf.c | 2 +-
> lib/zlib/inflate.c | 21 +++++++++++++++++++++
> net/net.c | 5 ++---
> 20 files changed, 50 insertions(+), 7 deletions(-)
>
More information about the U-Boot
mailing list