[PATCH v5 0/4] Mediatek MT2712 NAND FLASH Controller driver

Boris Brezillon boris.brezillon at free-electrons.com
Wed May 31 07:32:29 PDT 2017


On Wed, 31 May 2017 16:26:37 +0800
Xiaolei Li <xiaolei.li at mediatek.com> wrote:

> The following patch-set adds support for Mediatek MT2712 NAND FLASH
> Controller.

Applied to nand/next.

Thanks,

Boris

> 
> Changes on v5 relative to:
> --------------------
> 
> tree    : https://github.com/bbrezillon/linux-0day
> branch  : nand/next
> commit  :
>         'commit 2b12c057cc28 ("mtd: nand: brcmnand: Check flash #WP pin
>          status before nand erase/program")'
> 
> Patch v5:
> ---------
> - rename variable j as closest_spare in function mtk_nfc_set_spare_per_sector
> - remove unneeded parenthesis
> - add define MTK_NFC_MIN_SPARE to check whether there is no entry that is
>   less than *sps.
> 
> Patch v4:
> ---------
> - remove spare size array sort. iterate over all entries of spare size
>   table and pick the best one.
> 
> Patch v3:
> ---------
> - separate patches into 4.
> - rename struct mtk_ecc_devdata and struct mtk_nfc_devdata to struct
>   mtk_ecc_caps and struct mtk_nfc_caps respectively.
> - add variables const u8 *ecc_strength and u8 num_ecc_strength into struct
>   mtk_ecc_caps, and remove u8 max_ecc_strength.
> - rename variabl u32 temp in function mtk_ecc_probe to u32 max_eccdata_size.
> - remove ECC_CNFG_xBIT define, use a for loop to do ecc hw configuration.
> - remove const u32 *spare_format from struct mtk_nfc_caps, and add variables
>   u8 num_spare_size and u8 pageformat_spare_shift.
> - remove PAGEFMT_SPARE_ define, use a for loop to do nfc hw configuration.
> - sort spare size array before setting spare size.
> - fix coding style issue.
> 
> Patch v2:
> ---------
> - sperate patches into 3.
> - refine DT bindings documentation about NFC and ECC compatible.
> - use ecc->devdata->encode_parity_reg0 and ecc->devdata->err_mask
>   directly, but hide them in define.
> 
> Tests:
> ------
> 
> * ubifs and jffs2 are validated on NAND device MT29F16G08ADBCA
>   by 'dd' command.
> * all drivers/mtd/tests/* pass.
> * speed test:
>   eraseblock write speed is 8318 KiB/s
>   eraseblock read speed is 11374 KiB/s
>   page write speed is 8155 KiB/s
>   page read speed is 11290 KiB/s
>   2 page write speed is 8217 KiB/s
>   2 page read speed is 11354 KiB/s
>   erase speed is 116472 KiB/s
>   2x multi-block erase speed is 352978 KiB/s
>   4x multi-block erase speed is 359750 KiB/s
>   8x multi-block erase speed is 361484 KiB/s
>   16x multi-block erase speed is 364116 KiB/s
>   32x multi-block erase speed is 364116 KiB/s
>   64x multi-block erase speed is 364116 KiB/s
> 
> Xiaolei Li (4):
>   mtd: nand: mediatek: update DT bindings
>   mtd: nand: mediatek: refine register NFI_PAGEFMT setting
>   mtd: nand: mediatek: add support for different MTK NAND FLASH
>     Controller IP
>   mtd: nand: mediatek: add support for MT2712 NAND FLASH Controller
> 
>  Documentation/devicetree/bindings/mtd/mtk-nand.txt |   5 +-
>  drivers/mtd/nand/mtk_ecc.c                         | 218 ++++++++++-----------
>  drivers/mtd/nand/mtk_ecc.h                         |   2 +-
>  drivers/mtd/nand/mtk_nand.c                        | 187 +++++++++---------
>  4 files changed, 206 insertions(+), 206 deletions(-)
> 
> --
> 1.9.1




More information about the Linux-mediatek mailing list