e413a19a8e
- refactor m25p80.c driver for use as a general SPI NOR framework for other drivers which may speak to SPI NOR flash without providing full SPI support (i.e., not part of drivers/spi/) - new Freescale QuadSPI driver (utilizing new SPI NOR framework) - updates for the STMicro "FSM" SPI NOR driver - fix sync/flush behavior on mtd_blkdevs - fixup subpage write support on a few NAND drivers - correct the MTD OOB test for odd-sized OOB areas - add BCH-16 support for OMAP NAND - fix warnings and trivial refactoring - utilize new ECC DT bindings in pxa3xx NAND driver - new LPDDR NVM driver - address a few assorted bugs caught by Coverity - add new imx6sx support for GPMI NAND - use a bounce buffer for NAND when non-DMA-able buffers are used -----BEGIN PGP SIGNATURE----- Version: GnuPG v1 iQIcBAABAgAGBQJTl/9oAAoJEFySrpd9RFgtfnUP+wURZfF1Xnek/3yNZP0Pt90x yToXPDgsK5oteBAAWMUwtnJImDzsUMD8BgLNLU1jvPKuvMo9lwNMaCF+l1wUrTeC F1VgYWq4tub3tk104Dthlguk0Jhj66k61LbvFvKXhkGEYGD9iPFeTPWyARUZTYOv R4eRybuU+l2ZTDd+vNStXx9oWyqzWXekwrhMi10YWoxF694kBMI4C0rZQ2CexjVl B5K0oL2P8JU/yNLgtMgPOfkh8rHZEoXECA3vaQscZzsOnc0evDndKSTkTX1Ls61Y eWFgXV6qyhL+5VKTiHNzi6/J0NeNaTquOs9HoBuWr1DwaS8aoWEhBjeuNrXGYs/s 6++CRoDDcdWunAXBH8hqFSu6IweYB5TQ+QMUa7Z69C9n/fZg82dF4i2RSnp4Y2rs qI19LrPIpdyL1ril5ndp0U2JRYXdxOpX3+jf2anG6u3vYjzI8P8tXEGKUz/uNpnK fpEn2zKpeHAq62eqScuhGsO7MO2bIg7yNKMdSoeeeT9dgbah6fkrQnaDNbtjC+Y1 rXMhgLiVebmm8BVe6w5XSFqCw+76RxmO04TAj/Vy3WVPQ2KNn+OuLc0yVlsqAO9n 7Y19QvHeMZZW4O/w5RQ/OniJpysXN0ESj2cE93DHdgUPQ5aedIN0r5eQA0M1e8c6 W2MQFS5nJPiCxUYia4KP =6UIq -----END PGP SIGNATURE----- Merge tag 'for-linus-20140610' of git://git.infradead.org/linux-mtd Pull MTD updates from Brian Norris: - refactor m25p80.c driver for use as a general SPI NOR framework for other drivers which may speak to SPI NOR flash without providing full SPI support (i.e., not part of drivers/spi/) - new Freescale QuadSPI driver (utilizing new SPI NOR framework) - updates for the STMicro "FSM" SPI NOR driver - fix sync/flush behavior on mtd_blkdevs - fixup subpage write support on a few NAND drivers - correct the MTD OOB test for odd-sized OOB areas - add BCH-16 support for OMAP NAND - fix warnings and trivial refactoring - utilize new ECC DT bindings in pxa3xx NAND driver - new LPDDR NVM driver - address a few assorted bugs caught by Coverity - add new imx6sx support for GPMI NAND - use a bounce buffer for NAND when non-DMA-able buffers are used * tag 'for-linus-20140610' of git://git.infradead.org/linux-mtd: (77 commits) mtd: gpmi: add gpmi support for imx6sx mtd: maps: remove check for CONFIG_MTD_SUPERH_RESERVE mtd: bf5xx_nand: use the managed version of kzalloc mtd: pxa3xx_nand: make the driver work on big-endian systems mtd: nand: omap: fix omap_calculate_ecc_bch() for-loop error mtd: nand: r852: correct write_buf loop bounds mtd: nand_bbt: handle error case for nand_create_badblock_pattern() mtd: nand_bbt: remove unused variable mtd: maps: sc520cdp: fix warnings mtd: slram: fix unused variable warning mtd: pfow: remove unused variable mtd: lpddr: fix Kconfig dependency, for I/O accessors mtd: nand: pxa3xx: Add supported ECC strength and step size to the DT binding mtd: nand: pxa3xx: Use ECC strength and step size devicetree binding mtd: nand: pxa3xx: Clean pxa_ecc_init() error handling mtd: nand: Warn the user if the selected ECC strength is too weak mtd: nand: omap: Documentation: How to select correct ECC scheme for your device ? mtd: nand: omap: add support for BCH16_ECC - NAND driver updates mtd: nand: omap: add support for BCH16_ECC - ELM driver updates mtd: nand: omap: add support for BCH16_ECC - GPMC driver updates ...
138 lines
4.9 KiB
Plaintext
138 lines
4.9 KiB
Plaintext
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:
|
|
"sw" <deprecated> use "ham1" instead
|
|
"hw" <deprecated> use "ham1" instead
|
|
"hw-romcode" <deprecated> use "ham1" instead
|
|
"ham1" 1-bit Hamming ecc code
|
|
"bch4" 4-bit BCH ecc code
|
|
"bch8" 8-bit BCH ecc code
|
|
"bch16" 16-bit BCH ECC code
|
|
Refer below "How to select correct ECC scheme for your device ?"
|
|
|
|
- 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
|
|
|
|
- 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.
|
|
|
|
For inline partition 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 */
|
|
elm_id = <&elm>;
|
|
|
|
nand@0,0 {
|
|
reg = <0 0 0>; /* CS0, offset 0 */
|
|
nand-bus-width = <16>;
|
|
ti,nand-ecc-opt = "bch8";
|
|
ti,nand-xfer-type = "polled";
|
|
|
|
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>;
|
|
|
|
#address-cells = <1>;
|
|
#size-cells = <1>;
|
|
|
|
/* partitions go here */
|
|
};
|
|
};
|
|
|
|
How to select correct ECC scheme for your device ?
|
|
--------------------------------------------------
|
|
Higher ECC scheme usually means better protection against bit-flips and
|
|
increased system lifetime. However, selection of ECC scheme is dependent
|
|
on various other factors also like;
|
|
|
|
(1) support of built in hardware engines.
|
|
Some legacy OMAP SoC do not have ELM harware engine, so those SoC cannot
|
|
support ecc-schemes with hardware error-correction (BCHx_HW). However
|
|
such SoC can use ecc-schemes with software library for error-correction
|
|
(BCHx_HW_DETECTION_SW). The error correction capability with software
|
|
library remains equivalent to their hardware counter-part, but there is
|
|
slight CPU penalty when too many bit-flips are detected during reads.
|
|
|
|
(2) Device parameters like OOBSIZE.
|
|
Other factor which governs the selection of ecc-scheme is oob-size.
|
|
Higher ECC schemes require more OOB/Spare area to store ECC syndrome,
|
|
so the device should have enough free bytes available its OOB/Spare
|
|
area to accomodate ECC for entire page. In general following expression
|
|
helps in determining if given device can accomodate ECC syndrome:
|
|
"2 + (PAGESIZE / 512) * ECC_BYTES" >= OOBSIZE"
|
|
where
|
|
OOBSIZE number of bytes in OOB/spare area
|
|
PAGESIZE number of bytes in main-area of device page
|
|
ECC_BYTES number of ECC bytes generated to protect
|
|
512 bytes of data, which is:
|
|
'3' for HAM1_xx ecc schemes
|
|
'7' for BCH4_xx ecc schemes
|
|
'14' for BCH8_xx ecc schemes
|
|
'26' for BCH16_xx ecc schemes
|
|
|
|
Example(a): For a device with PAGESIZE = 2048 and OOBSIZE = 64 and
|
|
trying to use BCH16 (ECC_BYTES=26) ecc-scheme.
|
|
Number of ECC bytes per page = (2 + (2048 / 512) * 26) = 106 B
|
|
which is greater than capacity of NAND device (OOBSIZE=64)
|
|
Hence, BCH16 cannot be supported on given device. But it can
|
|
probably use lower ecc-schemes like BCH8.
|
|
|
|
Example(b): For a device with PAGESIZE = 2048 and OOBSIZE = 128 and
|
|
trying to use BCH16 (ECC_BYTES=26) ecc-scheme.
|
|
Number of ECC bytes per page = (2 + (2048 / 512) * 26) = 106 B
|
|
which can be accomodate in the OOB/Spare area of this device
|
|
(OOBSIZE=128). So this device can use BCH16 ecc-scheme.
|