Proposal: U-Boot MTD (rewriting old story)

Jagan Teki jagan at amarulasolutions.com
Tue Aug 3 17:00:40 CEST 2021


Yes, this is the old discussion and triggered again now since we had a
discussion on the last U-Boot contributor call.

I will brief the main points here, as most of the details are
mentioned in previous threads.

Here are the couple of old and new implementations on the SPI-NOR side.

http://u-boot.10912.n7.nabble.com/PATCH-v10-00-27-dm-Generic-MTD-Subsystem-with-SPI-NOR-interface-tt315694.html#none
http://u-boot.10912.n7.nabble.com/PATCH-0-5-mtd-Implement-MTD-UCLASS-use-SPINOR-td419538.html#a419541
https://patchwork.ozlabs.org/project/uboot/cover/20200709111709.68904-1-jagan@amarulasolutions.com/

Idea is to
1. Create MTD_UCLASS, already present
2. Create DM MTD Operations, above patchset does.
3. Create Flash specific MTD UClass's like
    UCLASS_NAND
    UCLASS_SPI_NAND
    UCLASS_SPI_NOR
    UCLASS_NOR
    UCLASS_UBI
and register to UCLASS_MTD as interface slaves like how MMC, SCSI are
registered to UCLASS_BLK
4. Sync only respective flash specific code, and drop __UBOOT__
5. Interface mtd, sf, and nand commands to UCLASS_MTD.

Hard points:
1. Hard to arrange Linux specific code and drop unneeded _UBOOT_ code,
but possible.
2. Requires a lot of testing.

Any inputs?
Jagan.


More information about the U-Boot mailing list