[PATCH 15/18] mtd: rawnand: nand_base: annotate switch/case fallthrough
Michael Nazzareno Trimarchi
michael at amarulasolutions.com
Fri Mar 28 09:26:55 CET 2025
On Thu, Mar 27, 2025 at 4:33 PM Andre Przywara <andre.przywara at arm.com>
wrote:
> The raw NAND flash code uses an implicit switch/case fallthrough to
> share code when dealing with different ECC modes, and also when handling
> some read command.
>
> Add our "fallthrough;" statement-like macro before the respective labels
> in the NAND code, to avoid a warning when GCC's -Wimplicit-fallthrough
> warning option is enabled.
>
> This copies the fallthrough annotations that the original kernel code
> gained, before this function got refactored there.
>
> Signed-off-by: Andre Przywara <andre.przywara at arm.com>
> ---
> drivers/mtd/nand/raw/nand_base.c | 4 ++++
> 1 file changed, 4 insertions(+)
>
> diff --git a/drivers/mtd/nand/raw/nand_base.c
> b/drivers/mtd/nand/raw/nand_base.c
> index 1b65c6f6443..daf12807c67 100644
> --- a/drivers/mtd/nand/raw/nand_base.c
> +++ b/drivers/mtd/nand/raw/nand_base.c
> @@ -774,6 +774,7 @@ static void nand_command_lp(struct mtd_info *mtd,
> unsigned int command,
> NAND_NCE | NAND_CTRL_CHANGE);
>
> /* This applies to read commands */
> + fallthrough;
> default:
> /*
> * If we don't have access to the busy pin, we apply the
> given
> @@ -4974,6 +4975,7 @@ int nand_scan_tail(struct mtd_info *mtd)
> if (!ecc->read_page)
> ecc->read_page = nand_read_page_hwecc_oob_first;
>
> + fallthrough;
> case NAND_ECC_HW:
> /* Use standard hwecc read page function? */
> if (!ecc->read_page)
> @@ -4993,6 +4995,7 @@ int nand_scan_tail(struct mtd_info *mtd)
> if (!ecc->write_subpage && ecc->hwctl && ecc->calculate)
> ecc->write_subpage = nand_write_subpage_hwecc;
>
> + fallthrough;
> case NAND_ECC_HW_SYNDROME:
> if ((!ecc->calculate || !ecc->correct || !ecc->hwctl) &&
> (!ecc->read_page ||
> @@ -5027,6 +5030,7 @@ int nand_scan_tail(struct mtd_info *mtd)
> ecc->size, mtd->writesize);
> ecc->mode = NAND_ECC_SOFT;
>
> + fallthrough;
> case NAND_ECC_SOFT:
> ecc->calculate = nand_calculate_ecc;
> ecc->correct = nand_correct_data;
> --
> 2.25.1
>
Reviewed-by: Michael Trimrachi <michael at amarulasolutions.com>
I think I will apply the relative patches on mtd tree
Michael
--
Michael Nazzareno Trimarchi
Co-Founder & Chief Executive Officer
M. +39 347 913 2170
michael at amarulasolutions.com
__________________________________
Amarula Solutions BV
Joop Geesinkweg 125, 1114 AB, Amsterdam, NL
T. +31 (0)85 111 9172
info at amarulasolutions.com
www.amarulasolutions.com
More information about the U-Boot
mailing list