This patch adds a new structure, 'nand_timing_spec', to capture the A/C
timing characteristics of NAND devices.

Unfortunately, there is no universally accepted standard for defining
NAND timing parameters. Different datasheets list different sets of
parameters. The ONFI standard gets close, but support is missing from
some of the major NAND manufacturers (e.g. Samsung, Toshiba). Here we
have followed broadly the ONFI timing definitions.

We also provide specifications for the six standard ONFI timing modes,
in terms of the new nand_timing_spec structure. This will allow fully
automated configuration of the timing registers when using
ONFI-compliant NAND.

Signed-off-by: Lee Jones <lee.jo...@linaro.org>
---
 drivers/mtd/nand/nand_ids.c | 165 ++++++++++++++++++++++++++++++++++++++++++++
 include/linux/mtd/nand.h    |  34 +++++++++
 2 files changed, 199 insertions(+)

diff --git a/drivers/mtd/nand/nand_ids.c b/drivers/mtd/nand/nand_ids.c
index a87b0a3..12f769d 100644
--- a/drivers/mtd/nand/nand_ids.c
+++ b/drivers/mtd/nand/nand_ids.c
@@ -175,6 +175,171 @@ struct nand_manufacturers nand_manuf_ids[] = {
 EXPORT_SYMBOL(nand_manuf_ids);
 EXPORT_SYMBOL(nand_flash_ids);
 
+/*
+ * ONFI NAND Timing Mode Specifications
+ *
+ * Note, 'tR' field (maximum page read time) is extracted from the ONFI
+ * parameter page during device probe.
+ */
+struct nand_timing_spec nand_onfi_timing_specs[] = {
+       /*
+        * ONFI Timing Mode '0' (supported on all ONFI compliant devices)
+        */
+       [0] = {
+               .tCLS   = 50,
+               .tCS    = 70,
+               .tALS   = 50,
+               .tDS    = 40,
+               .tWP    = 50,
+               .tCLH   = 20,
+               .tCH    = 20,
+               .tALH   = 20,
+               .tDH    = 20,
+               .tWB    = 200,
+               .tWH    = 30,
+               .tWC    = 100,
+               .tRP    = 50,
+               .tREH   = 30,
+               .tRC    = 100,
+               .tREA   = 40,
+               .tRHOH  = 0,
+               .tCEA   = 100,
+               .tCOH   = 0,
+               .tCHZ   = 100,
+       },
+
+       /*
+        * ONFI Timing Mode '1'
+        */
+       [1] = {
+               .tCLS   = 25,
+               .tCS    = 35,
+               .tALS   = 25,
+               .tDS    = 20,
+               .tWP    = 25,
+               .tCLH   = 10,
+               .tCH    = 10,
+               .tALH   = 10,
+               .tDH    = 10,
+               .tWB    = 100,
+               .tWH    = 15,
+               .tWC    = 45,
+               .tRP    = 25,
+               .tREH   = 15,
+               .tRC    = 50,
+               .tREA   = 30,
+               .tRHOH  = 15,
+               .tCEA   = 45,
+               .tCOH   = 15,
+               .tCHZ   = 50,
+       },
+
+       /*
+        * ONFI Timing Mode '2'
+        */
+       [2] = {
+               .tCLS   = 15,
+               .tCS    = 25,
+               .tALS   = 15,
+               .tDS    = 15,
+               .tWP    = 17,
+               .tCLH   = 10,
+               .tCH    = 10,
+               .tALH   = 10,
+               .tDH    = 5,
+               .tWB    = 100,
+               .tWH    = 15,
+               .tWC    = 35,
+               .tRP    = 17,
+               .tREH   = 16,
+               .tRC    = 35,
+               .tREA   = 25,
+               .tRHOH  = 15,
+               .tCEA   = 30,
+               .tCOH   = 15,
+               .tCHZ   = 50,
+       },
+
+       /*
+        * ONFI Timing Mode '3'
+        */
+       [3] = {
+               .tCLS   = 10,
+               .tCS    = 25,
+               .tALS   = 10,
+               .tDS    = 10,
+               .tWP    = 15,
+               .tCLH   = 5,
+               .tCH    = 5,
+               .tALH   = 5,
+               .tDH    = 5,
+               .tWB    = 100,
+               .tWH    = 10,
+               .tWC    = 30,
+               .tRP    = 15,
+               .tREH   = 10,
+               .tRC    = 30,
+               .tREA   = 20,
+               .tRHOH  = 15,
+               .tCEA   = 25,
+               .tCOH   = 15,
+               .tCHZ   = 50,
+       },
+
+       /*
+        * ONFI Timing Mode '4' (EDO only)
+        */
+       [4] = {
+               .tCLS   = 10,
+               .tCS    = 20,
+               .tALS   = 10,
+               .tDS    = 10,
+               .tWP    = 12,
+               .tCLH   = 5,
+               .tCH    = 5,
+               .tALH   = 5,
+               .tDH    = 5,
+               .tWB    = 100,
+               .tWH    = 10,
+               .tWC    = 25,
+               .tRP    = 12,
+               .tREH   = 10,
+               .tRC    = 25,
+               .tREA   = 20,
+               .tRHOH  = 15,
+               .tCEA   = 25,
+               .tCOH   = 15,
+               .tCHZ   = 30,
+       },
+
+       /*
+        * ONFI Timing Mode '5' (EDO only)
+        */
+       [5] = {
+               .tCLS   = 10,
+               .tCS    = 15,
+               .tALS   = 10,
+               .tDS    = 7,
+               .tWP    = 10,
+               .tCLH   = 5,
+               .tCH    = 5,
+               .tALH   = 5,
+               .tDH    = 5,
+               .tWB    = 100,
+               .tWH    = 7,
+               .tWC    = 20,
+               .tRP    = 10,
+               .tREH   = 7,
+               .tRC    = 20,
+               .tREA   = 16,
+               .tRHOH  = 15,
+               .tCEA   = 25,
+               .tCOH   = 15,
+               .tCHZ   = 30,
+       }
+};
+EXPORT_SYMBOL(nand_onfi_timing_specs);
+
 MODULE_LICENSE("GPL");
 MODULE_AUTHOR("Thomas Gleixner <t...@linutronix.de>");
 MODULE_DESCRIPTION("Nand device & manufacturer IDs");
diff --git a/include/linux/mtd/nand.h b/include/linux/mtd/nand.h
index f7b6a53..0d456b4 100644
--- a/include/linux/mtd/nand.h
+++ b/include/linux/mtd/nand.h
@@ -326,6 +326,40 @@ struct onfi_ext_param_page {
         */
 } __packed;
 
+/*
+ * NAND Device Timing Specification
+ *
+ * All values in nano seconds, except where specified.
+ */
+struct nand_timing_spec {
+       int     tR;             /* Max Page Read delay [us]*/
+       int     tCLS;           /* Min CLE setup time */
+       int     tCS;            /* Min CE setup time */
+       int     tALS;           /* Min ALE setup time */
+       int     tDS;            /* Min Data setup time */
+       int     tWP;            /* Min WE pulse width */
+       int     tCLH;           /* Min CLE hold time */
+       int     tCH;            /* Min CE hold time */
+       int     tALH;           /* Min ALE hold time */
+       int     tDH;            /* Min Data hold time */
+       int     tWB;            /* Max WE high to busy */
+       int     tWH;            /* Min WE hold time */
+       int     tWC;            /* Min Write cycle time */
+       int     tRP;            /* Min RE pulse width */
+       int     tREH;           /* Min RE high hold time */
+       int     tRC;            /* Min Read cycle time */
+       int     tREA;           /* Max Read access time */
+       int     tRHOH;          /* Min RE high to output hold */
+       int     tCEA;           /* Max CE access time */
+       int     tCOH;           /* Min CE high to output hold */
+       int     tCHZ;           /* Max CE high to output high Z */
+       int     tCSD;           /* Min CE high to ALE/CLE don't care */
+};
+
+/* ONFI define 6 timing modes */
+#define NAND_ONFI_TIMING_MODES         6
+extern struct nand_timing_spec nand_onfi_timing_specs[];
+
 /**
  * struct nand_hw_control - Control structure for hardware controller (e.g ECC 
generator) shared among independent devices
  * @lock:               protection lock
-- 
1.8.3.2

--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/

Reply via email to