[PATCH v2 0/5] mtd: pxa3xx_nand: add support for Armada 8k

Miquel Raynal miquel.raynal at bootlin.com
Mon Oct 26 10:36:49 CET 2020


Hi Stefan,

Stefan Roese <sr at denx.de> wrote on Tue, 20 Oct 2020 10:29:52 +0200:

> Hi Baruch,
> Hi Chris,
> 
> On 19.10.20 07:24, Baruch Siach wrote:
> > Hi Chris,
> > 
> > On Sun, Oct 18 2020, Chris Packham wrote:  
> >> On Mon, Oct 19, 2020 at 1:59 AM Baruch Siach <baruch at tkos.co.il> wrote:  
> >>>
> >>> This series adds NAND flash support to Aramda 8k systems. Patches make the
> >>> necessary changes to the pxa3xx_nand driver and DT files.
> >>>
> >>> v2:
> >>>    Rebase on current master. Fixes conflict with commit 661c98121d4 ("mtd: nand:
> >>>    pxa3xx: Fix not calling dev_xxx with a device")  
> >>
> >> Is it worth looking at bringing in the newer marvell_nand driver from
> >> Linux? I suspect that it will be easier to keep in sync with changes
> >> for the Armada 8K. I have considered it in the past but it kind of
> >> fell off my radar.  
> > 
> > The kernel raw nand API has seen some significant changes recently. It
> > looks like the kernel marvell_nand driver relies on newer API. I'm not
> > sure how easy would be syncing the drivers to a degree that makes
> > porting of changes trivial. It would probably require many other changes
> > in generic U-Boot raw NAND code.  
> 
> I agree that without a re-sync with a more recent Linux MTD (NAND) core
> code, this task might prove complex and failure prone. And sync'ing the
> MTD core is also a pretty complex task which needs to be done very
> carefully, to not break any existing platforms. FWICT, nobody is working
> on it right now and we can't wait for this to happen and stall the
> development here. So from my point of view, I'm okay with updates to
> the current PXA NAND driver. Testing of these patches on other platforms
> would be very welcome though.
> 
> > Maybe Miquel can shed some light on that.

Yes, the "new" marvell_nand.c driver is using the ->exec_op() interface
which is the one that must be ported to U-Boot. Many changes have been
brought to the raw NAND core but everything has been carefully patched
to be easily ported (besides the huge number of potential
dependencies that have not been brought to U-Boot already). Bringing-in 
this new interface does not affect the other controller drivers though,
as the ->cmdfunc() and ->cmd_ctrl() interfaces are still functional.

Thanks,
Miquèl


More information about the U-Boot mailing list