[PATCH 00/18] Annotate switch/case fallthrough cases
Andre Przywara
andre.przywara at arm.com
Fri Mar 28 11:39:59 CET 2025
On Fri, 28 Mar 2025 11:28:05 +0100
Heinrich Schuchardt <xypron.glpk at gmx.de> wrote:
Hi,
> 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
Ah, didn't know we have that in U-Boot as well! Sounds promising, and
fixes the sandbox build for me (when using bzlib_decompress.o). I will add
this to the last patch and will check what the CI has to say about this.
Thanks for the heads up!
Cheers,
Andre
>
> 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