mirror of
https://github.com/AsahiLinux/u-boot
synced 2025-02-26 04:17:09 +00:00
mtd: move NAND files into a raw/ subdirectory
NAND flavors, like serial and parallel, have a lot in common and would benefit to share code. Let's move raw (parallel) NAND specific code in a raw/ subdirectory, to ease the addition of a core file in nand/ and the introduction of a spi/ subdirectory specific to SPI NANDs. Signed-off-by: Miquel Raynal <miquel.raynal@bootlin.com>
This commit is contained in:
parent
ce9bdc8743
commit
a430fa06a4
66 changed files with 400 additions and 395 deletions
|
@ -298,7 +298,7 @@ F: drivers/i2c/i2c-cdns.c
|
||||||
F: drivers/i2c/muxes/pca954x.c
|
F: drivers/i2c/muxes/pca954x.c
|
||||||
F: drivers/i2c/zynq_i2c.c
|
F: drivers/i2c/zynq_i2c.c
|
||||||
F: drivers/mmc/zynq_sdhci.c
|
F: drivers/mmc/zynq_sdhci.c
|
||||||
F: drivers/mtd/nand/zynq_nand.c
|
F: drivers/mtd/nand/raw/zynq_nand.c
|
||||||
F: drivers/net/phy/xilinx_phy.c
|
F: drivers/net/phy/xilinx_phy.c
|
||||||
F: drivers/net/zynq_gem.c
|
F: drivers/net/zynq_gem.c
|
||||||
F: drivers/serial/serial_zynq.c
|
F: drivers/serial/serial_zynq.c
|
||||||
|
@ -322,7 +322,7 @@ F: drivers/i2c/i2c-cdns.c
|
||||||
F: drivers/i2c/muxes/pca954x.c
|
F: drivers/i2c/muxes/pca954x.c
|
||||||
F: drivers/i2c/zynq_i2c.c
|
F: drivers/i2c/zynq_i2c.c
|
||||||
F: drivers/mmc/zynq_sdhci.c
|
F: drivers/mmc/zynq_sdhci.c
|
||||||
F: drivers/mtd/nand/zynq_nand.c
|
F: drivers/mtd/nand/raw/zynq_nand.c
|
||||||
F: drivers/net/phy/xilinx_phy.c
|
F: drivers/net/phy/xilinx_phy.c
|
||||||
F: drivers/net/zynq_gem.c
|
F: drivers/net/zynq_gem.c
|
||||||
F: drivers/serial/serial_zynq.c
|
F: drivers/serial/serial_zynq.c
|
||||||
|
@ -467,7 +467,7 @@ NAND FLASH
|
||||||
#M: Scott Wood <oss@buserror.net>
|
#M: Scott Wood <oss@buserror.net>
|
||||||
S: Orphaned (Since 2018-07)
|
S: Orphaned (Since 2018-07)
|
||||||
T: git git://git.denx.de/u-boot-nand-flash.git
|
T: git git://git.denx.de/u-boot-nand-flash.git
|
||||||
F: drivers/mtd/nand/
|
F: drivers/mtd/nand/raw/
|
||||||
|
|
||||||
NDS32
|
NDS32
|
||||||
M: Macpaul Lin <macpaul@andestech.com>
|
M: Macpaul Lin <macpaul@andestech.com>
|
||||||
|
|
2
Makefile
2
Makefile
|
@ -689,7 +689,7 @@ libs-y += drivers/dma/
|
||||||
libs-y += drivers/gpio/
|
libs-y += drivers/gpio/
|
||||||
libs-y += drivers/i2c/
|
libs-y += drivers/i2c/
|
||||||
libs-y += drivers/mtd/
|
libs-y += drivers/mtd/
|
||||||
libs-$(CONFIG_CMD_NAND) += drivers/mtd/nand/
|
libs-$(CONFIG_CMD_NAND) += drivers/mtd/nand/raw/
|
||||||
libs-y += drivers/mtd/onenand/
|
libs-y += drivers/mtd/onenand/
|
||||||
libs-$(CONFIG_CMD_UBI) += drivers/mtd/ubi/
|
libs-$(CONFIG_CMD_UBI) += drivers/mtd/ubi/
|
||||||
libs-y += drivers/mtd/spi/
|
libs-y += drivers/mtd/spi/
|
||||||
|
|
6
README
6
README
|
@ -3256,8 +3256,8 @@ Low Level (hardware related) configuration options:
|
||||||
a 16 bit bus.
|
a 16 bit bus.
|
||||||
Not all NAND drivers use this symbol.
|
Not all NAND drivers use this symbol.
|
||||||
Example of drivers that use it:
|
Example of drivers that use it:
|
||||||
- drivers/mtd/nand/ndfc.c
|
- drivers/mtd/nand/raw/ndfc.c
|
||||||
- drivers/mtd/nand/mxc_nand.c
|
- drivers/mtd/nand/raw/mxc_nand.c
|
||||||
|
|
||||||
- CONFIG_SYS_NDFC_EBC0_CFG
|
- CONFIG_SYS_NDFC_EBC0_CFG
|
||||||
Sets the EBC0_CFG register for the NDFC. If not defined
|
Sets the EBC0_CFG register for the NDFC. If not defined
|
||||||
|
@ -3374,7 +3374,7 @@ Low Level (hardware related) configuration options:
|
||||||
- CONFIG_SYS_NAND_NO_SUBPAGE_WRITE
|
- CONFIG_SYS_NAND_NO_SUBPAGE_WRITE
|
||||||
Option to disable subpage write in NAND driver
|
Option to disable subpage write in NAND driver
|
||||||
driver that uses this:
|
driver that uses this:
|
||||||
drivers/mtd/nand/davinci_nand.c
|
drivers/mtd/nand/raw/davinci_nand.c
|
||||||
|
|
||||||
Freescale QE/FMAN Firmware Support:
|
Freescale QE/FMAN Firmware Support:
|
||||||
-----------------------------------
|
-----------------------------------
|
||||||
|
|
|
@ -12,7 +12,7 @@
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
#include <linux/io.h>
|
#include <linux/io.h>
|
||||||
#include <linux/printk.h>
|
#include <linux/printk.h>
|
||||||
#include <../drivers/mtd/nand/denali.h>
|
#include <../drivers/mtd/nand/raw/denali.h>
|
||||||
|
|
||||||
#include "init.h"
|
#include "init.h"
|
||||||
|
|
||||||
|
|
|
@ -487,7 +487,7 @@ config SPL_NAND_SUPPORT
|
||||||
help
|
help
|
||||||
Enable support for NAND (Negative AND) flash in SPL. NAND flash
|
Enable support for NAND (Negative AND) flash in SPL. NAND flash
|
||||||
can be used to allow SPL to load U-Boot from supported devices.
|
can be used to allow SPL to load U-Boot from supported devices.
|
||||||
This enables the drivers in drivers/mtd/nand as part of an SPL
|
This enables the drivers in drivers/mtd/nand/raw as part of an SPL
|
||||||
build.
|
build.
|
||||||
|
|
||||||
config SPL_NET_SUPPORT
|
config SPL_NET_SUPPORT
|
||||||
|
|
|
@ -2,7 +2,7 @@
|
||||||
/*
|
/*
|
||||||
* Copyright (C) 2011 OMICRON electronics GmbH
|
* Copyright (C) 2011 OMICRON electronics GmbH
|
||||||
*
|
*
|
||||||
* based on drivers/mtd/nand/nand_spl_load.c
|
* based on drivers/mtd/nand/raw/nand_spl_load.c
|
||||||
*
|
*
|
||||||
* Copyright (C) 2011
|
* Copyright (C) 2011
|
||||||
* Heiko Schocher, DENX Software Engineering, hs@denx.de.
|
* Heiko Schocher, DENX Software Engineering, hs@denx.de.
|
||||||
|
|
|
@ -57,11 +57,11 @@ CONFIG_SPL_FAT_SUPPORT (fs/fat/libfat.o)
|
||||||
CONFIG_SPL_EXT_SUPPORT
|
CONFIG_SPL_EXT_SUPPORT
|
||||||
CONFIG_SPL_LIBGENERIC_SUPPORT (lib/libgeneric.o)
|
CONFIG_SPL_LIBGENERIC_SUPPORT (lib/libgeneric.o)
|
||||||
CONFIG_SPL_POWER_SUPPORT (drivers/power/libpower.o)
|
CONFIG_SPL_POWER_SUPPORT (drivers/power/libpower.o)
|
||||||
CONFIG_SPL_NAND_SUPPORT (drivers/mtd/nand/libnand.o)
|
CONFIG_SPL_NAND_SUPPORT (drivers/mtd/nand/raw/libnand.o)
|
||||||
CONFIG_SPL_DRIVERS_MISC_SUPPORT (drivers/misc)
|
CONFIG_SPL_DRIVERS_MISC_SUPPORT (drivers/misc)
|
||||||
CONFIG_SPL_DMA_SUPPORT (drivers/dma/libdma.o)
|
CONFIG_SPL_DMA_SUPPORT (drivers/dma/libdma.o)
|
||||||
CONFIG_SPL_POST_MEM_SUPPORT (post/drivers/memory.o)
|
CONFIG_SPL_POST_MEM_SUPPORT (post/drivers/memory.o)
|
||||||
CONFIG_SPL_NAND_LOAD (drivers/mtd/nand/nand_spl_load.o)
|
CONFIG_SPL_NAND_LOAD (drivers/mtd/nand/raw/nand_spl_load.o)
|
||||||
CONFIG_SPL_SPI_LOAD (drivers/mtd/spi/spi_spl_load.o)
|
CONFIG_SPL_SPI_LOAD (drivers/mtd/spi/spi_spl_load.o)
|
||||||
CONFIG_SPL_RAM_DEVICE (common/spl/spl.c)
|
CONFIG_SPL_RAM_DEVICE (common/spl/spl.c)
|
||||||
CONFIG_SPL_WATCHDOG_SUPPORT (drivers/watchdog/libwatchdog.o)
|
CONFIG_SPL_WATCHDOG_SUPPORT (drivers/watchdog/libwatchdog.o)
|
||||||
|
|
|
@ -84,7 +84,7 @@ Relocation with SPL (example for the tx25 booting from NAND Flash):
|
||||||
- cpu copies the first page from NAND to 0xbb000000 (IMX_NFC_BASE)
|
- cpu copies the first page from NAND to 0xbb000000 (IMX_NFC_BASE)
|
||||||
and start with code execution on this address.
|
and start with code execution on this address.
|
||||||
|
|
||||||
- The First page contains u-boot code from drivers/mtd/nand/mxc_nand_spl.c
|
- The First page contains u-boot code from drivers/mtd/nand/raw/mxc_nand_spl.c
|
||||||
which inits the dram, cpu registers, reloacte itself to CONFIG_SPL_TEXT_BASE and loads
|
which inits the dram, cpu registers, reloacte itself to CONFIG_SPL_TEXT_BASE and loads
|
||||||
the "real" u-boot to CONFIG_SYS_NAND_U_BOOT_DST and starts execution
|
the "real" u-boot to CONFIG_SYS_NAND_U_BOOT_DST and starts execution
|
||||||
@CONFIG_SYS_NAND_U_BOOT_START
|
@CONFIG_SYS_NAND_U_BOOT_START
|
||||||
|
|
|
@ -116,7 +116,7 @@ Configuration Options:
|
||||||
The maximum number of NAND chips per device to be supported.
|
The maximum number of NAND chips per device to be supported.
|
||||||
|
|
||||||
CONFIG_SYS_NAND_SELF_INIT
|
CONFIG_SYS_NAND_SELF_INIT
|
||||||
Traditionally, glue code in drivers/mtd/nand/nand.c has driven
|
Traditionally, glue code in drivers/mtd/nand/raw/nand.c has driven
|
||||||
the initialization process -- it provides the mtd and nand
|
the initialization process -- it provides the mtd and nand
|
||||||
structs, calls a board init function for a specific device,
|
structs, calls a board init function for a specific device,
|
||||||
calls nand_scan(), and registers with mtd.
|
calls nand_scan(), and registers with mtd.
|
||||||
|
@ -125,7 +125,7 @@ Configuration Options:
|
||||||
run code between nand_scan_ident() and nand_scan_tail(), or other
|
run code between nand_scan_ident() and nand_scan_tail(), or other
|
||||||
deviations from the "normal" flow.
|
deviations from the "normal" flow.
|
||||||
|
|
||||||
If a board defines CONFIG_SYS_NAND_SELF_INIT, drivers/mtd/nand/nand.c
|
If a board defines CONFIG_SYS_NAND_SELF_INIT, drivers/mtd/nand/raw/nand.c
|
||||||
will make one call to board_nand_init(), with no arguments. That
|
will make one call to board_nand_init(), with no arguments. That
|
||||||
function is responsible for calling a driver init function for
|
function is responsible for calling a driver init function for
|
||||||
each NAND device on the board, that performs all initialization
|
each NAND device on the board, that performs all initialization
|
||||||
|
@ -280,7 +280,7 @@ NOTE:
|
||||||
=====
|
=====
|
||||||
|
|
||||||
The Disk On Chip driver is currently broken and has been for some time.
|
The Disk On Chip driver is currently broken and has been for some time.
|
||||||
There is a driver in drivers/mtd/nand, taken from Linux, that works with
|
There is a driver in drivers/mtd/nand/raw, taken from Linux, that works with
|
||||||
the current NAND system but has not yet been adapted to the u-boot
|
the current NAND system but has not yet been adapted to the u-boot
|
||||||
environment.
|
environment.
|
||||||
|
|
||||||
|
|
|
@ -63,7 +63,7 @@ bootmode strings at runtime.
|
||||||
spi - drivers/spi/zynq_spi.c
|
spi - drivers/spi/zynq_spi.c
|
||||||
qspi - drivers/spi/zynq_qspi.c
|
qspi - drivers/spi/zynq_qspi.c
|
||||||
i2c - drivers/i2c/zynq_i2c.c
|
i2c - drivers/i2c/zynq_i2c.c
|
||||||
nand - drivers/mtd/nand/zynq_nand.c
|
nand - drivers/mtd/nand/raw/zynq_nand.c
|
||||||
- Done proper cleanups on board configurations
|
- Done proper cleanups on board configurations
|
||||||
- Added basic FDT support for zynq boards
|
- Added basic FDT support for zynq boards
|
||||||
- d-cache support for zynq_gem.c
|
- d-cache support for zynq_gem.c
|
||||||
|
|
|
@ -6,7 +6,7 @@ obj-$(CONFIG_$(SPL_TPL_)DRIVERS_MISC_SUPPORT) += misc/ sysreset/ firmware/
|
||||||
obj-$(CONFIG_$(SPL_TPL_)I2C_SUPPORT) += i2c/
|
obj-$(CONFIG_$(SPL_TPL_)I2C_SUPPORT) += i2c/
|
||||||
obj-$(CONFIG_$(SPL_TPL_)LED) += led/
|
obj-$(CONFIG_$(SPL_TPL_)LED) += led/
|
||||||
obj-$(CONFIG_$(SPL_TPL_)MMC_SUPPORT) += mmc/
|
obj-$(CONFIG_$(SPL_TPL_)MMC_SUPPORT) += mmc/
|
||||||
obj-$(CONFIG_$(SPL_TPL_)NAND_SUPPORT) += mtd/nand/
|
obj-$(CONFIG_$(SPL_TPL_)NAND_SUPPORT) += mtd/nand/raw/
|
||||||
obj-$(CONFIG_$(SPL_TPL_)PHY) += phy/
|
obj-$(CONFIG_$(SPL_TPL_)PHY) += phy/
|
||||||
obj-$(CONFIG_$(SPL_TPL_)PINCTRL) += pinctrl/
|
obj-$(CONFIG_$(SPL_TPL_)PINCTRL) += pinctrl/
|
||||||
obj-$(CONFIG_$(SPL_TPL_)RAM) += ram/
|
obj-$(CONFIG_$(SPL_TPL_)RAM) += ram/
|
||||||
|
|
|
@ -18,3 +18,5 @@ obj-$(CONFIG_FLASH_PIC32) += pic32_flash.o
|
||||||
obj-$(CONFIG_ST_SMI) += st_smi.o
|
obj-$(CONFIG_ST_SMI) += st_smi.o
|
||||||
obj-$(CONFIG_STM32_FLASH) += stm32_flash.o
|
obj-$(CONFIG_STM32_FLASH) += stm32_flash.o
|
||||||
obj-$(CONFIG_RENESAS_RPC_HF) += renesas_rpc_hf.o
|
obj-$(CONFIG_RENESAS_RPC_HF) += renesas_rpc_hf.o
|
||||||
|
|
||||||
|
obj-y += nand/
|
||||||
|
|
|
@ -1,297 +1 @@
|
||||||
|
source "drivers/mtd/nand/raw/Kconfig"
|
||||||
menuconfig NAND
|
|
||||||
bool "NAND Device Support"
|
|
||||||
if NAND
|
|
||||||
|
|
||||||
config SYS_NAND_SELF_INIT
|
|
||||||
bool
|
|
||||||
help
|
|
||||||
This option, if enabled, provides more flexible and linux-like
|
|
||||||
NAND initialization process.
|
|
||||||
|
|
||||||
config NAND_ATMEL
|
|
||||||
bool "Support Atmel NAND controller"
|
|
||||||
imply SYS_NAND_USE_FLASH_BBT
|
|
||||||
help
|
|
||||||
Enable this driver for NAND flash platforms using an Atmel NAND
|
|
||||||
controller.
|
|
||||||
|
|
||||||
config NAND_DAVINCI
|
|
||||||
bool "Support TI Davinci NAND controller"
|
|
||||||
help
|
|
||||||
Enable this driver for NAND flash controllers available in TI Davinci
|
|
||||||
and Keystone2 platforms
|
|
||||||
|
|
||||||
config NAND_DENALI
|
|
||||||
bool
|
|
||||||
select SYS_NAND_SELF_INIT
|
|
||||||
imply CMD_NAND
|
|
||||||
|
|
||||||
config NAND_DENALI_DT
|
|
||||||
bool "Support Denali NAND controller as a DT device"
|
|
||||||
select NAND_DENALI
|
|
||||||
depends on OF_CONTROL && DM
|
|
||||||
help
|
|
||||||
Enable the driver for NAND flash on platforms using a Denali NAND
|
|
||||||
controller as a DT device.
|
|
||||||
|
|
||||||
config NAND_DENALI_SPARE_AREA_SKIP_BYTES
|
|
||||||
int "Number of bytes skipped in OOB area"
|
|
||||||
depends on NAND_DENALI
|
|
||||||
range 0 63
|
|
||||||
help
|
|
||||||
This option specifies the number of bytes to skip from the beginning
|
|
||||||
of OOB area before last ECC sector data starts. This is potentially
|
|
||||||
used to preserve the bad block marker in the OOB area.
|
|
||||||
|
|
||||||
config NAND_LPC32XX_SLC
|
|
||||||
bool "Support LPC32XX_SLC controller"
|
|
||||||
help
|
|
||||||
Enable the LPC32XX SLC NAND controller.
|
|
||||||
|
|
||||||
config NAND_OMAP_GPMC
|
|
||||||
bool "Support OMAP GPMC NAND controller"
|
|
||||||
depends on ARCH_OMAP2PLUS
|
|
||||||
help
|
|
||||||
Enables omap_gpmc.c driver for OMAPx and AMxxxx platforms.
|
|
||||||
GPMC controller is used for parallel NAND flash devices, and can
|
|
||||||
do ECC calculation (not ECC error detection) for HAM1, BCH4, BCH8
|
|
||||||
and BCH16 ECC algorithms.
|
|
||||||
|
|
||||||
config NAND_OMAP_GPMC_PREFETCH
|
|
||||||
bool "Enable GPMC Prefetch"
|
|
||||||
depends on NAND_OMAP_GPMC
|
|
||||||
default y
|
|
||||||
help
|
|
||||||
On OMAP platforms that use the GPMC controller
|
|
||||||
(CONFIG_NAND_OMAP_GPMC_PREFETCH), this options enables the code that
|
|
||||||
uses the prefetch mode to speed up read operations.
|
|
||||||
|
|
||||||
config NAND_OMAP_ELM
|
|
||||||
bool "Enable ELM driver for OMAPxx and AMxx platforms."
|
|
||||||
depends on NAND_OMAP_GPMC && !OMAP34XX
|
|
||||||
help
|
|
||||||
ELM controller is used for ECC error detection (not ECC calculation)
|
|
||||||
of BCH4, BCH8 and BCH16 ECC algorithms.
|
|
||||||
Some legacy platforms like OMAP3xx do not have in-built ELM h/w engine,
|
|
||||||
thus such SoC platforms need to depend on software library for ECC error
|
|
||||||
detection. However ECC calculation on such plaforms would still be
|
|
||||||
done by GPMC controller.
|
|
||||||
|
|
||||||
config NAND_VF610_NFC
|
|
||||||
bool "Support for Freescale NFC for VF610"
|
|
||||||
select SYS_NAND_SELF_INIT
|
|
||||||
imply CMD_NAND
|
|
||||||
help
|
|
||||||
Enables support for NAND Flash Controller on some Freescale
|
|
||||||
processors like the VF610, MCF54418 or Kinetis K70.
|
|
||||||
The driver supports a maximum 2k page size. The driver
|
|
||||||
currently does not support hardware ECC.
|
|
||||||
|
|
||||||
choice
|
|
||||||
prompt "Hardware ECC strength"
|
|
||||||
depends on NAND_VF610_NFC
|
|
||||||
default SYS_NAND_VF610_NFC_45_ECC_BYTES
|
|
||||||
help
|
|
||||||
Select the ECC strength used in the hardware BCH ECC block.
|
|
||||||
|
|
||||||
config SYS_NAND_VF610_NFC_45_ECC_BYTES
|
|
||||||
bool "24-error correction (45 ECC bytes)"
|
|
||||||
|
|
||||||
config SYS_NAND_VF610_NFC_60_ECC_BYTES
|
|
||||||
bool "32-error correction (60 ECC bytes)"
|
|
||||||
|
|
||||||
endchoice
|
|
||||||
|
|
||||||
config NAND_PXA3XX
|
|
||||||
bool "Support for NAND on PXA3xx and Armada 370/XP/38x"
|
|
||||||
select SYS_NAND_SELF_INIT
|
|
||||||
imply CMD_NAND
|
|
||||||
help
|
|
||||||
This enables the driver for the NAND flash device found on
|
|
||||||
PXA3xx processors (NFCv1) and also on Armada 370/XP (NFCv2).
|
|
||||||
|
|
||||||
config NAND_SUNXI
|
|
||||||
bool "Support for NAND on Allwinner SoCs"
|
|
||||||
default ARCH_SUNXI
|
|
||||||
depends on MACH_SUN4I || MACH_SUN5I || MACH_SUN7I || MACH_SUN8I
|
|
||||||
select SYS_NAND_SELF_INIT
|
|
||||||
select SYS_NAND_U_BOOT_LOCATIONS
|
|
||||||
select SPL_NAND_SUPPORT
|
|
||||||
imply CMD_NAND
|
|
||||||
---help---
|
|
||||||
Enable support for NAND. This option enables the standard and
|
|
||||||
SPL drivers.
|
|
||||||
The SPL driver only supports reading from the NAND using DMA
|
|
||||||
transfers.
|
|
||||||
|
|
||||||
if NAND_SUNXI
|
|
||||||
|
|
||||||
config NAND_SUNXI_SPL_ECC_STRENGTH
|
|
||||||
int "Allwinner NAND SPL ECC Strength"
|
|
||||||
default 64
|
|
||||||
|
|
||||||
config NAND_SUNXI_SPL_ECC_SIZE
|
|
||||||
int "Allwinner NAND SPL ECC Step Size"
|
|
||||||
default 1024
|
|
||||||
|
|
||||||
config NAND_SUNXI_SPL_USABLE_PAGE_SIZE
|
|
||||||
int "Allwinner NAND SPL Usable Page Size"
|
|
||||||
default 1024
|
|
||||||
|
|
||||||
endif
|
|
||||||
|
|
||||||
config NAND_ARASAN
|
|
||||||
bool "Configure Arasan Nand"
|
|
||||||
select SYS_NAND_SELF_INIT
|
|
||||||
imply CMD_NAND
|
|
||||||
help
|
|
||||||
This enables Nand driver support for Arasan nand flash
|
|
||||||
controller. This uses the hardware ECC for read and
|
|
||||||
write operations.
|
|
||||||
|
|
||||||
config NAND_MXC
|
|
||||||
bool "MXC NAND support"
|
|
||||||
depends on CPU_ARM926EJS || CPU_ARM1136 || MX5
|
|
||||||
imply CMD_NAND
|
|
||||||
help
|
|
||||||
This enables the NAND driver for the NAND flash controller on the
|
|
||||||
i.MX27 / i.MX31 / i.MX5 rocessors.
|
|
||||||
|
|
||||||
config NAND_MXS
|
|
||||||
bool "MXS NAND support"
|
|
||||||
depends on MX23 || MX28 || MX6 || MX7
|
|
||||||
select SYS_NAND_SELF_INIT
|
|
||||||
imply CMD_NAND
|
|
||||||
select APBH_DMA
|
|
||||||
select APBH_DMA_BURST if ARCH_MX6 || ARCH_MX7
|
|
||||||
select APBH_DMA_BURST8 if ARCH_MX6 || ARCH_MX7
|
|
||||||
help
|
|
||||||
This enables NAND driver for the NAND flash controller on the
|
|
||||||
MXS processors.
|
|
||||||
|
|
||||||
if NAND_MXS
|
|
||||||
|
|
||||||
config NAND_MXS_DT
|
|
||||||
bool "Support MXS NAND controller as a DT device"
|
|
||||||
depends on OF_CONTROL && MTD
|
|
||||||
help
|
|
||||||
Enable the driver for MXS NAND flash on platforms using
|
|
||||||
device tree.
|
|
||||||
|
|
||||||
config NAND_MXS_USE_MINIMUM_ECC
|
|
||||||
bool "Use minimum ECC strength supported by the controller"
|
|
||||||
default false
|
|
||||||
|
|
||||||
endif
|
|
||||||
|
|
||||||
config NAND_ZYNQ
|
|
||||||
bool "Support for Zynq Nand controller"
|
|
||||||
select SYS_NAND_SELF_INIT
|
|
||||||
imply CMD_NAND
|
|
||||||
help
|
|
||||||
This enables Nand driver support for Nand flash controller
|
|
||||||
found on Zynq SoC.
|
|
||||||
|
|
||||||
config NAND_ZYNQ_USE_BOOTLOADER1_TIMINGS
|
|
||||||
bool "Enable use of 1st stage bootloader timing for NAND"
|
|
||||||
depends on NAND_ZYNQ
|
|
||||||
help
|
|
||||||
This flag prevent U-boot reconfigure NAND flash controller and reuse
|
|
||||||
the NAND timing from 1st stage bootloader.
|
|
||||||
|
|
||||||
comment "Generic NAND options"
|
|
||||||
|
|
||||||
config SYS_NAND_BLOCK_SIZE
|
|
||||||
hex "NAND chip eraseblock size"
|
|
||||||
depends on ARCH_SUNXI
|
|
||||||
help
|
|
||||||
Number of data bytes in one eraseblock for the NAND chip on the
|
|
||||||
board. This is the multiple of NAND_PAGE_SIZE and the number of
|
|
||||||
pages.
|
|
||||||
|
|
||||||
config SYS_NAND_PAGE_SIZE
|
|
||||||
hex "NAND chip page size"
|
|
||||||
depends on ARCH_SUNXI
|
|
||||||
help
|
|
||||||
Number of data bytes in one page for the NAND chip on the
|
|
||||||
board, not including the OOB area.
|
|
||||||
|
|
||||||
config SYS_NAND_OOBSIZE
|
|
||||||
hex "NAND chip OOB size"
|
|
||||||
depends on ARCH_SUNXI
|
|
||||||
help
|
|
||||||
Number of bytes in the Out-Of-Band area for the NAND chip on
|
|
||||||
the board.
|
|
||||||
|
|
||||||
# Enhance depends when converting drivers to Kconfig which use this config
|
|
||||||
# option (mxc_nand, ndfc, omap_gpmc).
|
|
||||||
config SYS_NAND_BUSWIDTH_16BIT
|
|
||||||
bool "Use 16-bit NAND interface"
|
|
||||||
depends on NAND_VF610_NFC || NAND_OMAP_GPMC || NAND_MXC || ARCH_DAVINCI
|
|
||||||
help
|
|
||||||
Indicates that NAND device has 16-bit wide data-bus. In absence of this
|
|
||||||
config, bus-width of NAND device is assumed to be either 8-bit and later
|
|
||||||
determined by reading ONFI params.
|
|
||||||
Above config is useful when NAND device's bus-width information cannot
|
|
||||||
be determined from on-chip ONFI params, like in following scenarios:
|
|
||||||
- SPL boot does not support reading of ONFI parameters. This is done to
|
|
||||||
keep SPL code foot-print small.
|
|
||||||
- In current U-Boot flow using nand_init(), driver initialization
|
|
||||||
happens in board_nand_init() which is called before any device probe
|
|
||||||
(nand_scan_ident + nand_scan_tail), thus device's ONFI parameters are
|
|
||||||
not available while configuring controller. So a static CONFIG_NAND_xx
|
|
||||||
is needed to know the device's bus-width in advance.
|
|
||||||
|
|
||||||
if SPL
|
|
||||||
|
|
||||||
config SYS_NAND_U_BOOT_LOCATIONS
|
|
||||||
bool "Define U-boot binaries locations in NAND"
|
|
||||||
help
|
|
||||||
Enable CONFIG_SYS_NAND_U_BOOT_OFFS though Kconfig.
|
|
||||||
This option should not be enabled when compiling U-boot for boards
|
|
||||||
defining CONFIG_SYS_NAND_U_BOOT_OFFS in their include/configs/<board>.h
|
|
||||||
file.
|
|
||||||
|
|
||||||
config SYS_NAND_U_BOOT_OFFS
|
|
||||||
hex "Location in NAND to read U-Boot from"
|
|
||||||
default 0x800000 if NAND_SUNXI
|
|
||||||
depends on SYS_NAND_U_BOOT_LOCATIONS
|
|
||||||
help
|
|
||||||
Set the offset from the start of the nand where u-boot should be
|
|
||||||
loaded from.
|
|
||||||
|
|
||||||
config SYS_NAND_U_BOOT_OFFS_REDUND
|
|
||||||
hex "Location in NAND to read U-Boot from"
|
|
||||||
default SYS_NAND_U_BOOT_OFFS
|
|
||||||
depends on SYS_NAND_U_BOOT_LOCATIONS
|
|
||||||
help
|
|
||||||
Set the offset from the start of the nand where the redundant u-boot
|
|
||||||
should be loaded from.
|
|
||||||
|
|
||||||
config SPL_NAND_AM33XX_BCH
|
|
||||||
bool "Enables SPL-NAND driver which supports ELM based"
|
|
||||||
depends on NAND_OMAP_GPMC && !OMAP34XX
|
|
||||||
default y
|
|
||||||
help
|
|
||||||
Hardware ECC correction. This is useful for platforms which have ELM
|
|
||||||
hardware engine and use NAND boot mode.
|
|
||||||
Some legacy platforms like OMAP3xx do not have in-built ELM h/w engine,
|
|
||||||
so those platforms should use CONFIG_SPL_NAND_SIMPLE for enabling
|
|
||||||
SPL-NAND driver with software ECC correction support.
|
|
||||||
|
|
||||||
config SPL_NAND_DENALI
|
|
||||||
bool "Support Denali NAND controller for SPL"
|
|
||||||
help
|
|
||||||
This is a small implementation of the Denali NAND controller
|
|
||||||
for use on SPL.
|
|
||||||
|
|
||||||
config SPL_NAND_SIMPLE
|
|
||||||
bool "Use simple SPL NAND driver"
|
|
||||||
depends on !SPL_NAND_AM33XX_BCH
|
|
||||||
help
|
|
||||||
Support for NAND boot using simple NAND drivers that
|
|
||||||
expose the cmd_ctrl() interface.
|
|
||||||
endif
|
|
||||||
|
|
||||||
endif # if NAND
|
|
||||||
|
|
|
@ -1,77 +1,2 @@
|
||||||
# SPDX-License-Identifier: GPL-2.0+
|
# SPDX-License-Identifier: GPL-2.0+
|
||||||
#
|
|
||||||
# (C) Copyright 2006
|
|
||||||
# Wolfgang Denk, DENX Software Engineering, wd@denx.de.
|
|
||||||
|
|
||||||
ifdef CONFIG_SPL_BUILD
|
|
||||||
|
|
||||||
ifdef CONFIG_SPL_NAND_DRIVERS
|
|
||||||
NORMAL_DRIVERS=y
|
|
||||||
endif
|
|
||||||
|
|
||||||
obj-$(CONFIG_SPL_NAND_AM33XX_BCH) += am335x_spl_bch.o
|
|
||||||
obj-$(CONFIG_SPL_NAND_DENALI) += denali_spl.o
|
|
||||||
obj-$(CONFIG_SPL_NAND_SIMPLE) += nand_spl_simple.o
|
|
||||||
obj-$(CONFIG_SPL_NAND_LOAD) += nand_spl_load.o
|
|
||||||
obj-$(CONFIG_SPL_NAND_ECC) += nand_ecc.o
|
|
||||||
obj-$(CONFIG_SPL_NAND_BASE) += nand_base.o
|
|
||||||
obj-$(CONFIG_SPL_NAND_IDENT) += nand_ids.o nand_timings.o
|
|
||||||
obj-$(CONFIG_SPL_NAND_INIT) += nand.o
|
|
||||||
ifeq ($(CONFIG_SPL_ENV_SUPPORT),y)
|
|
||||||
obj-$(CONFIG_ENV_IS_IN_NAND) += nand_util.o
|
|
||||||
endif
|
|
||||||
|
|
||||||
else # not spl
|
|
||||||
|
|
||||||
NORMAL_DRIVERS=y
|
|
||||||
|
|
||||||
obj-y += nand.o
|
|
||||||
obj-y += nand_bbt.o
|
|
||||||
obj-y += nand_ids.o
|
|
||||||
obj-y += nand_util.o
|
|
||||||
obj-y += nand_ecc.o
|
|
||||||
obj-y += nand_base.o
|
|
||||||
obj-y += nand_timings.o
|
|
||||||
|
|
||||||
endif # not spl
|
|
||||||
|
|
||||||
ifdef NORMAL_DRIVERS
|
|
||||||
|
|
||||||
obj-$(CONFIG_NAND_ECC_BCH) += nand_bch.o
|
|
||||||
|
|
||||||
obj-$(CONFIG_NAND_ATMEL) += atmel_nand.o
|
|
||||||
obj-$(CONFIG_NAND_ARASAN) += arasan_nfc.o
|
|
||||||
obj-$(CONFIG_NAND_DAVINCI) += davinci_nand.o
|
|
||||||
obj-$(CONFIG_NAND_DENALI) += denali.o
|
|
||||||
obj-$(CONFIG_NAND_DENALI_DT) += denali_dt.o
|
|
||||||
obj-$(CONFIG_NAND_FSL_ELBC) += fsl_elbc_nand.o
|
|
||||||
obj-$(CONFIG_NAND_FSL_IFC) += fsl_ifc_nand.o
|
|
||||||
obj-$(CONFIG_NAND_FSL_UPM) += fsl_upm.o
|
|
||||||
obj-$(CONFIG_NAND_FSMC) += fsmc_nand.o
|
|
||||||
obj-$(CONFIG_NAND_KB9202) += kb9202_nand.o
|
|
||||||
obj-$(CONFIG_NAND_KIRKWOOD) += kirkwood_nand.o
|
|
||||||
obj-$(CONFIG_NAND_KMETER1) += kmeter1_nand.o
|
|
||||||
obj-$(CONFIG_NAND_LPC32XX_MLC) += lpc32xx_nand_mlc.o
|
|
||||||
obj-$(CONFIG_NAND_LPC32XX_SLC) += lpc32xx_nand_slc.o
|
|
||||||
obj-$(CONFIG_NAND_VF610_NFC) += vf610_nfc.o
|
|
||||||
obj-$(CONFIG_NAND_MXC) += mxc_nand.o
|
|
||||||
obj-$(CONFIG_NAND_MXS) += mxs_nand.o
|
|
||||||
obj-$(CONFIG_NAND_MXS_DT) += mxs_nand_dt.o
|
|
||||||
obj-$(CONFIG_NAND_PXA3XX) += pxa3xx_nand.o
|
|
||||||
obj-$(CONFIG_NAND_SPEAR) += spr_nand.o
|
|
||||||
obj-$(CONFIG_TEGRA_NAND) += tegra_nand.o
|
|
||||||
obj-$(CONFIG_NAND_OMAP_GPMC) += omap_gpmc.o
|
|
||||||
obj-$(CONFIG_NAND_OMAP_ELM) += omap_elm.o
|
|
||||||
obj-$(CONFIG_NAND_PLAT) += nand_plat.o
|
|
||||||
obj-$(CONFIG_NAND_SUNXI) += sunxi_nand.o
|
|
||||||
obj-$(CONFIG_NAND_ZYNQ) += zynq_nand.o
|
|
||||||
|
|
||||||
else # minimal SPL drivers
|
|
||||||
|
|
||||||
obj-$(CONFIG_NAND_FSL_ELBC) += fsl_elbc_spl.o
|
|
||||||
obj-$(CONFIG_NAND_FSL_IFC) += fsl_ifc_spl.o
|
|
||||||
obj-$(CONFIG_NAND_MXC) += mxc_nand_spl.o
|
|
||||||
obj-$(CONFIG_NAND_MXS) += mxs_nand_spl.o mxs_nand.o
|
|
||||||
obj-$(CONFIG_NAND_SUNXI) += sunxi_nand_spl.o
|
|
||||||
|
|
||||||
endif # drivers
|
|
||||||
|
|
297
drivers/mtd/nand/raw/Kconfig
Normal file
297
drivers/mtd/nand/raw/Kconfig
Normal file
|
@ -0,0 +1,297 @@
|
||||||
|
|
||||||
|
menuconfig NAND
|
||||||
|
bool "NAND Device Support"
|
||||||
|
if NAND
|
||||||
|
|
||||||
|
config SYS_NAND_SELF_INIT
|
||||||
|
bool
|
||||||
|
help
|
||||||
|
This option, if enabled, provides more flexible and linux-like
|
||||||
|
NAND initialization process.
|
||||||
|
|
||||||
|
config NAND_ATMEL
|
||||||
|
bool "Support Atmel NAND controller"
|
||||||
|
imply SYS_NAND_USE_FLASH_BBT
|
||||||
|
help
|
||||||
|
Enable this driver for NAND flash platforms using an Atmel NAND
|
||||||
|
controller.
|
||||||
|
|
||||||
|
config NAND_DAVINCI
|
||||||
|
bool "Support TI Davinci NAND controller"
|
||||||
|
help
|
||||||
|
Enable this driver for NAND flash controllers available in TI Davinci
|
||||||
|
and Keystone2 platforms
|
||||||
|
|
||||||
|
config NAND_DENALI
|
||||||
|
bool
|
||||||
|
select SYS_NAND_SELF_INIT
|
||||||
|
imply CMD_NAND
|
||||||
|
|
||||||
|
config NAND_DENALI_DT
|
||||||
|
bool "Support Denali NAND controller as a DT device"
|
||||||
|
select NAND_DENALI
|
||||||
|
depends on OF_CONTROL && DM
|
||||||
|
help
|
||||||
|
Enable the driver for NAND flash on platforms using a Denali NAND
|
||||||
|
controller as a DT device.
|
||||||
|
|
||||||
|
config NAND_DENALI_SPARE_AREA_SKIP_BYTES
|
||||||
|
int "Number of bytes skipped in OOB area"
|
||||||
|
depends on NAND_DENALI
|
||||||
|
range 0 63
|
||||||
|
help
|
||||||
|
This option specifies the number of bytes to skip from the beginning
|
||||||
|
of OOB area before last ECC sector data starts. This is potentially
|
||||||
|
used to preserve the bad block marker in the OOB area.
|
||||||
|
|
||||||
|
config NAND_LPC32XX_SLC
|
||||||
|
bool "Support LPC32XX_SLC controller"
|
||||||
|
help
|
||||||
|
Enable the LPC32XX SLC NAND controller.
|
||||||
|
|
||||||
|
config NAND_OMAP_GPMC
|
||||||
|
bool "Support OMAP GPMC NAND controller"
|
||||||
|
depends on ARCH_OMAP2PLUS
|
||||||
|
help
|
||||||
|
Enables omap_gpmc.c driver for OMAPx and AMxxxx platforms.
|
||||||
|
GPMC controller is used for parallel NAND flash devices, and can
|
||||||
|
do ECC calculation (not ECC error detection) for HAM1, BCH4, BCH8
|
||||||
|
and BCH16 ECC algorithms.
|
||||||
|
|
||||||
|
config NAND_OMAP_GPMC_PREFETCH
|
||||||
|
bool "Enable GPMC Prefetch"
|
||||||
|
depends on NAND_OMAP_GPMC
|
||||||
|
default y
|
||||||
|
help
|
||||||
|
On OMAP platforms that use the GPMC controller
|
||||||
|
(CONFIG_NAND_OMAP_GPMC_PREFETCH), this options enables the code that
|
||||||
|
uses the prefetch mode to speed up read operations.
|
||||||
|
|
||||||
|
config NAND_OMAP_ELM
|
||||||
|
bool "Enable ELM driver for OMAPxx and AMxx platforms."
|
||||||
|
depends on NAND_OMAP_GPMC && !OMAP34XX
|
||||||
|
help
|
||||||
|
ELM controller is used for ECC error detection (not ECC calculation)
|
||||||
|
of BCH4, BCH8 and BCH16 ECC algorithms.
|
||||||
|
Some legacy platforms like OMAP3xx do not have in-built ELM h/w engine,
|
||||||
|
thus such SoC platforms need to depend on software library for ECC error
|
||||||
|
detection. However ECC calculation on such plaforms would still be
|
||||||
|
done by GPMC controller.
|
||||||
|
|
||||||
|
config NAND_VF610_NFC
|
||||||
|
bool "Support for Freescale NFC for VF610"
|
||||||
|
select SYS_NAND_SELF_INIT
|
||||||
|
imply CMD_NAND
|
||||||
|
help
|
||||||
|
Enables support for NAND Flash Controller on some Freescale
|
||||||
|
processors like the VF610, MCF54418 or Kinetis K70.
|
||||||
|
The driver supports a maximum 2k page size. The driver
|
||||||
|
currently does not support hardware ECC.
|
||||||
|
|
||||||
|
choice
|
||||||
|
prompt "Hardware ECC strength"
|
||||||
|
depends on NAND_VF610_NFC
|
||||||
|
default SYS_NAND_VF610_NFC_45_ECC_BYTES
|
||||||
|
help
|
||||||
|
Select the ECC strength used in the hardware BCH ECC block.
|
||||||
|
|
||||||
|
config SYS_NAND_VF610_NFC_45_ECC_BYTES
|
||||||
|
bool "24-error correction (45 ECC bytes)"
|
||||||
|
|
||||||
|
config SYS_NAND_VF610_NFC_60_ECC_BYTES
|
||||||
|
bool "32-error correction (60 ECC bytes)"
|
||||||
|
|
||||||
|
endchoice
|
||||||
|
|
||||||
|
config NAND_PXA3XX
|
||||||
|
bool "Support for NAND on PXA3xx and Armada 370/XP/38x"
|
||||||
|
select SYS_NAND_SELF_INIT
|
||||||
|
imply CMD_NAND
|
||||||
|
help
|
||||||
|
This enables the driver for the NAND flash device found on
|
||||||
|
PXA3xx processors (NFCv1) and also on Armada 370/XP (NFCv2).
|
||||||
|
|
||||||
|
config NAND_SUNXI
|
||||||
|
bool "Support for NAND on Allwinner SoCs"
|
||||||
|
default ARCH_SUNXI
|
||||||
|
depends on MACH_SUN4I || MACH_SUN5I || MACH_SUN7I || MACH_SUN8I
|
||||||
|
select SYS_NAND_SELF_INIT
|
||||||
|
select SYS_NAND_U_BOOT_LOCATIONS
|
||||||
|
select SPL_NAND_SUPPORT
|
||||||
|
imply CMD_NAND
|
||||||
|
---help---
|
||||||
|
Enable support for NAND. This option enables the standard and
|
||||||
|
SPL drivers.
|
||||||
|
The SPL driver only supports reading from the NAND using DMA
|
||||||
|
transfers.
|
||||||
|
|
||||||
|
if NAND_SUNXI
|
||||||
|
|
||||||
|
config NAND_SUNXI_SPL_ECC_STRENGTH
|
||||||
|
int "Allwinner NAND SPL ECC Strength"
|
||||||
|
default 64
|
||||||
|
|
||||||
|
config NAND_SUNXI_SPL_ECC_SIZE
|
||||||
|
int "Allwinner NAND SPL ECC Step Size"
|
||||||
|
default 1024
|
||||||
|
|
||||||
|
config NAND_SUNXI_SPL_USABLE_PAGE_SIZE
|
||||||
|
int "Allwinner NAND SPL Usable Page Size"
|
||||||
|
default 1024
|
||||||
|
|
||||||
|
endif
|
||||||
|
|
||||||
|
config NAND_ARASAN
|
||||||
|
bool "Configure Arasan Nand"
|
||||||
|
select SYS_NAND_SELF_INIT
|
||||||
|
imply CMD_NAND
|
||||||
|
help
|
||||||
|
This enables Nand driver support for Arasan nand flash
|
||||||
|
controller. This uses the hardware ECC for read and
|
||||||
|
write operations.
|
||||||
|
|
||||||
|
config NAND_MXC
|
||||||
|
bool "MXC NAND support"
|
||||||
|
depends on CPU_ARM926EJS || CPU_ARM1136 || MX5
|
||||||
|
imply CMD_NAND
|
||||||
|
help
|
||||||
|
This enables the NAND driver for the NAND flash controller on the
|
||||||
|
i.MX27 / i.MX31 / i.MX5 rocessors.
|
||||||
|
|
||||||
|
config NAND_MXS
|
||||||
|
bool "MXS NAND support"
|
||||||
|
depends on MX23 || MX28 || MX6 || MX7
|
||||||
|
select SYS_NAND_SELF_INIT
|
||||||
|
imply CMD_NAND
|
||||||
|
select APBH_DMA
|
||||||
|
select APBH_DMA_BURST if ARCH_MX6 || ARCH_MX7
|
||||||
|
select APBH_DMA_BURST8 if ARCH_MX6 || ARCH_MX7
|
||||||
|
help
|
||||||
|
This enables NAND driver for the NAND flash controller on the
|
||||||
|
MXS processors.
|
||||||
|
|
||||||
|
if NAND_MXS
|
||||||
|
|
||||||
|
config NAND_MXS_DT
|
||||||
|
bool "Support MXS NAND controller as a DT device"
|
||||||
|
depends on OF_CONTROL && MTD
|
||||||
|
help
|
||||||
|
Enable the driver for MXS NAND flash on platforms using
|
||||||
|
device tree.
|
||||||
|
|
||||||
|
config NAND_MXS_USE_MINIMUM_ECC
|
||||||
|
bool "Use minimum ECC strength supported by the controller"
|
||||||
|
default false
|
||||||
|
|
||||||
|
endif
|
||||||
|
|
||||||
|
config NAND_ZYNQ
|
||||||
|
bool "Support for Zynq Nand controller"
|
||||||
|
select SYS_NAND_SELF_INIT
|
||||||
|
imply CMD_NAND
|
||||||
|
help
|
||||||
|
This enables Nand driver support for Nand flash controller
|
||||||
|
found on Zynq SoC.
|
||||||
|
|
||||||
|
config NAND_ZYNQ_USE_BOOTLOADER1_TIMINGS
|
||||||
|
bool "Enable use of 1st stage bootloader timing for NAND"
|
||||||
|
depends on NAND_ZYNQ
|
||||||
|
help
|
||||||
|
This flag prevent U-boot reconfigure NAND flash controller and reuse
|
||||||
|
the NAND timing from 1st stage bootloader.
|
||||||
|
|
||||||
|
comment "Generic NAND options"
|
||||||
|
|
||||||
|
config SYS_NAND_BLOCK_SIZE
|
||||||
|
hex "NAND chip eraseblock size"
|
||||||
|
depends on ARCH_SUNXI
|
||||||
|
help
|
||||||
|
Number of data bytes in one eraseblock for the NAND chip on the
|
||||||
|
board. This is the multiple of NAND_PAGE_SIZE and the number of
|
||||||
|
pages.
|
||||||
|
|
||||||
|
config SYS_NAND_PAGE_SIZE
|
||||||
|
hex "NAND chip page size"
|
||||||
|
depends on ARCH_SUNXI
|
||||||
|
help
|
||||||
|
Number of data bytes in one page for the NAND chip on the
|
||||||
|
board, not including the OOB area.
|
||||||
|
|
||||||
|
config SYS_NAND_OOBSIZE
|
||||||
|
hex "NAND chip OOB size"
|
||||||
|
depends on ARCH_SUNXI
|
||||||
|
help
|
||||||
|
Number of bytes in the Out-Of-Band area for the NAND chip on
|
||||||
|
the board.
|
||||||
|
|
||||||
|
# Enhance depends when converting drivers to Kconfig which use this config
|
||||||
|
# option (mxc_nand, ndfc, omap_gpmc).
|
||||||
|
config SYS_NAND_BUSWIDTH_16BIT
|
||||||
|
bool "Use 16-bit NAND interface"
|
||||||
|
depends on NAND_VF610_NFC || NAND_OMAP_GPMC || NAND_MXC || ARCH_DAVINCI
|
||||||
|
help
|
||||||
|
Indicates that NAND device has 16-bit wide data-bus. In absence of this
|
||||||
|
config, bus-width of NAND device is assumed to be either 8-bit and later
|
||||||
|
determined by reading ONFI params.
|
||||||
|
Above config is useful when NAND device's bus-width information cannot
|
||||||
|
be determined from on-chip ONFI params, like in following scenarios:
|
||||||
|
- SPL boot does not support reading of ONFI parameters. This is done to
|
||||||
|
keep SPL code foot-print small.
|
||||||
|
- In current U-Boot flow using nand_init(), driver initialization
|
||||||
|
happens in board_nand_init() which is called before any device probe
|
||||||
|
(nand_scan_ident + nand_scan_tail), thus device's ONFI parameters are
|
||||||
|
not available while configuring controller. So a static CONFIG_NAND_xx
|
||||||
|
is needed to know the device's bus-width in advance.
|
||||||
|
|
||||||
|
if SPL
|
||||||
|
|
||||||
|
config SYS_NAND_U_BOOT_LOCATIONS
|
||||||
|
bool "Define U-boot binaries locations in NAND"
|
||||||
|
help
|
||||||
|
Enable CONFIG_SYS_NAND_U_BOOT_OFFS though Kconfig.
|
||||||
|
This option should not be enabled when compiling U-boot for boards
|
||||||
|
defining CONFIG_SYS_NAND_U_BOOT_OFFS in their include/configs/<board>.h
|
||||||
|
file.
|
||||||
|
|
||||||
|
config SYS_NAND_U_BOOT_OFFS
|
||||||
|
hex "Location in NAND to read U-Boot from"
|
||||||
|
default 0x800000 if NAND_SUNXI
|
||||||
|
depends on SYS_NAND_U_BOOT_LOCATIONS
|
||||||
|
help
|
||||||
|
Set the offset from the start of the nand where u-boot should be
|
||||||
|
loaded from.
|
||||||
|
|
||||||
|
config SYS_NAND_U_BOOT_OFFS_REDUND
|
||||||
|
hex "Location in NAND to read U-Boot from"
|
||||||
|
default SYS_NAND_U_BOOT_OFFS
|
||||||
|
depends on SYS_NAND_U_BOOT_LOCATIONS
|
||||||
|
help
|
||||||
|
Set the offset from the start of the nand where the redundant u-boot
|
||||||
|
should be loaded from.
|
||||||
|
|
||||||
|
config SPL_NAND_AM33XX_BCH
|
||||||
|
bool "Enables SPL-NAND driver which supports ELM based"
|
||||||
|
depends on NAND_OMAP_GPMC && !OMAP34XX
|
||||||
|
default y
|
||||||
|
help
|
||||||
|
Hardware ECC correction. This is useful for platforms which have ELM
|
||||||
|
hardware engine and use NAND boot mode.
|
||||||
|
Some legacy platforms like OMAP3xx do not have in-built ELM h/w engine,
|
||||||
|
so those platforms should use CONFIG_SPL_NAND_SIMPLE for enabling
|
||||||
|
SPL-NAND driver with software ECC correction support.
|
||||||
|
|
||||||
|
config SPL_NAND_DENALI
|
||||||
|
bool "Support Denali NAND controller for SPL"
|
||||||
|
help
|
||||||
|
This is a small implementation of the Denali NAND controller
|
||||||
|
for use on SPL.
|
||||||
|
|
||||||
|
config SPL_NAND_SIMPLE
|
||||||
|
bool "Use simple SPL NAND driver"
|
||||||
|
depends on !SPL_NAND_AM33XX_BCH
|
||||||
|
help
|
||||||
|
Support for NAND boot using simple NAND drivers that
|
||||||
|
expose the cmd_ctrl() interface.
|
||||||
|
endif
|
||||||
|
|
||||||
|
endif # if NAND
|
77
drivers/mtd/nand/raw/Makefile
Normal file
77
drivers/mtd/nand/raw/Makefile
Normal file
|
@ -0,0 +1,77 @@
|
||||||
|
# SPDX-License-Identifier: GPL-2.0+
|
||||||
|
#
|
||||||
|
# (C) Copyright 2006
|
||||||
|
# Wolfgang Denk, DENX Software Engineering, wd@denx.de.
|
||||||
|
|
||||||
|
ifdef CONFIG_SPL_BUILD
|
||||||
|
|
||||||
|
ifdef CONFIG_SPL_NAND_DRIVERS
|
||||||
|
NORMAL_DRIVERS=y
|
||||||
|
endif
|
||||||
|
|
||||||
|
obj-$(CONFIG_SPL_NAND_AM33XX_BCH) += am335x_spl_bch.o
|
||||||
|
obj-$(CONFIG_SPL_NAND_DENALI) += denali_spl.o
|
||||||
|
obj-$(CONFIG_SPL_NAND_SIMPLE) += nand_spl_simple.o
|
||||||
|
obj-$(CONFIG_SPL_NAND_LOAD) += nand_spl_load.o
|
||||||
|
obj-$(CONFIG_SPL_NAND_ECC) += nand_ecc.o
|
||||||
|
obj-$(CONFIG_SPL_NAND_BASE) += nand_base.o
|
||||||
|
obj-$(CONFIG_SPL_NAND_IDENT) += nand_ids.o nand_timings.o
|
||||||
|
obj-$(CONFIG_SPL_NAND_INIT) += nand.o
|
||||||
|
ifeq ($(CONFIG_SPL_ENV_SUPPORT),y)
|
||||||
|
obj-$(CONFIG_ENV_IS_IN_NAND) += nand_util.o
|
||||||
|
endif
|
||||||
|
|
||||||
|
else # not spl
|
||||||
|
|
||||||
|
NORMAL_DRIVERS=y
|
||||||
|
|
||||||
|
obj-y += nand.o
|
||||||
|
obj-y += nand_bbt.o
|
||||||
|
obj-y += nand_ids.o
|
||||||
|
obj-y += nand_util.o
|
||||||
|
obj-y += nand_ecc.o
|
||||||
|
obj-y += nand_base.o
|
||||||
|
obj-y += nand_timings.o
|
||||||
|
|
||||||
|
endif # not spl
|
||||||
|
|
||||||
|
ifdef NORMAL_DRIVERS
|
||||||
|
|
||||||
|
obj-$(CONFIG_NAND_ECC_BCH) += nand_bch.o
|
||||||
|
|
||||||
|
obj-$(CONFIG_NAND_ATMEL) += atmel_nand.o
|
||||||
|
obj-$(CONFIG_NAND_ARASAN) += arasan_nfc.o
|
||||||
|
obj-$(CONFIG_NAND_DAVINCI) += davinci_nand.o
|
||||||
|
obj-$(CONFIG_NAND_DENALI) += denali.o
|
||||||
|
obj-$(CONFIG_NAND_DENALI_DT) += denali_dt.o
|
||||||
|
obj-$(CONFIG_NAND_FSL_ELBC) += fsl_elbc_nand.o
|
||||||
|
obj-$(CONFIG_NAND_FSL_IFC) += fsl_ifc_nand.o
|
||||||
|
obj-$(CONFIG_NAND_FSL_UPM) += fsl_upm.o
|
||||||
|
obj-$(CONFIG_NAND_FSMC) += fsmc_nand.o
|
||||||
|
obj-$(CONFIG_NAND_KB9202) += kb9202_nand.o
|
||||||
|
obj-$(CONFIG_NAND_KIRKWOOD) += kirkwood_nand.o
|
||||||
|
obj-$(CONFIG_NAND_KMETER1) += kmeter1_nand.o
|
||||||
|
obj-$(CONFIG_NAND_LPC32XX_MLC) += lpc32xx_nand_mlc.o
|
||||||
|
obj-$(CONFIG_NAND_LPC32XX_SLC) += lpc32xx_nand_slc.o
|
||||||
|
obj-$(CONFIG_NAND_VF610_NFC) += vf610_nfc.o
|
||||||
|
obj-$(CONFIG_NAND_MXC) += mxc_nand.o
|
||||||
|
obj-$(CONFIG_NAND_MXS) += mxs_nand.o
|
||||||
|
obj-$(CONFIG_NAND_MXS_DT) += mxs_nand_dt.o
|
||||||
|
obj-$(CONFIG_NAND_PXA3XX) += pxa3xx_nand.o
|
||||||
|
obj-$(CONFIG_NAND_SPEAR) += spr_nand.o
|
||||||
|
obj-$(CONFIG_TEGRA_NAND) += tegra_nand.o
|
||||||
|
obj-$(CONFIG_NAND_OMAP_GPMC) += omap_gpmc.o
|
||||||
|
obj-$(CONFIG_NAND_OMAP_ELM) += omap_elm.o
|
||||||
|
obj-$(CONFIG_NAND_PLAT) += nand_plat.o
|
||||||
|
obj-$(CONFIG_NAND_SUNXI) += sunxi_nand.o
|
||||||
|
obj-$(CONFIG_NAND_ZYNQ) += zynq_nand.o
|
||||||
|
|
||||||
|
else # minimal SPL drivers
|
||||||
|
|
||||||
|
obj-$(CONFIG_NAND_FSL_ELBC) += fsl_elbc_spl.o
|
||||||
|
obj-$(CONFIG_NAND_FSL_IFC) += fsl_ifc_spl.o
|
||||||
|
obj-$(CONFIG_NAND_MXC) += mxc_nand_spl.o
|
||||||
|
obj-$(CONFIG_NAND_MXS) += mxs_nand_spl.o mxs_nand.o
|
||||||
|
obj-$(CONFIG_NAND_SUNXI) += sunxi_nand_spl.o
|
||||||
|
|
||||||
|
endif # drivers
|
|
@ -9,7 +9,7 @@
|
||||||
|
|
||||||
/*
|
/*
|
||||||
*
|
*
|
||||||
* linux/drivers/mtd/nand/nand_davinci.c
|
* linux/drivers/mtd/nand/raw/nand_davinci.c
|
||||||
*
|
*
|
||||||
* NAND Flash Driver
|
* NAND Flash Driver
|
||||||
*
|
*
|
|
@ -3,7 +3,7 @@
|
||||||
* This file contains an ECC algorithm from Toshiba that detects and
|
* This file contains an ECC algorithm from Toshiba that detects and
|
||||||
* corrects 1 bit errors in a 256 byte block of data.
|
* corrects 1 bit errors in a 256 byte block of data.
|
||||||
*
|
*
|
||||||
* drivers/mtd/nand/nand_ecc.c
|
* drivers/mtd/nand/raw/nand_ecc.c
|
||||||
*
|
*
|
||||||
* Copyright (C) 2000-2004 Steven J. Hill (sjhill@realitydiluted.com)
|
* Copyright (C) 2000-2004 Steven J. Hill (sjhill@realitydiluted.com)
|
||||||
* Toshiba America Electronics Components, Inc.
|
* Toshiba America Electronics Components, Inc.
|
|
@ -1,6 +1,6 @@
|
||||||
// SPDX-License-Identifier: GPL-2.0
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* drivers/mtd/nand/nand_util.c
|
* drivers/mtd/nand/raw/nand_util.c
|
||||||
*
|
*
|
||||||
* Copyright (C) 2006 by Weiss-Electronic GmbH.
|
* Copyright (C) 2006 by Weiss-Electronic GmbH.
|
||||||
* All rights reserved.
|
* All rights reserved.
|
|
@ -1,6 +1,6 @@
|
||||||
// SPDX-License-Identifier: GPL-2.0
|
// SPDX-License-Identifier: GPL-2.0
|
||||||
/*
|
/*
|
||||||
* drivers/mtd/nand/pxa3xx_nand.c
|
* drivers/mtd/nand/raw/pxa3xx_nand.c
|
||||||
*
|
*
|
||||||
* Copyright © 2005 Intel Corporation
|
* Copyright © 2005 Intel Corporation
|
||||||
* Copyright © 2006 Marvell International Ltd.
|
* Copyright © 2006 Marvell International Ltd.
|
|
@ -240,7 +240,7 @@
|
||||||
/* LB refresh timer prescal, 266MHz/32 */
|
/* LB refresh timer prescal, 266MHz/32 */
|
||||||
#define CONFIG_SYS_LBC_MRTPR 0x20000000 /*TODO */
|
#define CONFIG_SYS_LBC_MRTPR 0x20000000 /*TODO */
|
||||||
|
|
||||||
/* drivers/mtd/nand/nand.c */
|
/* drivers/mtd/nand/raw/nand.c */
|
||||||
#if defined(CONFIG_NAND) && defined(CONFIG_SPL_BUILD)
|
#if defined(CONFIG_NAND) && defined(CONFIG_SPL_BUILD)
|
||||||
#define CONFIG_SYS_NAND_BASE 0xFFF00000
|
#define CONFIG_SYS_NAND_BASE 0xFFF00000
|
||||||
#else
|
#else
|
||||||
|
|
Loading…
Add table
Reference in a new issue