|
|
Subscribe / Log in / New account

New Arasan NAND controller driver

From:  Miquel Raynal <miquel.raynal-AT-bootlin.com>
To:  Rob Herring <robh+dt-AT-kernel.org>, Mark Rutland <mark.rutland-AT-arm.com>, <devicetree-AT-vger.kernel.org>, Richard Weinberger <richard-AT-nod.at>, Vignesh Raghavendra <vigneshr-AT-ti.com>, Tudor Ambarus <Tudor.Ambarus-AT-microchip.com>, <linux-mtd-AT-lists.infradead.org>
Subject:  [PATCH v3 0/8] New Arasan NAND controller driver
Date:  Thu, 7 May 2020 13:00:26 +0200
Message-ID:  <20200507110034.14736-1-miquel.raynal@bootlin.com>
Cc:  Thomas Petazzoni <thomas.petazzoni-AT-bootlin.com>, Boris Brezillon <boris.brezillon-AT-collabora.com>, Michal Simek <monstr-AT-monstr.eu>, Naga Sureshkumar Relli <nagasure-AT-xilinx.com>, Miquel Raynal <miquel.raynal-AT-bootlin.com>
Archive-link:  Article

New Arasan NAND controller driver

Hello,

This is a deep rework of Naga's Arasan NAND controller driver. This
version is the final version and works with software ECC. It relies on
a previous series called "Supporting restricted NAND controllers" that
brings more flexibility to the NAND with the goal to support
restricted controllers like this one.

Cheers,
Miquèl

Changes in v3:
* Prefix specific clock definitions with XLNX as they do not apply for
  any other SoC and are attached to a single compatible.
* Used field getters/setters as defined in bitfield.h.
* Force casting to u32 before shifting u8 values by 8 16 or 24 bits.
* Comply with the recent core changes and select manually
  nand_monolithic_read/write_page_raw() helpers.
* Add MAINTAINER patch.
* Add a bit extraction helper in the core.
* Rename BCH functions.
* Add a swapping bit mechanism to BCH.
* Support the hardware ECC engine.

Changes in v2:
* Working ->exec_op() implementation relying on core changes.
* Dropped the ECC support for now, will be part of another series if
  this patch is accepted.

Boris Brezillon (1):
  lib/bch: Allow easy bit swapping

Miquel Raynal (7):
  lib/bch: Rework a little bit the exported function names
  mtd: rawnand: Ensure the number of bitflips is consistent
  mtd: rawnand: Add nand_extract_bits()
  MAINTAINERS: Add Arasan NAND controller and bindings
  dt-bindings: mtd: Document ARASAN NAND bindings
  mtd: rawnand: arasan: Add new Arasan NAND controller
  mtd: rawnand: arasan: Support the hardware BCH ECC engine

 .../bindings/mtd/arasan,nand-controller.yaml  |   63 +
 MAINTAINERS                                   |    7 +
 drivers/mtd/devices/docg3.c                   |   10 +-
 drivers/mtd/nand/raw/Kconfig                  |    7 +
 drivers/mtd/nand/raw/Makefile                 |    1 +
 drivers/mtd/nand/raw/arasan-nand-controller.c | 1207 +++++++++++++++++
 drivers/mtd/nand/raw/nand_base.c              |   41 +-
 drivers/mtd/nand/raw/nand_bch.c               |   10 +-
 include/linux/bch.h                           |    9 +-
 include/linux/mtd/rawnand.h                   |    4 +
 lib/bch.c                                     |  148 +-
 11 files changed, 1443 insertions(+), 64 deletions(-)
 create mode 100644 Documentation/devicetree/bindings/mtd/arasan,nand-controller.yaml
 create mode 100644 drivers/mtd/nand/raw/arasan-nand-controller.c

-- 
2.20.1



Copyright © 2020, Eklektix, Inc.
Comments and public postings are copyrighted by their creators.
Linux is a registered trademark of Linus Torvalds