mtd: rawnand: timings: Make onfi_fill_interface_config() a void helper
authorMiquel Raynal <miquel.raynal@bootlin.com>
Fri, 29 May 2020 11:13:14 +0000 (13:13 +0200)
committerMiquel Raynal <miquel.raynal@bootlin.com>
Fri, 26 Jun 2020 06:35:07 +0000 (08:35 +0200)
Warn the user if the parameters are wrong but basically it would mean
there is a serious issue in the NAND core. So no need to ever check
its output, let's make this helper return void.

Signed-off-by: Miquel Raynal <miquel.raynal@bootlin.com>
Reviewed-by: Boris Brezillon <boris.brezillon@collabora.com>
Link: https://lore.kernel.org/linux-mtd/20200529111322.7184-21-miquel.raynal@bootlin.com
drivers/mtd/nand/raw/internals.h
drivers/mtd/nand/raw/nand_base.c
drivers/mtd/nand/raw/nand_timings.c

index 114c63a6a3492d988884ac270421b6214eacd3a0..63c5af436901361c95d615bf483b43762947ae7f 100644 (file)
@@ -84,10 +84,10 @@ int nand_bbm_get_next_page(struct nand_chip *chip, int page);
 int nand_markbad_bbm(struct nand_chip *chip, loff_t ofs);
 int nand_erase_nand(struct nand_chip *chip, struct erase_info *instr,
                    int allowbbt);
-int onfi_fill_interface_config(struct nand_chip *chip,
-                              struct nand_interface_config *iface,
-                              enum nand_interface_type type,
-                              unsigned int timing_mode);
+void onfi_fill_interface_config(struct nand_chip *chip,
+                               struct nand_interface_config *iface,
+                               enum nand_interface_type type,
+                               unsigned int timing_mode);
 unsigned int
 onfi_find_closest_sdr_mode(const struct nand_sdr_timings *spec_timings);
 int nand_get_features(struct nand_chip *chip, int addr, u8 *subfeature_param);
index 4fa18fb68d621329ba69b5d120c62c290ae97165..3bfd71d589cf81d64cfe24781357a1ef40ac625f 100644 (file)
@@ -1041,10 +1041,8 @@ static int nand_choose_interface_config(struct nand_chip *chip)
        }
 
        for (mode = fls(modes) - 1; mode >= 0; mode--) {
-               ret = onfi_fill_interface_config(chip, &chip->interface_config,
-                                                NAND_SDR_IFACE, mode);
-               if (ret)
-                       continue;
+               onfi_fill_interface_config(chip, &chip->interface_config,
+                                          NAND_SDR_IFACE, mode);
 
                /*
                 * Pass NAND_DATA_IFACE_CHECK_ONLY to only check if the
index bf05b4bceaa0bfd644719ccf3a8c4017d5f4d9ee..1e22006c79bae533cd16b14fdd524003ba70946c 100644 (file)
@@ -347,18 +347,18 @@ onfi_find_closest_sdr_mode(const struct nand_sdr_timings *spec_timings)
  * @type: The interface type
  * @timing_mode: The ONFI timing mode
  */
-int onfi_fill_interface_config(struct nand_chip *chip,
-                              struct nand_interface_config *iface,
-                              enum nand_interface_type type,
-                              unsigned int timing_mode)
+void onfi_fill_interface_config(struct nand_chip *chip,
+                               struct nand_interface_config *iface,
+                               enum nand_interface_type type,
+                               unsigned int timing_mode)
 {
        struct onfi_params *onfi = chip->parameters.onfi;
 
-       if (type != NAND_SDR_IFACE)
-               return -EINVAL;
+       if (WARN_ON(type != NAND_SDR_IFACE))
+               return;
 
-       if (timing_mode >= ARRAY_SIZE(onfi_sdr_timings))
-               return -EINVAL;
+       if (WARN_ON(timing_mode >= ARRAY_SIZE(onfi_sdr_timings)))
+               return;
 
        *iface = onfi_sdr_timings[timing_mode];
 
@@ -378,6 +378,4 @@ int onfi_fill_interface_config(struct nand_chip *chip,
                /* nanoseconds -> picoseconds */
                timings->tCCS_min = 1000UL * onfi->tCCS;
        }
-
-       return 0;
 }