[PATCH v2 0/9] add EDO feature for gpmi-nand driver
Huang Shijie
b32955 at freescale.com
Thu Sep 13 02:57:51 EDT 2012
The ONFI nand supports the EDO (extended data out) feature in
asynchronous mode when the host controller(such as gpmi-nand)
uses a tRC of less then 30ns.
The gpmi can supports this EDO feature.
This patch set adds the EDO support the gpmi-nand driver.
patch 1 ~ patch 2:
These two patches provide the infrastructure for the EDO feature.
They add necessary MTD helpers for the ONFI nand set/get features,
and the help to get the supportted timing mode.
These two patches are new version. The init version has been
reviewed by Vikram & Florian.
patch 3 ~ patch 7:
These patches are clean-ups for the gpmi-nand's timing code.
Also they make the some preparations for the EDO patch.
patch 8: add the EDO feature to the gpmi-nand.
patch 9: a small optimization for the timing.
only set the timing registers one time.
I tested this patch set on the IMX6Q-arm2 board with several Micron's
ONFI nand chips. Some chips only can supports to mode 4, some chips
can supports to mode 5.
The performance is much improved. Take Micron MT29F32G08MAA for example
(in mode 5, 100MHz):
1) The test result BEFORE we add the EDO feature:
=================================================
mtd_speedtest: MTD device: 2
mtd_speedtest: MTD device size 209715200, eraseblock size 524288,
page size 4096, count of eraseblocks 400,
pages per eraseblock 128, OOB size 218
.......................................
mtd_speedtest: testing eraseblock read speed
mtd_speedtest: eraseblock read speed is 3632 KiB/s
.......................................
mtd_speedtest: testing page read speed
mtd_speedtest: page read speed is 3554 KiB/s
.......................................
mtd_speedtest: testing 2 page read speed
mtd_speedtest: 2 page read speed is 3592 KiB/s
.......................................
=================================================
2) The test result AFTER we add the EDO feature:
=================================================
mtd_speedtest: MTD device: 2
mtd_speedtest: MTD device size 209715200, eraseblock size 524288,
page size 4096, count of eraseblocks 400,
pages per eraseblock 128, OOB size 218
.......................................
mtd_speedtest: testing eraseblock read speed
mtd_speedtest: eraseblock read speed is 19555 KiB/s
.......................................
mtd_speedtest: testing page read speed
mtd_speedtest: page read speed is 17319 KiB/s
.......................................
mtd_speedtest: testing 2 page read speed
mtd_speedtest: 2 page read speed is 18339 KiB/s
.......................................
=================================================
The read data performance is much improved by more then 5 times.
---
ChangLog:
v1 --> v2:
[1] fix the wrong macro for busy timeout
[2] use the NSEC_PER_SEC to replace the `1000000000`.
[3] fix the wrong macro type for WRN_DLY_SEL.
[4] fix some comments.
[5] misc
Huang Shijie (9):
mtd: add helpers to set/get features for ONFI nand
mtd: add helpers to get the supportted ONFI timing mode
mtd: gpmi: add a new field for HW_GPMI_TIMING1
mtd: gpmi: do not get the clock frequency in gpmi_begin()
mtd: gpmi: add a new field for HW_GPMI_CTRL1
mtd: gpmi: simplify the setting DLL code
mtd: gpmi: do not set the default values for the extra clocks
mtd: gpmi: add EDO feature for imx6q
mtd: gpmi: initialize the timing registers only one time
drivers/mtd/nand/gpmi-nand/gpmi-lib.c | 275 ++++++++++++++++++++++++++++---
drivers/mtd/nand/gpmi-nand/gpmi-nand.c | 23 ++--
drivers/mtd/nand/gpmi-nand/gpmi-nand.h | 19 +++
drivers/mtd/nand/gpmi-nand/gpmi-regs.h | 12 ++
drivers/mtd/nand/nand_base.c | 50 ++++++
include/linux/mtd/nand.h | 39 +++++
6 files changed, 381 insertions(+), 37 deletions(-)
More information about the linux-mtd
mailing list