2012-12-14 18:36:44 +08:00
|
|
|
Device tree bindings for GPMC connected NANDs
|
|
|
|
|
|
|
|
GPMC connected NAND (found on OMAP boards) are represented as child nodes of
|
|
|
|
the GPMC controller with a name of "nand".
|
|
|
|
|
|
|
|
All timing relevant properties as well as generic gpmc child properties are
|
|
|
|
explained in a separate documents - please refer to
|
|
|
|
Documentation/devicetree/bindings/bus/ti-gpmc.txt
|
|
|
|
|
|
|
|
For NAND specific properties such as ECC modes or bus width, please refer to
|
|
|
|
Documentation/devicetree/bindings/mtd/nand.txt
|
|
|
|
|
|
|
|
|
|
|
|
Required properties:
|
|
|
|
|
|
|
|
- reg: The CS line the peripheral is connected to
|
|
|
|
|
|
|
|
Optional properties:
|
|
|
|
|
|
|
|
- nand-bus-width: Set this numeric value to 16 if the hardware
|
|
|
|
is wired that way. If not specified, a bus
|
|
|
|
width of 8 is assumed.
|
|
|
|
|
|
|
|
- ti,nand-ecc-opt: A string setting the ECC layout to use. One of:
|
2013-10-24 20:50:18 +08:00
|
|
|
"sw" <deprecated> use "ham1" instead
|
|
|
|
"hw" <deprecated> use "ham1" instead
|
|
|
|
"hw-romcode" <deprecated> use "ham1" instead
|
|
|
|
"ham1" 1-bit Hamming ecc code
|
2012-12-14 18:36:44 +08:00
|
|
|
"bch4" 4-bit BCH ecc code
|
|
|
|
"bch8" 8-bit BCH ecc code
|
|
|
|
|
2013-04-20 04:08:28 +08:00
|
|
|
- ti,nand-xfer-type: A string setting the data transfer type. One of:
|
|
|
|
|
|
|
|
"prefetch-polled" Prefetch polled mode (default)
|
|
|
|
"polled" Polled mode, without prefetch
|
|
|
|
"prefetch-dma" Prefetch enabled sDMA mode
|
|
|
|
"prefetch-irq" Prefetch enabled irq mode
|
|
|
|
|
ARM: OMAP2+: cleaned-up DT support of various ECC schemes
OMAP NAND driver support multiple ECC scheme, which can used in different
flavours, depending on in-build Hardware engines present on SoC.
This patch updates following in DT bindings related to sectionion of ecc-schemes
- ti,elm-id: replaces elm_id (maintains backward compatibility)
- ti,nand-ecc-opts: selection of h/w or s/w implementation of an ecc-scheme
depends on ti,elm-id. (supported values ham1, bch4, and bch8)
- maintain backward compatibility to deprecated DT bindings (sw, hw, hw-romcode)
Below table shows different flavours of ecc-schemes supported by OMAP devices
+---------------------------------------+---------------+---------------+
| ECC scheme |ECC calculation|Error detection|
+---------------------------------------+---------------+---------------+
|OMAP_ECC_HAM1_CODE_HW |H/W (GPMC) |S/W |
+---------------------------------------+---------------+---------------+
|OMAP_ECC_BCH8_CODE_HW_DETECTION_SW |H/W (GPMC) |S/W |
|(requires CONFIG_MTD_NAND_ECC_BCH) | | |
+---------------------------------------+---------------+---------------+
|OMAP_ECC_BCH8_CODE_HW |H/W (GPMC) |H/W (ELM) |
|(requires CONFIG_MTD_NAND_OMAP_BCH && | | |
| ti,elm-id in DT) | | |
+---------------------------------------+---------------+---------------+
To optimize footprint of omap2-nand driver, selection of some ECC schemes
also require enabling following Kconfigs, in addition to setting appropriate
DT bindings
- Kconfig:CONFIG_MTD_NAND_ECC_BCH error detection done in software
- Kconfig:CONFIG_MTD_NAND_OMAP_BCH error detection done by h/w engine
Signed-off-by: Pekon Gupta <pekon@ti.com>
Reviewed-by: Felipe Balbi <balbi@ti.com>
Acked-by: Tony Lindgren <tony@atomide.com>
Tested-by: Ezequiel Garcia <ezequiel.garcia@free-electrons.com>
Signed-off-by: Brian Norris <computersforpeace@gmail.com>
2013-10-24 20:50:17 +08:00
|
|
|
- elm_id: <deprecated> use "ti,elm-id" instead
|
|
|
|
- ti,elm-id: Specifies phandle of the ELM devicetree node.
|
|
|
|
ELM is an on-chip hardware engine on TI SoC which is used for
|
|
|
|
locating ECC errors for BCHx algorithms. SoC devices which have
|
|
|
|
ELM hardware engines should specify this device node in .dtsi
|
|
|
|
Using ELM for ECC error correction frees some CPU cycles.
|
2013-01-18 12:57:46 +08:00
|
|
|
|
2012-12-14 18:36:44 +08:00
|
|
|
For inline partiton table parsing (optional):
|
|
|
|
|
|
|
|
- #address-cells: should be set to 1
|
|
|
|
- #size-cells: should be set to 1
|
|
|
|
|
|
|
|
Example for an AM33xx board:
|
|
|
|
|
|
|
|
gpmc: gpmc@50000000 {
|
|
|
|
compatible = "ti,am3352-gpmc";
|
|
|
|
ti,hwmods = "gpmc";
|
|
|
|
reg = <0x50000000 0x1000000>;
|
|
|
|
interrupts = <100>;
|
|
|
|
gpmc,num-cs = <8>;
|
|
|
|
gpmc,num-waitpins = <2>;
|
|
|
|
#address-cells = <2>;
|
|
|
|
#size-cells = <1>;
|
|
|
|
ranges = <0 0 0x08000000 0x2000>; /* CS0: NAND */
|
2013-01-18 12:57:46 +08:00
|
|
|
elm_id = <&elm>;
|
2012-12-14 18:36:44 +08:00
|
|
|
|
|
|
|
nand@0,0 {
|
|
|
|
reg = <0 0 0>; /* CS0, offset 0 */
|
|
|
|
nand-bus-width = <16>;
|
|
|
|
ti,nand-ecc-opt = "bch8";
|
2013-04-20 04:08:28 +08:00
|
|
|
ti,nand-xfer-type = "polled";
|
2012-12-14 18:36:44 +08:00
|
|
|
|
2013-04-10 00:37:40 +08:00
|
|
|
gpmc,sync-clk-ps = <0>;
|
|
|
|
gpmc,cs-on-ns = <0>;
|
|
|
|
gpmc,cs-rd-off-ns = <44>;
|
|
|
|
gpmc,cs-wr-off-ns = <44>;
|
|
|
|
gpmc,adv-on-ns = <6>;
|
|
|
|
gpmc,adv-rd-off-ns = <34>;
|
|
|
|
gpmc,adv-wr-off-ns = <44>;
|
|
|
|
gpmc,we-off-ns = <40>;
|
|
|
|
gpmc,oe-off-ns = <54>;
|
|
|
|
gpmc,access-ns = <64>;
|
|
|
|
gpmc,rd-cycle-ns = <82>;
|
|
|
|
gpmc,wr-cycle-ns = <82>;
|
|
|
|
gpmc,wr-access-ns = <40>;
|
|
|
|
gpmc,wr-data-mux-bus-ns = <0>;
|
2012-12-14 18:36:44 +08:00
|
|
|
|
|
|
|
#address-cells = <1>;
|
|
|
|
#size-cells = <1>;
|
|
|
|
|
|
|
|
/* partitions go here */
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|