[PATCH v3 1/2] mtd: rawnand: ca_nand: add Cortina Access Parallel NAND controller support
Alex Nemirovsky
alex.nemirovsky at cortina-access.com
Mon Jun 1 23:26:49 CEST 2020
From: Jason Li <jason.li at cortina-access.com>
Supports all CAxxxx SoCs which support a parallel nand controller.
It should be noted that some CAxxxx Soc also support an separate
SPI serial NAND controller.
This driver only supports the parallel NAND controller. A different
driver supports the SPI NAND interface controller.
Signed-off-by: Jason Li <jason.li at cortina-access.com>
Signed-off-by: Alex Nemirovsky <alex.nemirovsky at cortina-access.com>
CC: Miquel Raynal <miquel.raynal at bootlin.com>
CC: Simon Glass <sjg at chromium.org>
CC: Tom Rini <trini at konsulko.com>
---
Changes in v3:
- Include udelay.h to avoid implicit declaration of udelay()
Changes in v2:
- Cleanup code style to pass checkpatch.pl
MAINTAINERS | 2 +
drivers/mtd/nand/raw/Kconfig | 31 +
drivers/mtd/nand/raw/Makefile | 1 +
drivers/mtd/nand/raw/ca_nand.c | 4943 ++++++++++++++++++++++++++++++++++++++++
drivers/mtd/nand/raw/ca_nand.h | 3899 +++++++++++++++++++++++++++++++
5 files changed, 8876 insertions(+)
create mode 100644 drivers/mtd/nand/raw/ca_nand.c
create mode 100644 drivers/mtd/nand/raw/ca_nand.h
diff --git a/MAINTAINERS b/MAINTAINERS
index 8add9d4..6da2ad8 100644
--- a/MAINTAINERS
+++ b/MAINTAINERS
@@ -181,6 +181,8 @@ F: drivers/gpio/cortina_gpio.c
F: drivers/watchdog/cortina_wdt.c
F: drivers/serial/serial_cortina.c
F: drivers/mmc/ca_dw_mmc.c
+F: drivers/mtd/nand/raw/ca_nand.c
+F: drivers/mtd/nand/raw/ca_nand.h
ARM/CZ.NIC TURRIS MOX SUPPORT
M: Marek Behun <marek.behun at nic.cz>
diff --git a/drivers/mtd/nand/raw/Kconfig b/drivers/mtd/nand/raw/Kconfig
index c4d9d31..b3cbfcc 100644
--- a/drivers/mtd/nand/raw/Kconfig
+++ b/drivers/mtd/nand/raw/Kconfig
@@ -102,6 +102,37 @@ config NAND_BRCMNAND_63158
help
Enable support for broadcom nand driver on bcm63158.
+config NAND_CORTINA
+ tristate "Support Cortina-Access Parallel NAND cntlr."
+ select SYS_NAND_SELF_INIT
+ help
+ This enables the parallel RAW NAND driver for the
+ Cortina-Access CAxxxx Family of SoCs.
+
+config NAND_CORTINA_ECC_LEVEL
+ int "Cortina-Access Parallel Nand driver HW ECC algorithm"
+ default 3
+ range 0 5
+ depends on NAND_CORTINA
+ help
+ NAND Flash ECC algorithm. Value range from 0 to 5.
+ The default value is 3.
+
+ 0: Hamming algorithm. Correct 3 bad bits in 256 btyes.
+ 1: Hamming algorithm. Correct 3 bad bits in 512 btyes.
+ 2: BCH algorithm. Correct 8 bad bits in 1K btyes.
+ 3: BCH algorithm. Correct 16 bad bits in 1K btyes.
+ 4: BCH algorithm. Correct 24 bad bits in 1K btyes.
+ 5: BCH algorithm. Correct 40 bad bits in 1K btyes.
+
+config NAND_CORTINA_ECC_HW_BCH
+ bool
+ default y
+ depends on NAND_CORTINA_ECC_LEVEL=2 \
+ || NAND_CORTINA_ECC_LEVEL=3 \
+ || NAND_CORTINA_ECC_LEVEL=4 \
+ || NAND_CORTINA_ECC_LEVEL=5
+
config NAND_DAVINCI
bool "Support TI Davinci NAND controller"
help
diff --git a/drivers/mtd/nand/raw/Makefile b/drivers/mtd/nand/raw/Makefile
index 9337f64..572e9e6 100644
--- a/drivers/mtd/nand/raw/Makefile
+++ b/drivers/mtd/nand/raw/Makefile
@@ -42,6 +42,7 @@ 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_BRCMNAND) += brcmnand/
+obj-$(CONFIG_NAND_CORTINA) += ca_nand.o
obj-$(CONFIG_NAND_DAVINCI) += davinci_nand.o
obj-$(CONFIG_NAND_DENALI) += denali.o
obj-$(CONFIG_NAND_DENALI_DT) += denali_dt.o
diff --git a/drivers/mtd/nand/raw/ca_nand.c b/drivers/mtd/nand/raw/ca_nand.c
new file mode 100644
index 0000000..1044efb
--- /dev/null
+++ b/drivers/mtd/nand/raw/ca_nand.c
@@ -0,0 +1,4943 @@
+// SPDX-License-Identifier: GPL-2.0+
+/*
+ * Copyright (C) 2015-2020 Cortina-Access Incorporation
+ * Parallel NAND Controller Driver for CAxxxx based SoCs
+ */
+
+#include <common.h>
+#include <nand.h>
+#include <malloc.h>
+#include <watchdog.h>
+#include <linux/err.h>
+#ifdef CONFIG_MTD_PARTITIONS
+#include <linux/mtd/partitions.h>
+#endif
+
+#include <asm/io.h>
+#include <linux/errno.h>
+#include <linux/delay.h>
+#include "ca_nand.h"
+
+#ifdef CONFIG_JFFS2_NAND
+#include <jffs2/jffs2.h>
+#endif
+
+#ifndef CONFIG_SYS_NAND_BASE_LIST
+#define CONFIG_SYS_NAND_BASE_LIST { CONFIG_SYS_NAND_BASE }
+#endif
+
+DECLARE_GLOBAL_DATA_PTR;
+
+#define OWN_DMA 0
+#define OWN_SW 1
+
+struct mtd_info cortina_nand_info[CONFIG_SYS_MAX_NAND_DEVICE];
+
+static struct nand_chip nand_chip[CONFIG_SYS_MAX_NAND_DEVICE];
+static ulong base_address[CONFIG_SYS_MAX_NAND_DEVICE] =
+ CONFIG_SYS_NAND_BASE_LIST;
+static ulong dma_global_base_address = CORTINA_DMA_GLB_BASE;
+static ulong dma_ssp_base_address = CORTINA_DMA_SSP_BASE;
+
+static const char default_nand_name[] = "ca_nand";
+static __attribute__ ((unused))
+char dev_name[CONFIG_SYS_MAX_NAND_DEVICE][8];
+
+/* OOB placement block for use with hardware ecc generation */
+/*#ifdef CONFIG_G3_NAND_HWECC*/
+static struct nand_ecclayout ca_nand_ecclayout;
+
+/* Define default oob placement schemes for large and small page devices */
+#ifdef CONFIG_NAND_CORTINA_ECC_HW_BCH
+
+static struct nand_ecclayout ca_nand_bch_oob_16 = {
+ .eccbytes = 13,
+ .eccpos = {0, 1, 2, 3, 6, 7, 8, 9, 10, 11, 12, 13, 14},
+ .oobfree = {
+ {.offset = 15,
+ /* . length = 1}} resever 1 for erase tags: 1 - 1 = 0 */
+ .length = 0}} /* resever 1 for erase tags: 1 - 1 = 0 */
+};
+
+#else
+
+static struct nand_ecclayout ca_nand_oob_8 = {
+ .eccbytes = 3,
+ .eccpos = {0, 1, 2},
+ .oobfree = {
+ {.offset = 3,
+ .length = 2},
+ {.offset = 6,
+ .length = 2}}
+};
+
+static struct nand_ecclayout ca_nand_oob_16 = {
+ .eccbytes = 6,
+ .eccpos = {0, 1, 2, 3, 6, 7},
+ .oobfree = {
+ {.offset = 8,
+ .length = 8}}
+};
+
+#endif
+
+struct ca_nand_host {
+ struct mtd_info mtd;
+ struct nand_chip *nand;
+ void __iomem *io_base;
+ struct device *dev;
+ unsigned int col_addr;
+ unsigned int page_addr;
+};
+
+static struct ca_nand_host ca_host;
+static struct ca_nand_host *host = &ca_host;
+
+static unsigned int CHIP_EN;
+static unsigned int *pread, *pwrite;
+union FLASH_TYPE_t flash_type;
+union FLASH_STATUS_t flash_status;
+union FLASH_NF_ACCESS_t nf_access;
+union FLASH_NF_COUNT_t nf_cnt;
+union FLASH_NF_COMMAND_t nf_cmd;
+union FLASH_NF_ADDRESS_1_t nf_addr1;
+union FLASH_NF_ADDRESS_2_t nf_addr2;
+union FLASH_NF_DATA_t nf_data;
+union FLASH_NF_ECC_STATUS_t ecc_sts;
+union FLASH_NF_ECC_CONTROL_t ecc_ctl;
+union FLASH_NF_ECC_OOB_t ecc_oob;
+union FLASH_NF_ECC_GEN0_t ecc_gen0;
+union FLASH_NF_ECC_GEN1_t ecc_gen1;
+union FLASH_NF_ECC_GEN2_t ecc_gen2;
+union FLASH_NF_ECC_GEN3_t ecc_gen3;
+union FLASH_NF_ECC_GEN4_t ecc_gen4;
+union FLASH_NF_ECC_GEN5_t ecc_gen5;
+union FLASH_NF_ECC_GEN6_t ecc_gen6;
+union FLASH_NF_ECC_GEN7_t ecc_gen7;
+union FLASH_NF_ECC_GEN8_t ecc_gen8;
+union FLASH_NF_ECC_GEN9_t ecc_gen9;
+union FLASH_NF_ECC_GEN10_t ecc_gen10;
+union FLASH_NF_ECC_GEN11_t ecc_gen11;
+union FLASH_NF_ECC_GEN12_t ecc_gen12;
+union FLASH_NF_ECC_GEN13_t ecc_gen13;
+union FLASH_NF_ECC_GEN14_t ecc_gen14;
+union FLASH_NF_ECC_GEN15_t ecc_gen15;
+union FLASH_FLASH_ACCESS_START_t flash_start;
+union FLASH_NF_ECC_RESET_t ecc_reset;
+union FLASH_FLASH_INTERRUPT_t flash_int_sts;
+union FLASH_FLASH_MASK_t flash_int_mask;
+union FLASH_NF_BCH_STATUS_t bch_sts;
+union FLASH_NF_BCH_ERROR_LOC01_t bch_err_loc01;
+union FLASH_NF_BCH_ERROR_LOC23_t bch_err_loc23;
+union FLASH_NF_BCH_ERROR_LOC45_t bch_err_loc45;
+union FLASH_NF_BCH_ERROR_LOC67_t bch_err_loc67;
+union FLASH_NF_BCH_CONTROL_t bch_ctrl;
+union FLASH_NF_BCH_OOB0_t reg_bch_oob;
+union FLASH_NF_BCH_OOB1_t bch_oob1;
+union FLASH_NF_BCH_OOB2_t bch_oob2;
+union FLASH_NF_BCH_OOB3_t bch_oob3;
+union FLASH_NF_BCH_OOB4_t bch_oob4;
+
+/* DMA regs */
+union DMA_SEC_DMA_GLB_DMA_SSP_RX_CTRL_t dma_rxdma_ctrl;
+union DMA_SEC_DMA_GLB_DMA_SSP_TX_CTRL_t dma_txdma_ctrl;
+union DMA_SEC_DMA_SSP_Q_TXQ_CONTROL_t dma_txq5_ctrl;
+union DMA_SEC_DMA_SSP_Q_RXQ_BASE_DEPTH_t dma_rxq5_base_depth;
+union DMA_SEC_DMA_SSP_Q_RXQ_RPTR_t dma_rxq5_rptr;
+union DMA_SEC_DMA_SSP_Q_TXQ_BASE_DEPTH_t dma_txq5_base_depth;
+union DMA_SEC_DMA_SSP_Q_TXQ_WPTR_t dma_txq5_wptr;
+union DMA_SEC_DMA_SSP_Q_RXQ_COAL_INTERRUPT_t dma_ssp_rxq5_intsts;
+union DMA_SEC_DMA_SSP_Q_TXQ_COAL_INTERRUPT_t dma_ssp_txq5_intsts;
+
+union FLASH_FLASH_ACCESS_START_t tmp_access;
+
+struct tx_descriptor_t *tx_desc;
+struct rx_descriptor_t *rx_desc;
+
+static void write_flash_ctrl_reg(unsigned int ofs, unsigned int data);
+static unsigned int read_flash_ctrl_reg(unsigned int ofs);
+static void check_flash_ctrl_status(void);
+static int ca_nand_block_checkbad(struct mtd_info *mtd, loff_t ofs, int getchip,
+ int allowbbt);
+static int ca_nand_get_device(struct nand_chip *chip, struct mtd_info *mtd,
+ int new_state);
+static u8 *ca_nand_fill_oob(struct nand_chip *chip, u8 *oob,
+ struct mtd_oob_ops *ops);
+static int ca_nand_do_write_oob(struct mtd_info *mtd, loff_t to,
+ struct mtd_oob_ops *ops);
+static int ca_nand_do_write_ops(struct mtd_info *mtd, loff_t to,
+ struct mtd_oob_ops *ops);
+static int ca_nand_do_read_ops(struct mtd_info *mtd, loff_t from,
+ struct mtd_oob_ops *ops);
+static int ca_nand_erase_nand(struct mtd_info *mtd, struct erase_info *instr,
+ int allowbbt);
+static int ca_nand_check_wp(struct mtd_info *mtd);
+static unsigned int reg_wait(unsigned int regaddr, unsigned int mask,
+ unsigned int val, int timeout);
+static void ca_nand_wait_ready(struct mtd_info *mtd);
+static void ca_nand_command(struct mtd_info *mtd, unsigned int command,
+ int column,
+ int page_addr);
+static void ca_nand_command_lp(struct mtd_info *mtd, unsigned int command,
+ int column, int page_addr);
+
+#ifdef CONFIG_NAND_HIDE_BAD
+#define BAD_BLOCK_LIST_ELEMENT 512
+static u16 acc_phy_offset;
+static u16 bad_block_cnt;
+static u32 bad_block_list[BAD_BLOCK_LIST_ELEMENT];
+static u32 xlat_offset_to_skip_bad(struct mtd_info *mtd, u32 page_addr)
+{
+ struct nand_chip *chip = mtd->priv;
+ u32 i = 0;
+ u32 offset = page_addr << chip->page_shift;
+
+ /* Just return original offset:
+ * 1. if no bad block found
+ * 2. Physical flash offset access is assigned
+ */
+ if (bad_block_cnt == 0 || acc_phy_offset)
+ return page_addr;
+
+ for (i = 0; i < bad_block_cnt; i++) {
+ if (bad_block_list[i] <= offset)
+ offset += mtd->erasesize;
+ else
+ break;
+ }
+ page_addr = offset >> chip->page_shift;
+ return page_addr;
+}
+
+static void update_bad_block_list(u32 offset, u32 is_add)
+{
+ u32 i = 0;
+ u32 local_buf[BAD_BLOCK_LIST_ELEMENT];
+
+ memcpy(local_buf, bad_block_list, sizeof(local_buf));
+
+ if (is_add) {
+ if (!bad_block_cnt) {
+ bad_block_list[bad_block_cnt++] = offset;
+ goto done;
+ }
+ while (1) {
+ if (offset < bad_block_list[i]) {
+ bad_block_list[i] = offset;
+ memcpy(&bad_block_list[i + 1], &local_buf[i],
+ sizeof(u32) * (bad_block_cnt - i + 1));
+ bad_block_cnt++;
+ goto done;
+ } else if (offset == bad_block_list[i]) {
+ goto done;
+ } else if ((i + 1) == bad_block_cnt) {
+ bad_block_list[i + 1] = offset;
+ bad_block_cnt++;
+ goto done;
+ } else {
+ i++;
+ }
+ }
+ } else {
+ while (i < bad_block_cnt) {
+ if (offset != bad_block_list[i]) {
+ i++;
+ } else {
+ memcpy(&bad_block_list[i], &local_buf[i + 1],
+ sizeof(u32) * (bad_block_cnt - i - 1));
+ bad_block_cnt--;
+ goto done;
+ }
+ }
+ }
+done:
+ return
+}
+
+void nand_print_bad_block_hidden_list(void)
+{
+ u32 i;
+
+ puts("HiddenList: ");
+ for (i = 0; i < bad_block_cnt; i++)
+ printf("0x%x ", bad_block_list[i]);
+
+ puts("\n");
+}
+
+static void scan_parallel_nand_bad_blocks(struct mtd_info *mtd, u32 start,
+ u32 size)
+{
+ u32 offset = start;
+
+ acc_phy_offset = 1;
+ bad_block_cnt = 0;
+ memset(&bad_block_list, 0, BAD_BLOCK_LIST_ELEMENT * sizeof(u32));
+ while (((offset - start) < size) &&
+ (bad_block_cnt < BAD_BLOCK_LIST_ELEMENT)) {
+ if (mtd->_block_isbad(mtd, offset))
+ bad_block_list[bad_block_cnt++] = offset;
+
+ offset += mtd->erasesize;
+ }
+ acc_phy_offset = 0;
+ nand_print_bad_block_hidden_list();
+}
+
+u32 nand_get_phy_offset(struct mtd_info *mtd, u32 viraddr)
+{
+ struct nand_chip *chip = mtd->priv;
+ u32 page_addr = viraddr >> chip->page_shift;
+
+ return xlat_offset_to_skip_bad(mtd, page_addr) << chip->page_shift;
+}
+#endif
+
+#define NAND_MAX_CHIPS CONFIG_SYS_NAND_MAX_CHIPS
+#define BBT_PAGE_MASK 0xffffff3f
+#define SZ_32M 0x8000
+#define SZ_128M 0x20000
+
+static int dbg_ecc_check;
+
+u32 flash_reset(void)
+{
+ union FLASH_NF_ACCESS_t nf_access;
+ union FLASH_NF_ECC_RESET_t nf_ecc_reset;
+
+ nf_access.wrd = 0;
+ nf_access.bf.autoreset = 1;
+ write_flash_ctrl_reg(FLASH_NF_ACCESS, nf_access.wrd);
+
+ nf_ecc_reset.wrd = 0;
+ nf_ecc_reset.bf.nflash_reset = 1;
+ write_flash_ctrl_reg(FLASH_NF_ECC_RESET, nf_ecc_reset.wrd);
+
+ udelay(1);
+
+ return 0;
+}
+
+static unsigned int read_flash_ctrl_reg(unsigned int ofs)
+{
+ return readl((unsigned long)base_address[0] + ofs);
+}
+
+static void write_flash_ctrl_reg(unsigned int ofs, unsigned int data)
+{
+ writel(data, (unsigned long)base_address[0] + ofs);
+}
+
+static unsigned int read_dma_global_reg(unsigned int ofs)
+{
+ return readl((const unsigned long)dma_global_base_address + ofs);
+}
+
+void write_dma_global_reg(unsigned int ofs, unsigned int data)
+{
+ writel(data, (unsigned long)dma_global_base_address + ofs);
+}
+
+static unsigned int read_dma_ctrl_reg(unsigned int ofs)
+{
+ return readl((const unsigned long)dma_ssp_base_address + ofs);
+}
+
+void write_dma_ctrl_reg(unsigned int ofs, unsigned int data)
+{
+ writel(data, (unsigned long)dma_ssp_base_address + ofs);
+}
+
+/*
+ * ca_nand_get_device - [GENERIC] Get chip for selected access
+ * @chip: the nand chip descr
+ * @mtd: MTD device structure
+ * @new_state: the state which is requested
+ *
+ * Get the device and lock it for exclusive access
+ */
+static int ca_nand_get_device(struct nand_chip *this, struct mtd_info *mtd,
+ int new_state)
+{
+ this->state = new_state;
+ return 0;
+}
+
+/*
+ * ca_nand_do_write_oob - [MTD Interface] NAND write out-of-band
+ * @mtd: MTD device structure
+ * @to: offset to write to
+ * @ops: oob operation description structure
+ *
+ * NAND write out-of-band
+ */
+static int ca_nand_do_write_oob(struct mtd_info *mtd, loff_t to,
+ struct mtd_oob_ops *ops)
+{
+ int chipnr, page, status, len;
+ struct nand_chip *chip = mtd->priv;
+
+#ifdef DEBUG
+ printf("%s: to = 0x%08x, len = %i\n", __func__, (unsigned int)to,
+ (int)ops->ooblen);
+#endif
+
+ if (ops->mode == MTD_OPS_AUTO_OOB)
+ len = chip->ecc.layout->oobavail;
+ else
+ len = mtd->oobsize;
+
+ /* Do not allow write past end of page */
+ if ((ops->ooboffs + ops->ooblen) > len) {
+ printf("%s: Attempt to write past end of page\n", __func__);
+ return -EINVAL;
+ }
+
+ if (unlikely(ops->ooboffs >= len)) {
+ printf("%s: Attempt to start write outside oob\n", __func__);
+ return -EINVAL;
+ }
+
+ /* Do not allow reads past end of device */
+ if (unlikely(to >= mtd->size ||
+ ops->ooboffs + ops->ooblen >
+ ((mtd->size >> chip->page_shift) -
+ (to >> chip->page_shift)) * len)) {
+ printf("%s: Attempt write beyond end of device\n", __func__);
+ return -EINVAL;
+ }
+
+ chipnr = (int)(to >> chip->chip_shift);
+ chip->select_chip(mtd, chipnr);
+
+ /* Shift to get page */
+ page = (int)(to >> chip->page_shift);
+
+ /*
+ * Reset the chip. Some chips (like the Toshiba TC5832DC found in one
+ * of my DiskOnChip 2000 test units) will clear the whole data page too
+ * if we don't do this. I have no clue why, but I seem to have 'fixed'
+ * it in the doc2000 driver in August 1999. dwmw2.
+ */
+ chip->cmdfunc(mtd, NAND_CMD_RESET, -1, -1);
+
+ /* Check, if it is write protected */
+ if (ca_nand_check_wp(mtd))
+ return -EROFS;
+
+ /* Invalidate the page cache, if we write to the cached page */
+ if (page == chip->pagebuf)
+ chip->pagebuf = -1;
+
+ memset(chip->oob_poi, 0xff, mtd->oobsize);
+ ca_nand_fill_oob(chip, ops->oobbuf, ops);
+ status = chip->ecc.write_oob(mtd, chip, page & chip->pagemask);
+ memset(chip->oob_poi, 0xff, mtd->oobsize);
+
+ if (status)
+ return status;
+
+ ops->oobretlen = ops->ooblen;
+
+ return 0;
+}
+
+/*
+ * return register value after "(*reg) & mask == val", with timeout
+ */
+static unsigned int reg_wait(unsigned int regaddr, unsigned int mask,
+ unsigned int val, int timeout)
+{
+ unsigned int i, tmp;
+
+ for (i = timeout; i > 0; i--) {
+ tmp = read_flash_ctrl_reg(regaddr);
+ if ((tmp & mask) == val)
+ return 0; //TRUE;
+ udelay(5);
+ }
+
+ printf("%s error !!\n", __func__);
+
+ return 1; //FALSE;
+}
+
+unsigned int dma_wait(unsigned int regaddr, unsigned int mask, unsigned int val,
+ int timeout)
+{
+ unsigned int i, tmp;
+
+ for (i = timeout; i > 0; i--) {
+ tmp = read_dma_ctrl_reg(regaddr);
+ if ((tmp & mask) == val)
+ return 0; //TRUE;
+ udelay(5);
+ }
+
+ printf("%s error !!\n", __func__);
+
+ return 1; //FALSE;
+}
+
+/*#ifdef CONFIG_G3_NAND_HWECC*/
+
+int ca_nand_correct_data(struct mtd_info *mtd, u_char *dat, u_char *read_ecc,
+ u_char *calc_ecc)
+{
+ /* Do nothing, data are corrected in read_page_page_hwecc */
+ return 0;
+}
+
+int ca_nand_calculate_ecc(struct mtd_info *mtd, const u_char *dat,
+ u_char *ecc_code)
+{
+ return 0;
+}
+
+void check_flash_ctrl_status(void)
+{
+ int rty = 0;
+
+ flash_status.wrd = read_flash_ctrl_reg(FLASH_STATUS);
+ while (flash_status.bf.nstate) {
+ flash_status.wrd = read_flash_ctrl_reg(FLASH_STATUS);
+ udelay(5);
+ rty++;
+ if (rty > 50000) {
+ printf("FLASH_STATUS ERROR: %x\n", flash_status.wrd);
+ return;
+ }
+ }
+}
+
+/*
+ * ca_nand_release_device - [GENERIC] release chip
+ * @mtd: MTD device structure
+ *
+ * Deselect, release chip lock and wake up anyone waiting on the device
+ */
+/* XXX U-BOOT XXX */
+void ca_nand_release_device(struct mtd_info *mtd)
+{
+ struct nand_chip *this = mtd->priv;
+
+ this->select_chip(mtd, -1); /* De-select the NAND device */
+}
+
+void ca_nand_read_id(int chip_no, unsigned char *id)
+{
+ unsigned int opcode, i;
+ const unsigned int extid = 8;
+ union FLASH_FLASH_ACCESS_START_t tmp_access;
+
+ check_flash_ctrl_status();
+
+ write_flash_ctrl_reg(FLASH_NF_ECC_CONTROL, 0x0);
+
+ flash_type.wrd = read_flash_ctrl_reg(FLASH_TYPE);
+
+ /*need to check extid byte counts */
+ nf_cnt.wrd = 0;
+
+ nf_cnt.bf.nflashregoobcount = NCNT_EMPTY_OOB;
+ nf_cnt.bf.nflashregdatacount = NCNT_DATA_8;
+ nf_cnt.bf.nflashregaddrcount = NCNT_ADDR_1;
+ nf_cnt.bf.nflashregcmdcount = NCNT_CMD_1;
+
+ write_flash_ctrl_reg(FLASH_NF_COUNT, nf_cnt.wrd);
+
+ nf_cmd.wrd = 0;
+ nf_cmd.bf.nflashregcmd0 = NAND_CMD_READID;
+ write_flash_ctrl_reg(FLASH_NF_COMMAND, nf_cmd.wrd);
+ nf_addr1.wrd = 0;
+ write_flash_ctrl_reg(FLASH_NF_ADDRESS_1, nf_addr1.wrd);
+ nf_addr2.wrd = 0;
+ write_flash_ctrl_reg(FLASH_NF_ADDRESS_2, nf_addr2.wrd);
+
+ /* read maker code */
+ nf_access.wrd = 0;
+ nf_access.bf.nflashcealt = chip_no;
+
+ nf_access.bf.nflashregwidth = NFLASH_WIDTH8;
+ write_flash_ctrl_reg(FLASH_NF_ACCESS, nf_access.wrd);
+
+ for (i = 0; i < extid; i++) {
+ flash_start.wrd = 0;
+ flash_start.bf.nflashregreq = FLASH_GO;
+ flash_start.bf.nflashregcmd = FLASH_RD;
+ write_flash_ctrl_reg(FLASH_FLASH_ACCESS_START, flash_start.wrd);
+
+ flash_start.wrd = read_flash_ctrl_reg(FLASH_FLASH_ACCESS_START);
+ tmp_access.wrd = 0;
+ tmp_access.bf.nflashregreq = 1;
+ reg_wait(FLASH_FLASH_ACCESS_START, tmp_access.wrd, 0, 2000);
+
+ opcode = read_flash_ctrl_reg(FLASH_NF_DATA);
+ id[i] = (unsigned char)((opcode >> ((i << 3) % 32)) & 0xff);
+ }
+
+ ecc_reset.wrd = 0;
+ ecc_reset.bf.eccclear = ECC_CLR;
+ ecc_reset.bf.fifoclear = FIFO_CLR;
+ ecc_reset.bf.nflash_reset = NF_RESET;
+ write_flash_ctrl_reg(FLASH_NF_ECC_RESET, ecc_reset.wrd);
+}
+
+/* Sanitize ONFI strings so we can safely print them */
+static void sanitize_string(char *s, size_t len)
+{
+ ssize_t i;
+
+ /* Null terminate */
+ s[len - 1] = 0;
+
+ /* Remove non printable chars */
+ for (i = 0; i < len - 1; i++) {
+ if (s[i] < ' ' || s[i] > 127)
+ s[i] = '?';
+ }
+
+ /* Remove trailing spaces */
+ strim(s);
+}
+
+static u16 onfi_crc16(u16 crc, u8 const *p, size_t len)
+{
+ int i;
+
+ while (len--) {
+ crc ^= *p++ << 8;
+ for (i = 0; i < 8; i++)
+ crc = (crc << 1) ^ ((crc & 0x8000) ? 0x8005 : 0);
+ }
+
+ return crc;
+}
+
+static int nand_setup_read_retry_micron(struct mtd_info *mtd, int retry_mode)
+{
+ struct nand_chip *chip = mtd_to_nand(mtd);
+ u8 feature[ONFI_SUBFEATURE_PARAM_LEN] = { retry_mode };
+
+ return chip->onfi_set_features(mtd, chip, ONFI_FEATURE_ADDR_READ_RETRY,
+ feature);
+}
+
+/*
+ * Configure chip properties from Micron vendor-specific ONFI table
+ */
+static void nand_onfi_detect_micron(struct nand_chip *chip,
+ struct nand_onfi_params *p)
+{
+ struct nand_onfi_vendor_micron *micron = (void *)p->vendor;
+
+ if (le16_to_cpu(p->vendor_revision) < 1)
+ return;
+
+ chip->read_retries = micron->read_retry_options;
+ chip->setup_read_retry = nand_setup_read_retry_micron;
+}
+
+/* Parse the Extended Parameter Page. */
+static int nand_flash_detect_ext_param_page(struct mtd_info *mtd,
+ struct nand_chip *chip,
+ struct nand_onfi_params *p)
+{
+ struct onfi_ext_param_page *ep;
+ struct onfi_ext_section *s;
+ struct onfi_ext_ecc_info *ecc;
+ u8 *cursor;
+ int ret = -EINVAL;
+ int len;
+ int i;
+
+ len = le16_to_cpu(p->ext_param_page_length) * 16;
+ ep = kmalloc(len, GFP_KERNEL);
+ if (!ep)
+ return -ENOMEM;
+
+ /* Send our own NAND_CMD_PARAM. */
+ chip->cmdfunc(mtd, NAND_CMD_PARAM, 0, -1);
+
+ /* Use the Change Read Column command to skip the ONFI param pages. */
+ chip->cmdfunc(mtd, NAND_CMD_RNDOUT, sizeof(*p) * p->num_of_param_pages,
+ -1);
+
+ /* Read out the Extended Parameter Page. */
+ chip->read_buf(mtd, (u8 *)ep, len);
+ if ((onfi_crc16(ONFI_CRC_BASE, ((u8 *)ep) + 2, len - 2)
+ != le16_to_cpu(ep->crc))) {
+ pr_debug("fail in the CRC.\n");
+ goto ext_out;
+ }
+
+ /*
+ * Check the signature.
+ * Do not strictly follow the ONFI spec, maybe changed in future.
+ */
+ if (strncmp((char *)ep->sig, "EPPS", 4)) {
+ pr_debug("The signature is invalid.\n");
+ goto ext_out;
+ }
+
+ /* find the ECC section. */
+ cursor = (u8 *)(ep + 1);
+ for (i = 0; i < ONFI_EXT_SECTION_MAX; i++) {
+ s = ep->sections + i;
+ if (s->type == ONFI_SECTION_TYPE_2)
+ break;
+ cursor += s->length * 16;
+ }
+ if (i == ONFI_EXT_SECTION_MAX) {
+ pr_debug("We can not find the ECC section.\n");
+ goto ext_out;
+ }
+
+ /* get the info we want. */
+ ecc = (struct onfi_ext_ecc_info *)cursor;
+
+ if (!ecc->codeword_size) {
+ pr_debug("Invalid codeword size\n");
+ goto ext_out;
+ }
+
+ chip->ecc_strength_ds = ecc->ecc_bits;
+ chip->ecc_step_ds = 1 << ecc->codeword_size;
+ ret = 0;
+
+ ext_out:
+ kfree(ep);
+ return ret;
+}
+
+void ca_nand_onfi_id(int chip_no, unsigned char *id)
+{
+ unsigned int opcode, i;
+ union FLASH_FLASH_ACCESS_START_t tmp_access;
+
+ check_flash_ctrl_status();
+
+ write_flash_ctrl_reg(FLASH_NF_ECC_CONTROL, 0x0);
+
+ flash_type.wrd = read_flash_ctrl_reg(FLASH_TYPE);
+
+ /*need to check extid byte counts */
+ nf_cnt.wrd = 0;
+
+ nf_cnt.bf.nflashregoobcount = NCNT_EMPTY_OOB;
+ nf_cnt.bf.nflashregdatacount = NCNT_DATA_4;
+ nf_cnt.bf.nflashregaddrcount = NCNT_ADDR_1;
+ nf_cnt.bf.nflashregcmdcount = NCNT_CMD_1;
+
+ write_flash_ctrl_reg(FLASH_NF_COUNT, nf_cnt.wrd);
+
+ nf_cmd.wrd = 0;
+ nf_cmd.bf.nflashregcmd0 = NAND_CMD_READID;
+ write_flash_ctrl_reg(FLASH_NF_COMMAND, nf_cmd.wrd);
+ nf_addr1.wrd = 0x20; /* subcommand 0x20 to get ONFI signature */
+ write_flash_ctrl_reg(FLASH_NF_ADDRESS_1, nf_addr1.wrd);
+ nf_addr2.wrd = 0;
+ write_flash_ctrl_reg(FLASH_NF_ADDRESS_2, nf_addr2.wrd);
+
+ /* read maker code */
+ nf_access.wrd = 0;
+ nf_access.bf.nflashcealt = chip_no;
+
+ nf_access.bf.nflashregwidth = NFLASH_WIDTH8;
+ write_flash_ctrl_reg(FLASH_NF_ACCESS, nf_access.wrd);
+
+ for (i = 0; i < 4; i++) {
+ flash_start.wrd = 0;
+ flash_start.bf.nflashregreq = FLASH_GO;
+ flash_start.bf.nflashregcmd = FLASH_RD;
+ write_flash_ctrl_reg(FLASH_FLASH_ACCESS_START, flash_start.wrd);
+
+ flash_start.wrd = read_flash_ctrl_reg(FLASH_FLASH_ACCESS_START);
+ tmp_access.wrd = 0;
+ tmp_access.bf.nflashregreq = 1;
+ reg_wait(FLASH_FLASH_ACCESS_START, tmp_access.wrd, 0, 2000);
+
+ opcode = read_flash_ctrl_reg(FLASH_NF_DATA);
+ id[i] = (unsigned char)((opcode >> ((i << 3) % 32)) & 0xff);
+ }
+
+ ecc_reset.wrd = 0;
+ ecc_reset.bf.eccclear = ECC_CLR;
+ ecc_reset.bf.fifoclear = FIFO_CLR;
+ ecc_reset.bf.nflash_reset = NF_RESET;
+ write_flash_ctrl_reg(FLASH_NF_ECC_RESET, ecc_reset.wrd);
+}
+
+int ca_nand_flash_detect_onfi(struct mtd_info *mtd, struct nand_chip *chip,
+ int *busw)
+{
+ unsigned int opcode;
+ int i;
+ int val;
+ union FLASH_FLASH_ACCESS_START_t tmp_access;
+ struct nand_onfi_params *p = &chip->onfi_params;
+ unsigned char onfi_sig[4], *onfi_param = (unsigned char *)p;
+
+ ca_nand_onfi_id(0, onfi_sig);
+ if ((onfi_sig[0] != 'O') || (onfi_sig[1] != 'N') ||
+ (onfi_sig[2] != 'F') || (onfi_sig[3] != 'I'))
+ return 0;
+
+ check_flash_ctrl_status();
+
+ write_flash_ctrl_reg(FLASH_NF_ECC_CONTROL, 0x0);
+
+ flash_type.wrd = read_flash_ctrl_reg(FLASH_TYPE);
+
+ /*need to check extid byte counts */
+ nf_cnt.wrd = 0;
+
+ nf_cnt.bf.nflashregoobcount = NCNT_EMPTY_OOB;
+ nf_cnt.bf.nflashregdatacount = sizeof(*p) - 1;
+ nf_cnt.bf.nflashregaddrcount = NCNT_ADDR_1;
+ nf_cnt.bf.nflashregcmdcount = NCNT_CMD_1;
+
+ write_flash_ctrl_reg(FLASH_NF_COUNT, nf_cnt.wrd);
+
+ nf_cmd.wrd = 0;
+ nf_cmd.bf.nflashregcmd0 = NAND_CMD_PARAM;
+ write_flash_ctrl_reg(FLASH_NF_COMMAND, nf_cmd.wrd);
+ nf_addr1.wrd = 0x0;
+ write_flash_ctrl_reg(FLASH_NF_ADDRESS_1, nf_addr1.wrd);
+ nf_addr2.wrd = 0;
+ write_flash_ctrl_reg(FLASH_NF_ADDRESS_2, nf_addr2.wrd);
+
+ /* read maker code */
+ nf_access.wrd = 0;
+ nf_access.bf.nflashcealt = 0;
+
+ nf_access.bf.nflashregwidth = NFLASH_WIDTH8;
+ write_flash_ctrl_reg(FLASH_NF_ACCESS, nf_access.wrd);
+
+ for (i = 0; i < sizeof(*p); i++) {
+ flash_start.wrd = 0;
+ flash_start.bf.nflashregreq = FLASH_GO;
+ flash_start.bf.nflashregcmd = FLASH_RD;
+ write_flash_ctrl_reg(FLASH_FLASH_ACCESS_START, flash_start.wrd);
+
+ flash_start.wrd = read_flash_ctrl_reg(FLASH_FLASH_ACCESS_START);
+ tmp_access.wrd = 0;
+ tmp_access.bf.nflashregreq = 1;
+ reg_wait(FLASH_FLASH_ACCESS_START, tmp_access.wrd, 0, 2000);
+
+ opcode = read_flash_ctrl_reg(FLASH_NF_DATA);
+ onfi_param[i] =
+ (unsigned char)((opcode >> ((i << 3) % 32)) & 0xff);
+ }
+
+ if (onfi_crc16(ONFI_CRC_BASE, (u8 *)p, 254) !=
+ le16_to_cpu(p->crc))
+ return 0;
+
+ ecc_reset.wrd = 0;
+ ecc_reset.bf.eccclear = ECC_CLR;
+ ecc_reset.bf.fifoclear = FIFO_CLR;
+ ecc_reset.bf.nflash_reset = NF_RESET;
+ write_flash_ctrl_reg(FLASH_NF_ECC_RESET, ecc_reset.wrd);
+
+ /* Check version */
+ val = le16_to_cpu(p->revision);
+ if (val & (1 << 5))
+ chip->onfi_version = 23;
+ else if (val & (1 << 4))
+ chip->onfi_version = 22;
+ else if (val & (1 << 3))
+ chip->onfi_version = 21;
+ else if (val & (1 << 2))
+ chip->onfi_version = 20;
+ else if (val & (1 << 1))
+ chip->onfi_version = 10;
+
+ if (!chip->onfi_version) {
+ pr_info("unsupported ONFI version: %d\n", val);
+ return 0;
+ }
+
+ sanitize_string(p->manufacturer, sizeof(p->manufacturer));
+ sanitize_string(p->model, sizeof(p->model));
+ if (!mtd->name)
+ mtd->name = p->model;
+
+ mtd->writesize = le32_to_cpu(p->byte_per_page);
+
+ /*
+ * pages_per_block and blocks_per_lun may not be a power-of-2 size
+ * (don't ask me who thought of this...). MTD assumes that these
+ * dimensions will be power-of-2, so just truncate the remaining area.
+ */
+ mtd->erasesize = 1 << (fls(le32_to_cpu(p->pages_per_block)) - 1);
+ mtd->erasesize *= mtd->writesize;
+
+ mtd->oobsize = le16_to_cpu(p->spare_bytes_per_page);
+
+ /* See erasesize comment */
+ chip->chipsize = 1 << (fls(le32_to_cpu(p->blocks_per_lun)) - 1);
+ chip->chipsize *= (uint64_t)mtd->erasesize * p->lun_count;
+ chip->bits_per_cell = p->bits_per_cell;
+
+ if (onfi_feature(chip) & ONFI_FEATURE_16_BIT_BUS)
+ *busw = NAND_BUSWIDTH_16;
+ else
+ *busw = 0;
+
+ if (p->ecc_bits != 0xff) {
+ chip->ecc_strength_ds = p->ecc_bits;
+ chip->ecc_step_ds = 512;
+ } else if (chip->onfi_version >= 21 &&
+ (onfi_feature(chip) & ONFI_FEATURE_EXT_PARAM_PAGE)) {
+ /*
+ * The nand_flash_detect_ext_param_page() uses the
+ * Change Read Column command which maybe not supported
+ * by the chip->cmdfunc. So try to update the chip->cmdfunc
+ * now. We do not replace user supplied command function.
+ */
+ if (mtd->writesize > 512 && chip->cmdfunc == ca_nand_command)
+ chip->cmdfunc = ca_nand_command_lp;
+
+ /* The Extended Parameter Page is supported since ONFI 2.1. */
+ if (nand_flash_detect_ext_param_page(mtd, chip, p))
+ pr_warn("Failed to detect ONFI extended param page\n");
+ } else {
+ pr_warn("Could not retrieve ONFI ECC requirements\n");
+ }
+
+ if (p->jedec_id == NAND_MFR_MICRON)
+ nand_onfi_detect_micron(chip, p);
+
+ return 1;
+}
+
+/*
+ * ca_nand_fill_oob - [Internal] Transfer client buffer to oob
+ * @chip: nand chip structure
+ * @oob: oob data buffer
+ * @ops: oob ops structure
+ */
+static u8 *ca_nand_fill_oob(struct nand_chip *chip, u8 *oob,
+ struct mtd_oob_ops *ops)
+{
+ size_t len = ops->ooblen;
+
+ switch (ops->mode) {
+ case MTD_OPS_PLACE_OOB:
+ case MTD_OPS_RAW:
+ memcpy(chip->oob_poi + ops->ooboffs, oob, len);
+ return oob + len;
+
+ case MTD_OPS_AUTO_OOB:{
+ struct nand_oobfree *free = chip->ecc.layout->oobfree;
+ u32 boffs = 0, woffs = ops->ooboffs;
+ size_t bytes = 0;
+
+ for (; free->length && len; free++, len -= bytes) {
+ /* Write request not from offset 0 ? */
+ if (unlikely(woffs)) {
+ if (woffs >= free->length) {
+ woffs -= free->length;
+ continue;
+ }
+ boffs = free->offset + woffs;
+ bytes =
+ min_t(size_t, len,
+ (free->length - woffs));
+ woffs = 0;
+ } else {
+ bytes =
+ min_t(size_t, len, free->length);
+ boffs = free->offset;
+ }
+ memcpy(chip->oob_poi + boffs, oob, bytes);
+ oob += bytes;
+ }
+ return oob;
+ }
+ //default:
+ //BUG();
+ }
+ return NULL;
+}
+
+/*
+ * ca_nand_xfer_oob - [Internal] Transfer oob to client buffer
+ * @chip: nand chip structure
+ * @oob: oob destination address
+ * @ops: oob ops structure
+ * @len: size of oob to xfer
+ */
+u8 *ca_nand_xfer_oob(struct nand_chip *chip, u8 *oob,
+ struct mtd_oob_ops *ops, size_t len)
+{
+ switch (ops->mode) {
+ case MTD_OPS_PLACE_OOB:
+ case MTD_OPS_RAW:
+ memcpy(oob, chip->oob_poi + ops->ooboffs, len);
+ return oob + len;
+
+ case MTD_OPS_AUTO_OOB:{
+ struct nand_oobfree *free = chip->ecc.layout->oobfree;
+ u32 boffs = 0, roffs = ops->ooboffs;
+ size_t bytes = 0;
+
+ for (; free->length && len; free++, len -= bytes) {
+ /* Read request not from offset 0 ? */
+ if (unlikely(roffs)) {
+ if (roffs >= free->length) {
+ roffs -= free->length;
+ continue;
+ }
+ boffs = free->offset + roffs;
+ bytes =
+ min_t(size_t, len,
+ (free->length - roffs));
+ roffs = 0;
+ } else {
+ bytes =
+ min_t(size_t, len, free->length);
+ boffs = free->offset;
+ }
+ memcpy(oob, chip->oob_poi + boffs, bytes);
+ oob += bytes;
+ }
+ return oob;
+ }
+ }
+ return NULL;
+}
+
+/*
+ * ca_nand_block_isbad - [MTD Interface] Check if block at offset is bad
+ * @mtd: MTD device structure
+ * @offs: offset relative to mtd start
+ */
+int ca_nand_block_isbad(struct mtd_info *mtd, loff_t offs)
+{
+ int rc;
+ /* Check for invalid offset */
+ if (offs > mtd->size)
+ return -EINVAL;
+
+ rc = ca_nand_block_checkbad(mtd, offs, 1, 0);
+
+ return rc;
+}
+
+/*
+ * ca_nand_block_markbad - [MTD Interface] Mark block at the given offset as bad
+ * @mtd: MTD device structure
+ * @ofs: offset relative to mtd start
+ */
+int ca_nand_block_markbad(struct mtd_info *mtd, loff_t ofs)
+{
+ struct nand_chip *chip = mtd->priv;
+ int ret;
+
+ ret = ca_nand_block_isbad(mtd, ofs);
+ if (ret != 0) {
+ /* If it was bad already, return success and do nothing. */
+ if (ret > 0)
+ return 0;
+ return ret;
+ }
+
+ ret = chip->block_markbad(mtd, ofs);
+
+ return ret;
+}
+
+/*
+ * ca_nand_sync - [MTD Interface] sync
+ * @mtd: MTD device structure
+ *
+ * Sync is actually a wait for chip ready function
+ */
+void ca_nand_sync(struct mtd_info *mtd)
+{
+ struct nand_chip *chip = mtd->priv;
+
+#ifdef DEBUG
+ printf("%s: called\n", __func__);
+#endif
+
+ /* Grab the lock and see if the device is available */
+ ca_nand_get_device(chip, mtd, FL_SYNCING);
+ /* Release it and go back */
+ ca_nand_release_device(mtd);
+}
+
+/*
+ * ca_nand_check_wp - [GENERIC] check if the chip is write protected
+ * @mtd: MTD device structure
+ * Check, if the device is write protected
+ *
+ * The function expects, that the device is already selected
+ */
+static int ca_nand_check_wp(struct mtd_info *mtd)
+{
+// struct nand_chip *this = mtd->priv;
+ /* Check the WP bit */
+ int ready;
+
+ check_flash_ctrl_status();
+
+ write_flash_ctrl_reg(FLASH_NF_ECC_CONTROL, 0x0); //disable ecc gen
+
+ nf_cnt.wrd = 0;
+ nf_cnt.bf.nflashregoobcount = NCNT_EMPTY_OOB;
+ nf_cnt.bf.nflashregdatacount = NCNT_DATA_1;
+ nf_cnt.bf.nflashregaddrcount = NCNT_EMPTY_ADDR;
+ nf_cnt.bf.nflashregcmdcount = NCNT_CMD_1;
+ write_flash_ctrl_reg(FLASH_NF_COUNT, nf_cnt.wrd);
+
+ nf_cmd.wrd = 0;
+ nf_cmd.bf.nflashregcmd0 = NAND_CMD_STATUS;
+ write_flash_ctrl_reg(FLASH_NF_COMMAND, nf_cmd.wrd);
+
+ nf_access.wrd = 0;
+ nf_access.bf.nflashcealt = CHIP_EN;
+ //nf_access.bf.nflashDirWr = ;
+ nf_access.bf.nflashregwidth = NFLASH_WIDTH8;
+ write_flash_ctrl_reg(FLASH_NF_ACCESS, nf_access.wrd);
+
+ flash_start.wrd = 0;
+ flash_start.bf.nflashregreq = FLASH_GO;
+ flash_start.bf.nflashregcmd = FLASH_RD;
+ write_flash_ctrl_reg(FLASH_FLASH_ACCESS_START, flash_start.wrd);
+
+ flash_start.wrd = read_flash_ctrl_reg(FLASH_FLASH_ACCESS_START);
+ while (flash_start.bf.nflashregreq) {
+ flash_start.wrd = read_flash_ctrl_reg(FLASH_FLASH_ACCESS_START);
+ udelay(1);
+ }
+
+ ready = read_flash_ctrl_reg(FLASH_NF_DATA) & 0xff;
+ if (ready == 0xff)
+ printf("%s flash status : %x\n", __func__,
+ read_flash_ctrl_reg(FLASH_STATUS));
+
+ return (ready & NAND_STATUS_WP) ? 0 : 1;
+}
+
+/*
+ * ca_nand_write_oob - [MTD Interface] NAND write data and/or out-of-band
+ * @mtd: MTD device structure
+ * @to: offset to write to
+ * @ops: oob operation description structure
+ */
+int ca_nand_write_oob(struct mtd_info *mtd, loff_t to, struct mtd_oob_ops *ops)
+{
+ struct nand_chip *chip = mtd->priv;
+ int ret = -ENOTSUPP;
+
+ ops->retlen = 0;
+
+ /* Do not allow writes past end of device */
+ if (ops->datbuf && (to + ops->len) > mtd->size) {
+ printf("%s: Attempt write beyond end of device\n", __func__);
+ return -EINVAL;
+ }
+
+ ca_nand_get_device(chip, mtd, FL_WRITING);
+
+ switch (ops->mode) {
+ case MTD_OPS_PLACE_OOB:
+ case MTD_OPS_AUTO_OOB:
+ case MTD_OPS_RAW:
+ break;
+
+ default:
+ goto out;
+ }
+
+#ifdef CONFIG_NAND_HIDE_BAD
+ acc_phy_offset = 1;
+#endif
+
+ if (!ops->datbuf)
+ ret = ca_nand_do_write_oob(mtd, to, ops);
+ else
+ ret = ca_nand_do_write_ops(mtd, to, ops);
+
+#ifdef CONFIG_NAND_HIDE_BAD
+ acc_phy_offset = 0;
+#endif
+
+ out:
+ ca_nand_release_device(mtd);
+
+ return ret;
+}
+
+/*
+ * ca_nand_do_read_oob - [Intern] NAND read out-of-band
+ * @mtd: MTD device structure
+ * @from: offset to read from
+ * @ops: oob operations description structure
+ *
+ * NAND read out-of-band data from the spare area
+ */
+int ca_nand_do_read_oob(struct mtd_info *mtd, loff_t from,
+ struct mtd_oob_ops *ops)
+{
+ int page, realpage, chipnr;
+ struct nand_chip *chip = mtd->priv;
+ int readlen = ops->ooblen;
+ int len;
+ u8 *buf = ops->oobbuf;
+
+#ifdef DEBUG
+ printf("%s: from = 0x%08lx, len = %i\n", __func__,
+ (unsigned long long)from, readlen);
+#endif
+
+ if (ops->mode == MTD_OPS_AUTO_OOB)
+ len = chip->ecc.layout->oobavail;
+ else
+ len = mtd->oobsize;
+
+ if (unlikely(ops->ooboffs >= len)) {
+ printf("%s: Attempt to start read outside oob\n", __func__);
+ return -EINVAL;
+ }
+
+ /* Do not allow reads past end of device */
+ if (unlikely(from >= mtd->size ||
+ ops->ooboffs + readlen >
+ ((mtd->size >> chip->page_shift) -
+ (from >> chip->page_shift)) * len)) {
+ printf("%s: Attempt read beyond end of device\n", __func__);
+ return -EINVAL;
+ }
+
+ chipnr = (int)(from >> chip->chip_shift);
+ chip->select_chip(mtd, chipnr);
+
+ /* Shift to get page */
+ realpage = (int)(from >> chip->page_shift);
+ page = realpage & chip->pagemask;
+
+ while (1) {
+ chip->ecc.read_oob(mtd, chip, page);
+
+ len = min(len, readlen);
+ buf = ca_nand_xfer_oob(chip, buf, ops, len);
+
+ if (!(chip->options & NAND_NEED_READRDY)) {
+ /*
+ * Apply delay or wait for ready/busy pin. Do this
+ * before the AUTOINCR check, so no problems arise if a
+ * chip which does auto increment is marked as
+ * NOAUTOINCR by the board driver.
+ */
+ if (!chip->dev_ready)
+ udelay(chip->chip_delay);
+ else
+ ca_nand_wait_ready(mtd);
+ }
+
+ readlen -= len;
+ if (!readlen)
+ break;
+
+ /* Increment page address */
+ realpage++;
+
+ page = realpage & chip->pagemask;
+ /* Check, if we cross a chip boundary */
+ if (!page) {
+ chipnr++;
+ chip->select_chip(mtd, -1);
+ chip->select_chip(mtd, chipnr);
+ }
+ }
+
+ ops->oobretlen = ops->ooblen;
+ return 0;
+}
+
+/*
+ * ca_nand_read_oob - [MTD Interface] NAND read data and/or out-of-band
+ * @mtd: MTD device structure
+ * @from: offset to read from
+ * @ops: oob operation description structure
+ *
+ * NAND read data and/or out-of-band data
+ */
+int ca_nand_read_oob(struct mtd_info *mtd, loff_t from, struct mtd_oob_ops *ops)
+{
+ struct nand_chip *chip = mtd->priv;
+ int ret = -ENOTSUPP;
+
+ ops->retlen = 0;
+
+ /* Do not allow reads past end of device */
+ if (ops->datbuf && (from + ops->len) > mtd->size) {
+ printf("%s: Attempt read beyond end of device\n", __func__);
+ return -EINVAL;
+ }
+
+ ca_nand_get_device(chip, mtd, FL_READING);
+
+ switch (ops->mode) {
+ case MTD_OPS_PLACE_OOB:
+ case MTD_OPS_AUTO_OOB:
+ case MTD_OPS_RAW:
+ break;
+
+ default:
+ goto out;
+ }
+
+#ifdef CONFIG_NAND_HIDE_BAD
+ acc_phy_offset = 1;
+#endif
+
+ if (!ops->datbuf)
+ ret = ca_nand_do_read_oob(mtd, from, ops);
+ else
+ ret = ca_nand_do_read_ops(mtd, from, ops);
+
+#ifdef CONFIG_NAND_HIDE_BAD
+ acc_phy_offset = 0;
+#endif
+
+ out:
+ ca_nand_release_device(mtd);
+
+ return ret;
+}
+
+/*
+ * ca_nand_write - [MTD Interface] NAND write with ECC
+ * @mtd: MTD device structure
+ * @to: offset to write to
+ * @len: number of bytes to write
+ * @retlen: pointer to variable to store the number of written bytes
+ * @buf: the data to write
+ *
+ * NAND write with ECC
+ */
+int ca_nand_write(struct mtd_info *mtd, loff_t to, size_t len, size_t *retlen,
+ const u8 *buf)
+{
+ struct nand_chip *chip = mtd->priv;
+ struct mtd_oob_ops ops;
+ int ret;
+
+ /* Do not allow reads past end of device */
+ if ((to + len) > mtd->size)
+ return -EINVAL;
+ if (!len)
+ return 0;
+
+ ca_nand_get_device(chip, mtd, FL_WRITING);
+
+ ops.len = len;
+ ops.datbuf = (u8 *)buf;
+ ops.oobbuf = NULL;
+ ops.mode = MTD_OPS_PLACE_OOB;
+
+ ret = ca_nand_do_write_ops(mtd, to, &ops);
+
+ *retlen = ops.retlen;
+
+ ca_nand_release_device(mtd);
+
+ return ret;
+}
+
+/*
+ * ca_nand_do_read_ops - [Internal] Read data with ECC
+ *
+ * @mtd: MTD device structure
+ * @from: offset to read from
+ * @ops: oob ops structure
+ *
+ * Internal function. Called with chip held.
+ */
+static int ca_nand_do_read_ops(struct mtd_info *mtd, loff_t from,
+ struct mtd_oob_ops *ops)
+{
+ int chipnr, page, realpage, col, bytes, aligned;
+ struct nand_chip *chip = mtd->priv;
+ struct mtd_ecc_stats stats;
+ int sndcmd = 1;
+ int ret = 0;
+ u32 readlen = ops->len;
+ u32 oobreadlen = ops->ooblen;
+ u8 *bufpoi, *oob, *buf;
+
+ memcpy(&stats, &mtd->ecc_stats, sizeof(struct mtd_ecc_stats));
+
+ chipnr = (int)(from >> chip->chip_shift);
+ chip->select_chip(mtd, chipnr);
+
+ realpage = (int)(from >> chip->page_shift);
+ page = realpage & chip->pagemask;
+
+ col = (int)(from & (mtd->writesize - 1));
+
+ buf = ops->datbuf;
+ oob = ops->oobbuf;
+
+ while (1) {
+ bytes = min(mtd->writesize - col, readlen);
+ aligned = (bytes == mtd->writesize);
+
+#ifdef CONFIG_NAND_HIDE_BAD
+ if (!acc_phy_offset)
+ page = xlat_offset_to_skip_bad(mtd, page);
+#endif
+
+ /* Is the current page in the buffer ? */
+ if (realpage != chip->pagebuf || oob) {
+ bufpoi = aligned ? buf : chip->buffers->databuf;
+
+ if (likely(sndcmd)) {
+ chip->cmdfunc(mtd, NAND_CMD_READ0, 0x00, page);
+ sndcmd = 0;
+ }
+
+ /* Now read the page into the buffer */
+ if (unlikely(ops->mode == MTD_OPS_RAW))
+ ret =
+ chip->ecc.read_page_raw(mtd, chip, bufpoi,
+ 0, page);
+ else if (!aligned && NAND_HAS_SUBPAGE_READ(chip) &&
+ !oob)
+ ret =
+ chip->ecc.read_subpage(mtd, chip, col,
+ bytes, bufpoi, page);
+ else
+ ret =
+ chip->ecc.read_page(mtd, chip, bufpoi, 1,
+ page);
+ if (ret < 0)
+ break;
+
+ /* Transfer not aligned data */
+ if (!aligned) {
+ if (!NAND_HAS_SUBPAGE_READ(chip) && !oob)
+ chip->pagebuf = realpage;
+ memcpy(buf, chip->buffers->databuf + col,
+ bytes);
+ }
+
+ buf += bytes;
+
+ if (unlikely(oob)) {
+ /* Raw mode does data:oob:data:oob */
+ if (ops->mode != MTD_OPS_RAW) {
+ int toread =
+ min(oobreadlen,
+ chip->ecc.layout->oobavail);
+ if (toread) {
+ oob =
+ ca_nand_xfer_oob(chip,
+ oob,
+ ops,
+ toread);
+ oobreadlen -= toread;
+ }
+ } else {
+ buf =
+ ca_nand_xfer_oob(chip, oob, ops,
+ mtd->oobsize);
+ }
+ }
+
+ if (!(chip->options & NAND_NEED_READRDY)) {
+ /*
+ * Apply delay or wait for ready/busy pin. Do
+ * this before the AUTOINCR check, so no
+ * problems arise if a chip which does auto
+ * increment is marked as NOAUTOINCR by the
+ * board driver.
+ */
+ if (!chip->dev_ready)
+ udelay(chip->chip_delay);
+ else
+ ca_nand_wait_ready(mtd);
+ }
+ } else {
+ memcpy(buf, chip->buffers->databuf + col, bytes);
+ buf += bytes;
+ }
+
+ readlen -= bytes;
+
+ if (!readlen)
+ break;
+
+ /* For subsequent reads align to page boundary. */
+ col = 0;
+ /* Increment page address */
+ realpage++;
+
+ page = realpage & chip->pagemask;
+ /* Check, if we cross a chip boundary */
+ if (!page) {
+ chipnr++;
+ chip->select_chip(mtd, -1);
+ chip->select_chip(mtd, chipnr);
+ }
+ }
+
+ ops->retlen = ops->len - (size_t)readlen;
+ if (oob)
+ ops->oobretlen = ops->ooblen - oobreadlen;
+
+ if (ret)
+ return ret;
+
+ if (mtd->ecc_stats.failed - stats.failed)
+ return -EBADMSG;
+
+ return mtd->ecc_stats.corrected - stats.corrected ? -EUCLEAN : 0;
+}
+
+/*
+ * ca_nand_read - [MTD Interface] MTD compatibility func. for nand_do_read_ecc
+ * @mtd: MTD device structure
+ * @from: offset to read from
+ * @len: number of bytes to read
+ * @retlen: pointer to variable to store the number of read bytes
+ * @buf: the databuffer to put data
+ *
+ * Get hold of the chip and call nand_do_read
+ */
+
+int ca_nand_read(struct mtd_info *mtd, loff_t from, size_t len, size_t *retlen,
+ u8 *buf)
+{
+ struct nand_chip *chip = mtd->priv;
+ struct mtd_oob_ops ops;
+ int ret;
+
+ /* Do not allow reads past end of device */
+ if ((from + len) > mtd->size)
+ return -EINVAL;
+ if (!len)
+ return 0;
+
+ ca_nand_get_device(chip, mtd, FL_READING);
+
+ ops.len = len;
+ ops.datbuf = buf;
+ ops.oobbuf = NULL;
+ ops.mode = MTD_OPS_PLACE_OOB;
+
+ ret = ca_nand_do_read_ops(mtd, from, &ops);
+
+ *retlen = ops.retlen;
+
+ ca_nand_release_device(mtd);
+
+ return ret;
+}
+
+/*
+ * ca_nand_erase_block - [GENERIC] erase a block
+ * @mtd: MTD device structure
+ * @page: page address
+ *
+ * Erase a block.
+ */
+
+int ca_nand_erase_block(struct mtd_info *mtd, int page)
+{
+ struct nand_chip *this = mtd->priv;
+ u64 test;
+ union FLASH_FLASH_ACCESS_START_t tmp_access;
+
+ check_flash_ctrl_status();
+
+ /* Send commands to erase a page */
+ write_flash_ctrl_reg(FLASH_NF_ECC_CONTROL, 0); //
+
+ nf_cnt.wrd = 0;
+ nf_cmd.wrd = 0;
+ nf_addr1.wrd = 0;
+ nf_cnt.bf.nflashregoobcount = NCNT_EMPTY_OOB;
+ nf_cnt.bf.nflashregdatacount = NCNT_EMPTY_DATA;
+ nf_cnt.bf.nflashregcmdcount = NCNT_CMD_2;
+
+ test = 0x10000 * mtd->writesize;
+ if (this->chipsize > test)
+ nf_cnt.bf.nflashregaddrcount = NCNT_ADDR_3;
+ else
+ nf_cnt.bf.nflashregaddrcount = NCNT_ADDR_2;
+
+ nf_cmd.bf.nflashregcmd0 = NAND_CMD_ERASE1;
+ nf_cmd.bf.nflashregcmd1 = NAND_CMD_ERASE2;
+ nf_addr1.wrd = page;
+ nf_addr2.wrd = 0;
+ write_flash_ctrl_reg(FLASH_NF_COUNT, nf_cnt.wrd);
+ write_flash_ctrl_reg(FLASH_NF_COMMAND, nf_cmd.wrd);
+ write_flash_ctrl_reg(FLASH_NF_ADDRESS_1, nf_addr1.wrd);
+ write_flash_ctrl_reg(FLASH_NF_ADDRESS_2, nf_addr2.wrd);
+
+ nf_access.wrd = 0;
+ nf_access.bf.nflashcealt = CHIP_EN;
+ nf_access.bf.nflashregwidth = NFLASH_WIDTH8;
+
+ write_flash_ctrl_reg(FLASH_NF_ACCESS, nf_access.wrd);
+ flash_start.wrd = 0;
+ flash_start.bf.nflashregreq = FLASH_GO;
+ flash_start.bf.nflashregcmd = FLASH_RD; //no data access use read..
+ write_flash_ctrl_reg(FLASH_FLASH_ACCESS_START, flash_start.wrd);
+ flash_start.wrd = read_flash_ctrl_reg(FLASH_FLASH_ACCESS_START);
+ tmp_access.wrd = 0;
+ tmp_access.bf.nflashregreq = 1;
+ reg_wait(FLASH_FLASH_ACCESS_START, tmp_access.wrd, 0, 1000);
+
+ return 0;
+}
+
+/*
+ * ca_nand_block_checkbad - [GENERIC] Check if a block is marked bad
+ * @mtd: MTD device structure
+ * @ofs: offset from device start
+ * @getchip: 0, if the chip is already selected
+ * @allowbbt: 1, if its allowed to access the bbt area
+ *
+ * Check, if the block is bad. Either by reading the bad block table or
+ * calling of the scan function.
+ */
+static int ca_nand_block_checkbad(struct mtd_info *mtd, loff_t ofs, int getchip,
+ int allowbbt)
+{
+ struct nand_chip *chip = mtd->priv;
+
+ if (!chip->bbt)
+ return chip->block_bad(mtd, ofs);
+
+ /* Return info from the table */
+ return nand_isbad_bbt(mtd, ofs, allowbbt);
+}
+
+/*
+ * ca_nand_erase - [MTD Interface] erase block(s)
+ * @mtd: MTD device structure
+ * @instr: erase instruction
+ *
+ * Erase one ore more blocks
+ */
+int ca_nand_erase(struct mtd_info *mtd, struct erase_info *instr)
+{
+ int rc;
+
+ rc = ca_nand_erase_nand(mtd, instr, 0);
+
+ return rc;
+}
+
+/*
+ * ca_nand_erase_nand - [Internal] erase block(s)
+ * @mtd: MTD device structure
+ * @instr: erase instruction
+ * @allowbbt: allow erasing the bbt area
+ *
+ * Erase one ore more blocks
+ */
+static int ca_nand_erase_nand(struct mtd_info *mtd, struct erase_info *instr,
+ int allowbbt)
+{
+ int page, status, pages_per_block, ret, chipnr;
+ struct nand_chip *chip = mtd->priv;
+ unsigned int bbt_masked_page = 0xffffffff;
+ loff_t len;
+
+#ifdef DEBUG
+ printf("%s: start = 0x%012llx, len = %llu\n",
+ __func__, (unsigned long long)instr->addr,
+ (unsigned long long)instr->len);
+#endif
+
+ /* Start address must align on block boundary */
+ if (instr->addr & ((1 << chip->phys_erase_shift) - 1)) {
+ printf("%s: Unaligned address\n", __func__);
+ printf("unaligned_chipptr!!!");
+ return -EINVAL;
+ }
+
+ /* Length must align on block boundary */
+ if (instr->len & ((1 << chip->phys_erase_shift) - 1)) {
+ printf("%s: Length not block aligned\n", __func__);
+ return -EINVAL;
+ }
+
+ /* Do not allow erase past end of device */
+ if ((instr->len + instr->addr) > mtd->size) {
+ printf("%s: Erase past end of device\n", __func__);
+ return -EINVAL;
+ }
+
+ instr->fail_addr = MTD_FAIL_ADDR_UNKNOWN;
+
+ /* Grab the lock and see if the device is available */
+ ca_nand_get_device(chip, mtd, FL_ERASING);
+
+ /* Shift to get first page */
+ page = (int)(instr->addr >> chip->page_shift);
+ chipnr = (int)(instr->addr >> chip->chip_shift);
+
+#ifdef CONFIG_NAND_HIDE_BAD
+ int input_addr = page;
+#endif
+
+ /* Calculate pages in each block */
+ pages_per_block = 1 << (chip->phys_erase_shift - chip->page_shift);
+
+ /* Select the NAND device */
+ chip->select_chip(mtd, chipnr);
+
+ /* Check, if it is write protected */
+ if (ca_nand_check_wp(mtd)) {
+ printf("%s: Device is write protected!!!\n", __func__);
+ instr->state = MTD_ERASE_FAILED;
+ goto erase_exit;
+ }
+
+ /*
+ * If BBT requires refresh, set the BBT page mask to see if the BBT
+ * should be rewritten. Otherwise the mask is set to 0xffffffff which
+ * can not be matched. This is also done when the bbt is actually
+ * erased to avoid recusrsive updates
+ */
+ //Jason if (chip->options & BBT_AUTO_REFRESH && !allowbbt)
+ // bbt_masked_page = chip->bbt_td->pages[chipnr] & BBT_PAGE_MASK;
+
+ /* Loop through the pages */
+ len = instr->len;
+
+ instr->state = MTD_ERASING;
+
+ while (len) {
+#ifdef CONFIG_NAND_HIDE_BAD
+ if (!instr->scrub) {
+ page = xlat_offset_to_skip_bad(mtd, input_addr);
+ input_addr += pages_per_block;
+ }
+#endif
+
+ /*
+ * Invalidate the page cache, if we erase the block which
+ * contains the current cached page
+ */
+ if (page <= chip->pagebuf &&
+ chip->pagebuf < (page + pages_per_block))
+ chip->pagebuf = -1;
+
+ //chip->erase_cmd(mtd, page & chip->pagemask);
+ ca_nand_erase_block(mtd, page);
+
+ status = chip->waitfunc(mtd, chip);
+
+ /* See if block erase succeeded */
+ if (status & NAND_STATUS_FAIL) {
+ printf("%s: Failed erase, page 0x%08x\n", __func__,
+ page);
+ instr->state = MTD_ERASE_FAILED;
+ instr->fail_addr = ((loff_t)page << chip->page_shift);
+ goto erase_exit;
+ }
+#ifdef CONFIG_NAND_HIDE_BAD
+ if (instr->scrub)
+ update_bad_block_list(page << chip->page_shift, 0);
+#endif
+
+ /* Increment page address and decrement length */
+ len -= (1 << chip->phys_erase_shift);
+ page += pages_per_block;
+
+ /* Check, if we cross a chip boundary */
+ if (len && !(page & chip->pagemask)) {
+ chipnr++;
+ chip->select_chip(mtd, -1);
+ chip->select_chip(mtd, chipnr);
+
+ /*
+ * If BBT requires refresh and BBT-PERCHIP, set the BBT
+ * page mask to see if this BBT should be rewritten
+ */
+ if (bbt_masked_page != 0xffffffff &&
+ (chip->bbt_td->options & NAND_BBT_PERCHIP))
+ bbt_masked_page =
+ chip->bbt_td->pages[chipnr] & BBT_PAGE_MASK;
+ }
+ }
+ instr->state = MTD_ERASE_DONE;
+
+ erase_exit:
+
+ ret = instr->state == MTD_ERASE_DONE ? 0 : -EIO;
+
+ /* Deselect and wake up anyone waiting on the device */
+ ca_nand_release_device(mtd);
+
+ /* Do call back function */
+ if (!ret)
+ mtd_erase_callback(instr);
+
+ /*
+ * If BBT requires refresh and erase was successful, rewrite any
+ * selected bad block tables
+ */
+ if (bbt_masked_page == 0xffffffff || ret)
+ return ret;
+
+ /* Return more or less happy */
+ return ret;
+}
+
+/*
+ * ca_nand_write_oob_std - [REPLACEABLE] the most common OOB data write function
+ * @mtd: mtd info structure
+ * @chip: nand chip info structure
+ * @page: page number to write
+ */
+int ca_nand_write_oob_std(struct mtd_info *mtd, struct nand_chip *chip,
+ int page)
+{
+ int status = 0, i;
+ union FLASH_FLASH_ACCESS_START_t tmp_access;
+ //const u8 *buf = chip->oob_poi;
+ //int length = mtd->oobsize;
+
+ check_flash_ctrl_status();
+
+ chip->cmdfunc(mtd, NAND_CMD_SEQIN, mtd->writesize, page);
+ //chip->write_buf(mtd, buf, length);
+ /* Send command to program the OOB data */
+ chip->cmdfunc(mtd, NAND_CMD_PAGEPROG, -1, -1);
+
+ //disable ecc gen
+ write_flash_ctrl_reg(FLASH_NF_ECC_CONTROL, 0x0);
+
+ nf_cmd.wrd = 0;
+ nf_addr1.wrd = 0;
+ nf_cnt.wrd = 0;
+ nf_cnt.bf.nflashregoobcount = mtd->oobsize - 1;
+ nf_cnt.bf.nflashregdatacount = NCNT_EMPTY_DATA;
+
+ nf_addr2.wrd = 0;
+
+ if (chip->chipsize < SZ_32M) {
+ nf_cnt.bf.nflashregaddrcount = NCNT_ADDR_3;
+
+ if (mtd->writesize > NCNT_512P_DATA) {
+ nf_cnt.bf.nflashregcmdcount = NCNT_CMD_2;
+ nf_cmd.bf.nflashregcmd0 = NAND_CMD_SEQIN;
+ nf_cmd.bf.nflashregcmd1 = NAND_CMD_PAGEPROG;
+ } else {
+ nf_cnt.bf.nflashregcmdcount = NCNT_CMD_3;
+ nf_cmd.bf.nflashregcmd0 = NAND_CMD_READOOB; //??
+ nf_cmd.bf.nflashregcmd1 = NAND_CMD_SEQIN;
+ nf_cmd.bf.nflashregcmd2 = NAND_CMD_PAGEPROG;
+ }
+ //read oob need to add page data size to match correct oob ddress
+ nf_addr1.wrd = (((page & 0x00ffffff) << 8));
+ nf_addr2.wrd = ((page & 0xff000000) >> 24);
+ } else if (chip->chipsize <= SZ_128M) {
+ nf_cnt.bf.nflashregaddrcount = NCNT_ADDR_4;
+ nf_cnt.bf.nflashregcmdcount = NCNT_CMD_2;
+ nf_cmd.bf.nflashregcmd0 = NAND_CMD_SEQIN;
+ nf_cmd.bf.nflashregcmd1 = NAND_CMD_PAGEPROG;
+ nf_addr1.wrd =
+ (((page & 0xffff) << 16) + (mtd->writesize & 0xffff));
+ nf_addr2.wrd = ((page & 0xffff0000) >> 16);
+
+ } else { //if((chip->chipsize > (128 << 20)) ))
+ nf_cnt.bf.nflashregaddrcount = NCNT_ADDR_5;
+ nf_cnt.bf.nflashregcmdcount = NCNT_CMD_2;
+ nf_cmd.bf.nflashregcmd0 = NAND_CMD_SEQIN;
+ nf_cmd.bf.nflashregcmd1 = NAND_CMD_PAGEPROG;
+ nf_addr1.wrd =
+ (((page & 0xffff) << 16) + (mtd->writesize & 0xffff));
+ nf_addr2.wrd = ((page & 0xffff0000) >> 16);
+ }
+
+ write_flash_ctrl_reg(FLASH_NF_COUNT, nf_cnt.wrd);
+ //write read id command
+ write_flash_ctrl_reg(FLASH_NF_COMMAND, nf_cmd.wrd);
+ //write address 0x0
+ write_flash_ctrl_reg(FLASH_NF_ADDRESS_1, nf_addr1.wrd);
+ write_flash_ctrl_reg(FLASH_NF_ADDRESS_2, nf_addr2.wrd);
+
+ pwrite = (unsigned int *)chip->oob_poi;
+
+ for (i = 0; i < ((mtd->oobsize / 4)); i++) {
+ nf_access.wrd = 0;
+ nf_access.bf.nflashcealt = CHIP_EN;
+ //nf_access.bf.nflashDirWr = ;
+ nf_access.bf.nflashregwidth = NFLASH_WIDTH32;
+ write_flash_ctrl_reg(FLASH_NF_ACCESS, nf_access.wrd);
+
+ write_flash_ctrl_reg(FLASH_NF_DATA, pwrite[i]);
+
+ flash_start.wrd = 0;
+ flash_start.bf.nflashregreq = FLASH_GO;
+ flash_start.bf.nflashregcmd = FLASH_WT;
+ //flash_start.bf.nflash_random_access = RND_ENABLE;
+ write_flash_ctrl_reg(FLASH_FLASH_ACCESS_START, flash_start.wrd);
+
+ tmp_access.wrd = 0;
+ tmp_access.bf.nflashregreq = 1;
+ reg_wait(FLASH_FLASH_ACCESS_START, tmp_access.wrd, 0, 1000);
+ }
+
+ check_flash_ctrl_status();
+
+ status = chip->waitfunc(mtd, chip);
+
+ return status & NAND_STATUS_FAIL ? -EIO : 0;
+}
+
+/*
+ * ca_nand_read_oob_std - [REPLACEABLE] the most common OOB data read function
+ * @mtd: mtd info structure
+ * @chip: nand chip info structure
+ * @page: page number to read
+ * @sndcmd: flag whether to issue read command or not
+ */
+int ca_nand_read_oob_std(struct mtd_info *mtd, struct nand_chip *chip, int page)
+{
+ int i;
+ union FLASH_FLASH_ACCESS_START_t tmp_access;
+
+ check_flash_ctrl_status();
+
+ //disable ecc gen
+ write_flash_ctrl_reg(FLASH_NF_ECC_CONTROL, 0x0);
+
+ nf_cmd.wrd = 0;
+ nf_addr1.wrd = 0;
+ nf_addr2.wrd = 0;
+ nf_cnt.wrd = 0;
+ nf_cnt.bf.nflashregoobcount = mtd->oobsize - 1;
+ nf_cnt.bf.nflashregdatacount = NCNT_EMPTY_DATA;
+
+ if (chip->chipsize < (32 << 20)) {
+ nf_cnt.bf.nflashregaddrcount = NCNT_ADDR_3;
+ nf_cnt.bf.nflashregcmdcount = NCNT_CMD_1;
+ if (mtd->writesize > NCNT_512P_DATA)
+ nf_cmd.bf.nflashregcmd0 = NAND_CMD_READ0;
+ else
+ nf_cmd.bf.nflashregcmd0 = NAND_CMD_READOOB;
+
+ nf_addr1.wrd = ((page & 0x00ffffff) << 8);
+ nf_addr2.wrd = ((page & 0xff000000) >> 24);
+ } else if ((chip->chipsize >= (32 << 20)) &&
+ (chip->chipsize <= (128 << 20))) {
+ nf_cnt.bf.nflashregaddrcount = NCNT_ADDR_4;
+ nf_cnt.bf.nflashregcmdcount = NCNT_CMD_1;
+ nf_cmd.bf.nflashregcmd0 = NAND_CMD_READ0;
+
+ // Jeneng
+ if (mtd->writesize > NCNT_512P_DATA) {
+ nf_cnt.bf.nflashregcmdcount = NCNT_CMD_2;
+ nf_cmd.bf.nflashregcmd1 = NAND_CMD_READSTART;
+ }
+ nf_addr1.wrd =
+ (((page & 0xffff) << 16) + (mtd->writesize & 0xffff));
+ nf_addr2.wrd = ((page & 0xffff0000) >> 16);
+ } else { //if((chip->chipsize > (128 << 20)) ))
+ nf_cnt.bf.nflashregaddrcount = NCNT_ADDR_5;
+ nf_cnt.bf.nflashregcmdcount = NCNT_CMD_2;
+ nf_cmd.bf.nflashregcmd0 = NAND_CMD_READ0;
+ nf_cmd.bf.nflashregcmd1 = NAND_CMD_READSTART;
+ nf_addr1.wrd =
+ (((page & 0xffff) << 16) + (mtd->writesize & 0xffff));
+ nf_addr2.wrd = ((page & 0xffff0000) >> 16);
+ }
+
+ write_flash_ctrl_reg(FLASH_NF_COUNT, nf_cnt.wrd);
+ //write read id command
+ write_flash_ctrl_reg(FLASH_NF_COMMAND, nf_cmd.wrd);
+ //write address 0x0
+ write_flash_ctrl_reg(FLASH_NF_ADDRESS_1, nf_addr1.wrd);
+ write_flash_ctrl_reg(FLASH_NF_ADDRESS_2, nf_addr2.wrd);
+
+ pread = (unsigned int *)chip->oob_poi;
+
+ for (i = 0; i < mtd->oobsize / 4; i++) {
+ nf_access.wrd = 0;
+ nf_access.bf.nflashcealt = CHIP_EN;
+ //nf_access.bf.nflashDirWr = ;
+ nf_access.bf.nflashregwidth = NFLASH_WIDTH32;
+ write_flash_ctrl_reg(FLASH_NF_ACCESS, nf_access.wrd);
+
+ flash_start.wrd = 0;
+ flash_start.bf.nflashregreq = FLASH_GO;
+ flash_start.bf.nflashregcmd = FLASH_RD;
+ //flash_start.bf.nflash_random_access = RND_ENABLE;
+ write_flash_ctrl_reg(FLASH_FLASH_ACCESS_START, flash_start.wrd);
+
+ flash_start.wrd = read_flash_ctrl_reg(FLASH_FLASH_ACCESS_START);
+
+ tmp_access.wrd = 0;
+ tmp_access.bf.nflashregreq = 1;
+ reg_wait(FLASH_FLASH_ACCESS_START, tmp_access.wrd, 0, 1000);
+
+ pread[i] = read_flash_ctrl_reg(FLASH_NF_DATA);
+ }
+ return 0;
+}
+
+/*
+ * ca_nand_write_page_hwecc - [REPLACEABLE] HW ecc based page write function
+ * @mtd: mtd info structure
+ * @chip: nand chip info structure
+ * @buf: data buffer
+ */
+int ca_nand_write_page_hwecc(struct mtd_info *mtd, struct nand_chip *chip,
+ const u8 *buf, int oob_required, int page)
+{
+ int i, j, __attribute__ ((unused)) eccsize = chip->ecc.size;
+ int eccbytes = chip->ecc.bytes;
+ int eccsteps = chip->ecc.steps;
+ /*u8 *ecc_calc = chip->buffers->ecccalc; */
+ /*const u8 *p = buf; */
+ u32 *eccpos =
+ chip->ecc.layout->eccpos, *addr,
+ __attribute__ ((unused)) reg_bch_gen;
+ union DMA_SEC_DMA_SSP_Q_RXQ_COAL_INTERRUPT_t tmp_dma_ssp_rxq5_intsts;
+ union DMA_SEC_DMA_SSP_Q_TXQ_COAL_INTERRUPT_t tmp_dma_ssp_txq5_intsts;
+ union FLASH_FLASH_ACCESS_START_t tmp_access;
+#ifdef CONFIG_NAND_CORTINA_ECC_HW_BCH
+ union FLASH_NF_BCH_STATUS_t tmp_bsc_sts;
+#else
+ union FLASH_NF_ECC_STATUS_t tmp_ecc_sts;
+#endif
+ union FLASH_FIFO_CONTROL_t flash_fifo_ctrl;
+
+ check_flash_ctrl_status();
+
+ //page = host->page_addr;
+
+ ecc_reset.wrd = 3;
+ ecc_reset.bf.eccclear = ECC_CLR;
+ ecc_reset.bf.fifoclear = FIFO_CLR;
+ write_flash_ctrl_reg(FLASH_NF_ECC_RESET, ecc_reset.wrd);
+
+ flash_int_sts.bf.regirq = 1;
+ write_flash_ctrl_reg(FLASH_FLASH_INTERRUPT, flash_int_sts.wrd);
+
+ ecc_reset.wrd = 0;
+ ecc_reset.bf.eccclear = 1;
+ write_flash_ctrl_reg(FLASH_NF_ECC_RESET, ecc_reset.wrd);
+
+#ifdef CONFIG_NAND_CORTINA_ECC_HW_BCH
+ bch_ctrl.wrd = 0;
+ bch_ctrl.bf.bchen = BCH_ENABLE;
+ bch_ctrl.bf.bchopcode = BCH_ENCODE;
+#if (CONFIG_NAND_CORTINA_ECC_LEVEL == 2)
+ bch_ctrl.bf.bcherrcap = BCH_ERR_CAP_8;
+#elif (CONFIG_NAND_CORTINA_ECC_LEVEL == 3)
+ bch_ctrl.bf.bcherrcap = BCH_ERR_CAP_16;
+#elif (CONFIG_NAND_CORTINA_ECC_LEVEL == 4)
+ bch_ctrl.bf.bcherrcap = BCH_ERR_CAP_24;
+#elif (CONFIG_NAND_CORTINA_ECC_LEVEL == 5)
+ bch_ctrl.bf.bcherrcap = BCH_ERR_CAP_40;
+#else
+ printf("BCH Level is not recognized! %s:%d\n", __func__, __LINE__);
+#endif
+ write_flash_ctrl_reg(FLASH_NF_BCH_CONTROL, bch_ctrl.wrd);
+
+#else
+
+ ecc_ctl.wrd = 0;
+ if ((eccsize - 1) == NCNT_512P_DATA)
+ ecc_ctl.bf.eccgenmode = ECC_GEN_512;
+ else
+ ecc_ctl.bf.eccgenmode = ECC_GEN_256;
+ ecc_ctl.bf.eccen = ECC_ENABLE;
+ write_flash_ctrl_reg(FLASH_NF_ECC_CONTROL, ecc_ctl.wrd);
+#endif
+
+ /*disable txq5 */
+ dma_txq5_ctrl.bf.txq_en = 0;
+ write_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_TXQ_CONTROL, dma_txq5_ctrl.wrd);
+ /*clr tx/rx eof */
+ dma_ssp_txq5_intsts.wrd =
+ read_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_TXQ_COAL_INTERRUPT);
+ dma_ssp_txq5_intsts.bf.txq_eof = 0;
+ write_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_TXQ_COAL_INTERRUPT,
+ dma_ssp_txq5_intsts.wrd);
+ dma_ssp_rxq5_intsts.wrd =
+ read_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_RXQ_COAL_INTERRUPT);
+ dma_ssp_rxq5_intsts.bf.rxq_eof = 0;
+ write_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_RXQ_COAL_INTERRUPT,
+ dma_ssp_rxq5_intsts.wrd);
+
+ nf_cnt.wrd = 0;
+ nf_cmd.wrd = 0;
+ nf_addr1.wrd = 0;
+ nf_addr2.wrd = 0;
+ nf_cnt.wrd = 0;
+ nf_cnt.bf.nflashregoobcount = mtd->oobsize - 1;
+ nf_cnt.bf.nflashregdatacount = mtd->writesize - 1;
+
+ if (chip->chipsize < (32 << 20)) {
+ nf_cnt.bf.nflashregaddrcount = NCNT_ADDR_3;
+ nf_cnt.bf.nflashregcmdcount = NCNT_CMD_2;
+ nf_cmd.bf.nflashregcmd0 = NAND_CMD_SEQIN;
+ nf_cmd.bf.nflashregcmd1 = NAND_CMD_PAGEPROG;
+ nf_addr1.wrd = (((page & 0x00ffffff) << 8));
+ nf_addr2.wrd = ((page & 0xff000000) >> 24);
+
+ } else if ((chip->chipsize >= (32 << 20)) &&
+ (chip->chipsize <= (128 << 20))) {
+ nf_cnt.bf.nflashregaddrcount = NCNT_ADDR_4;
+ nf_cnt.bf.nflashregcmdcount = NCNT_CMD_2;
+ nf_cmd.bf.nflashregcmd0 = NAND_CMD_SEQIN;
+ nf_cmd.bf.nflashregcmd1 = NAND_CMD_PAGEPROG;
+ nf_addr1.wrd = (((page & 0xffff) << 16));
+ nf_addr2.wrd = ((page & 0xffff0000) >> 16);
+
+ } else { /*if((chip->chipsize > (128 << 20)) )) */
+
+ nf_cnt.bf.nflashregaddrcount = NCNT_ADDR_5;
+ nf_cnt.bf.nflashregcmdcount = NCNT_CMD_2;
+ nf_cmd.bf.nflashregcmd0 = NAND_CMD_SEQIN;
+ nf_cmd.bf.nflashregcmd1 = NAND_CMD_PAGEPROG;
+ nf_addr1.wrd = (((page & 0xffff) << 16));
+ nf_addr2.wrd = ((page & 0xffff0000) >> 16);
+ }
+
+ write_flash_ctrl_reg(FLASH_NF_COUNT, nf_cnt.wrd);
+ write_flash_ctrl_reg(FLASH_NF_COMMAND, nf_cmd.wrd);
+ write_flash_ctrl_reg(FLASH_NF_ADDRESS_1, nf_addr1.wrd);
+ write_flash_ctrl_reg(FLASH_NF_ADDRESS_2, nf_addr2.wrd);
+
+ /*dma_map_single( NULL, (void *)buf, mtd->writesize, DMA_TO_DEVICE); */
+
+ nf_access.wrd = 0;
+ nf_access.bf.nflashcealt = CHIP_EN;
+ nf_access.bf.nflashregwidth = NFLASH_WIDTH8;
+ nf_access.bf.nflashextaddr = ((page << chip->page_shift) / 0x8000000);
+ write_flash_ctrl_reg(FLASH_NF_ACCESS, nf_access.wrd);
+
+ addr =
+ (unsigned int *)(((unsigned long)page << chip->page_shift) %
+ 0x8000000);
+ addr =
+ (unsigned int *)((unsigned long)addr +
+ (unsigned long)(CONFIG_SYS_FLASH_BASE));
+
+ /*page data tx desc */
+ dma_txq5_wptr.wrd = read_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_TXQ_WPTR);
+ tx_desc[dma_txq5_wptr.bf.index].word1.bf.own = OWN_DMA;
+ tx_desc[dma_txq5_wptr.bf.index].word1.bf.buf_len = mtd->writesize;
+ tx_desc[dma_txq5_wptr.bf.index].buf_adr = (unsigned long)buf;
+
+ dma_rxq5_rptr.wrd = read_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_RXQ_RPTR);
+ rx_desc[dma_rxq5_rptr.bf.index].word1.bf.own = OWN_DMA;
+ rx_desc[dma_rxq5_rptr.bf.index].word1.bf.buf_len = mtd->writesize;
+ rx_desc[dma_rxq5_rptr.bf.index].buf_adr = (unsigned long)addr;
+
+ /*oob rx desc */
+ addr = (unsigned int *)((unsigned long)addr + mtd->writesize);
+
+ dma_rxq5_rptr.bf.index = (dma_rxq5_rptr.bf.index + 1) % FDMA_DESC_NUM;
+ rx_desc[dma_rxq5_rptr.bf.index].word1.bf.own = OWN_DMA;
+ rx_desc[dma_rxq5_rptr.bf.index].word1.bf.buf_len = mtd->oobsize;
+ rx_desc[dma_rxq5_rptr.bf.index].buf_adr = (unsigned long)addr;
+
+ /*update page tx write ptr */
+ dma_txq5_wptr.bf.index = (dma_txq5_wptr.bf.index + 1) % FDMA_DESC_NUM;
+ write_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_TXQ_WPTR, dma_txq5_wptr.wrd);
+
+ flash_fifo_ctrl.wrd = read_flash_ctrl_reg(FLASH_FIFO_CONTROL);
+ flash_fifo_ctrl.bf.fifocmd = FIFO_CMD_WRITE;
+ write_flash_ctrl_reg(FLASH_FIFO_CONTROL, flash_fifo_ctrl.wrd);
+
+ flash_start.wrd = 0;
+ flash_start.bf.nflashfiforeq = FLASH_GO;
+ /*flash_start.bf.nflashRegCmd = FLASH_WT; */
+ write_flash_ctrl_reg(FLASH_FLASH_ACCESS_START, flash_start.wrd);
+
+ /*enable txq5 */
+ dma_txq5_ctrl.bf.txq_en = 1;
+ write_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_TXQ_CONTROL, dma_txq5_ctrl.wrd);
+
+ dma_ssp_rxq5_intsts.wrd =
+ read_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_RXQ_COAL_INTERRUPT);
+ tmp_dma_ssp_rxq5_intsts.wrd = 0;
+ tmp_dma_ssp_rxq5_intsts.bf.rxq_eof = 1;
+
+ dma_wait(DMA_SEC_DMA_SSP_Q_RXQ_COAL_INTERRUPT,
+ tmp_dma_ssp_rxq5_intsts.wrd, tmp_dma_ssp_rxq5_intsts.wrd,
+ 1000);
+
+ dma_ssp_txq5_intsts.wrd =
+ read_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_TXQ_COAL_INTERRUPT);
+ tmp_dma_ssp_txq5_intsts.wrd = 0;
+ tmp_dma_ssp_txq5_intsts.bf.txq_eof = 1;
+
+ dma_wait(DMA_SEC_DMA_SSP_Q_TXQ_COAL_INTERRUPT,
+ tmp_dma_ssp_txq5_intsts.wrd, tmp_dma_ssp_txq5_intsts.wrd,
+ 1000);
+
+ /*clr tx/rx eof */
+
+ dma_ssp_txq5_intsts.bf.txq_eof = 0;
+ write_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_TXQ_COAL_INTERRUPT,
+ dma_ssp_txq5_intsts.wrd);
+
+ dma_ssp_rxq5_intsts.bf.rxq_eof = 0;
+ write_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_RXQ_COAL_INTERRUPT,
+ dma_ssp_rxq5_intsts.wrd);
+
+#if defined(CONFIG_NAND_CORTINA_ECC_HW_BCH)
+ bch_sts.wrd = read_flash_ctrl_reg(FLASH_NF_BCH_STATUS);
+ tmp_bsc_sts.wrd = 0;
+ tmp_bsc_sts.bf.bchgendone = 1;
+
+ reg_wait(FLASH_NF_BCH_STATUS, tmp_bsc_sts.wrd, tmp_bsc_sts.wrd, 1000);
+
+ udelay(10);
+
+#else
+
+ ecc_sts.wrd = read_flash_ctrl_reg(FLASH_NF_ECC_STATUS);
+ tmp_ecc_sts.wrd = 0;
+ tmp_ecc_sts.bf.eccdone = 1;
+
+ reg_wait(FLASH_NF_ECC_STATUS, tmp_ecc_sts.wrd, tmp_ecc_sts.wrd, 1000);
+
+#endif
+
+ for (i = 0, j = 0; eccsteps; eccsteps--, i++, j += eccbytes) {
+#if defined(CONFIG_NAND_CORTINA_ECC_HW_BCH)
+
+ reg_bch_gen = read_flash_ctrl_reg(FLASH_NF_BCH_GEN0_0 + 72 * i);
+ chip->oob_poi[eccpos[j]] = reg_bch_gen & 0xff;
+ chip->oob_poi[eccpos[j + 1]] = (reg_bch_gen >> 8) & 0xff;
+ chip->oob_poi[eccpos[j + 2]] = (reg_bch_gen >> 16) & 0xff;
+ chip->oob_poi[eccpos[j + 3]] = (reg_bch_gen >> 24) & 0xff;
+ reg_bch_gen = read_flash_ctrl_reg(FLASH_NF_BCH_GEN0_1 + 72 * i);
+ chip->oob_poi[eccpos[j + 4]] = reg_bch_gen & 0xff;
+ chip->oob_poi[eccpos[j + 5]] = (reg_bch_gen >> 8) & 0xff;
+ chip->oob_poi[eccpos[j + 6]] = (reg_bch_gen >> 16) & 0xff;
+ chip->oob_poi[eccpos[j + 7]] = (reg_bch_gen >> 24) & 0xff;
+ reg_bch_gen = read_flash_ctrl_reg(FLASH_NF_BCH_GEN0_2 + 72 * i);
+ chip->oob_poi[eccpos[j + 8]] = reg_bch_gen & 0xff;
+ chip->oob_poi[eccpos[j + 9]] = (reg_bch_gen >> 8) & 0xff;
+ chip->oob_poi[eccpos[j + 10]] = (reg_bch_gen >> 16) & 0xff;
+ chip->oob_poi[eccpos[j + 11]] = (reg_bch_gen >> 24) & 0xff;
+ reg_bch_gen = read_flash_ctrl_reg(FLASH_NF_BCH_GEN0_3 + 72 * i);
+ chip->oob_poi[eccpos[j + 12]] = reg_bch_gen & 0xff;
+ chip->oob_poi[eccpos[j + 13]] = (reg_bch_gen >> 8) & 0xff;
+#if (CONFIG_NAND_CORTINA_ECC_LEVEL > 2)
+ chip->oob_poi[eccpos[j + 14]] = (reg_bch_gen >> 16) & 0xff;
+ chip->oob_poi[eccpos[j + 15]] = (reg_bch_gen >> 24) & 0xff;
+ reg_bch_gen = read_flash_ctrl_reg(FLASH_NF_BCH_GEN0_4 + 72 * i);
+ chip->oob_poi[eccpos[j + 16]] = reg_bch_gen & 0xff;
+ chip->oob_poi[eccpos[j + 17]] = (reg_bch_gen >> 8) & 0xff;
+ chip->oob_poi[eccpos[j + 18]] = (reg_bch_gen >> 16) & 0xff;
+ chip->oob_poi[eccpos[j + 19]] = (reg_bch_gen >> 24) & 0xff;
+ reg_bch_gen = read_flash_ctrl_reg(FLASH_NF_BCH_GEN0_5 + 72 * i);
+ chip->oob_poi[eccpos[j + 20]] = reg_bch_gen & 0xff;
+ chip->oob_poi[eccpos[j + 21]] = (reg_bch_gen >> 8) & 0xff;
+ chip->oob_poi[eccpos[j + 22]] = (reg_bch_gen >> 16) & 0xff;
+ chip->oob_poi[eccpos[j + 23]] = (reg_bch_gen >> 24) & 0xff;
+ reg_bch_gen = read_flash_ctrl_reg(FLASH_NF_BCH_GEN0_6 + 72 * i);
+ chip->oob_poi[eccpos[j + 24]] = reg_bch_gen & 0xff;
+ chip->oob_poi[eccpos[j + 25]] = (reg_bch_gen >> 8) & 0xff;
+ chip->oob_poi[eccpos[j + 26]] = (reg_bch_gen >> 16) & 0xff;
+ chip->oob_poi[eccpos[j + 27]] = (reg_bch_gen >> 24) & 0xff;
+
+#endif
+#if (CONFIG_NAND_CORTINA_ECC_LEVEL > 3)
+ reg_bch_gen = read_flash_ctrl_reg(FLASH_NF_BCH_GEN0_7 + 72 * i);
+ chip->oob_poi[eccpos[j + 28]] = reg_bch_gen & 0xff;
+ chip->oob_poi[eccpos[j + 29]] = (reg_bch_gen >> 8) & 0xff;
+ chip->oob_poi[eccpos[j + 30]] = (reg_bch_gen >> 16) & 0xff;
+ chip->oob_poi[eccpos[j + 31]] = (reg_bch_gen >> 24) & 0xff;
+ reg_bch_gen = read_flash_ctrl_reg(FLASH_NF_BCH_GEN0_8 + 72 * i);
+ chip->oob_poi[eccpos[j + 32]] = reg_bch_gen & 0xff;
+ chip->oob_poi[eccpos[j + 33]] = (reg_bch_gen >> 8) & 0xff;
+ chip->oob_poi[eccpos[j + 34]] = (reg_bch_gen >> 16) & 0xff;
+ chip->oob_poi[eccpos[j + 35]] = (reg_bch_gen >> 24) & 0xff;
+ reg_bch_gen = read_flash_ctrl_reg(FLASH_NF_BCH_GEN0_9 + 72 * i);
+ chip->oob_poi[eccpos[j + 36]] = reg_bch_gen & 0xff;
+ chip->oob_poi[eccpos[j + 37]] = (reg_bch_gen >> 8) & 0xff;
+ chip->oob_poi[eccpos[j + 38]] = (reg_bch_gen >> 16) & 0xff;
+ chip->oob_poi[eccpos[j + 39]] = (reg_bch_gen >> 24) & 0xff;
+ reg_bch_gen =
+ read_flash_ctrl_reg(FLASH_NF_BCH_GEN0_10 + 72 * i);
+ chip->oob_poi[eccpos[j + 40]] = reg_bch_gen & 0xff;
+ chip->oob_poi[eccpos[j + 41]] = (reg_bch_gen >> 8) & 0xff;
+#endif
+#if (CONFIG_NAND_CORTINA_ECC_LEVEL > 4)
+ chip->oob_poi[eccpos[j + 42]] = (reg_bch_gen >> 16) & 0xff;
+ chip->oob_poi[eccpos[j + 43]] = (reg_bch_gen >> 24) & 0xff;
+ reg_bch_gen =
+ read_flash_ctrl_reg(FLASH_NF_BCH_GEN0_11 + 72 * i);
+ chip->oob_poi[eccpos[j + 44]] = reg_bch_gen & 0xff;
+ chip->oob_poi[eccpos[j + 45]] = (reg_bch_gen >> 8) & 0xff;
+ chip->oob_poi[eccpos[j + 46]] = (reg_bch_gen >> 16) & 0xff;
+ chip->oob_poi[eccpos[j + 47]] = (reg_bch_gen >> 24) & 0xff;
+ reg_bch_gen =
+ read_flash_ctrl_reg(FLASH_NF_BCH_GEN0_12 + 72 * i);
+ chip->oob_poi[eccpos[j + 48]] = reg_bch_gen & 0xff;
+ chip->oob_poi[eccpos[j + 49]] = (reg_bch_gen >> 8) & 0xff;
+ chip->oob_poi[eccpos[j + 50]] = (reg_bch_gen >> 16) & 0xff;
+ chip->oob_poi[eccpos[j + 51]] = (reg_bch_gen >> 24) & 0xff;
+ reg_bch_gen =
+ read_flash_ctrl_reg(FLASH_NF_BCH_GEN0_13 + 72 * i);
+ chip->oob_poi[eccpos[j + 52]] = reg_bch_gen & 0xff;
+ chip->oob_poi[eccpos[j + 53]] = (reg_bch_gen >> 8) & 0xff;
+ chip->oob_poi[eccpos[j + 54]] = (reg_bch_gen >> 16) & 0xff;
+ chip->oob_poi[eccpos[j + 55]] = (reg_bch_gen >> 24) & 0xff;
+ reg_bch_gen =
+ read_flash_ctrl_reg(FLASH_NF_BCH_GEN0_14 + 72 * i);
+ chip->oob_poi[eccpos[j + 56]] = reg_bch_gen & 0xff;
+ chip->oob_poi[eccpos[j + 57]] = (reg_bch_gen >> 8) & 0xff;
+ chip->oob_poi[eccpos[j + 58]] = (reg_bch_gen >> 16) & 0xff;
+ chip->oob_poi[eccpos[j + 59]] = (reg_bch_gen >> 24) & 0xff;
+ reg_bch_gen =
+ read_flash_ctrl_reg(FLASH_NF_BCH_GEN0_15 + 72 * i);
+ chip->oob_poi[eccpos[j + 60]] = reg_bch_gen & 0xff;
+ chip->oob_poi[eccpos[j + 61]] = (reg_bch_gen >> 8) & 0xff;
+ chip->oob_poi[eccpos[j + 62]] = (reg_bch_gen >> 16) & 0xff;
+ chip->oob_poi[eccpos[j + 63]] = (reg_bch_gen >> 24) & 0xff;
+ reg_bch_gen =
+ read_flash_ctrl_reg(FLASH_NF_BCH_GEN0_16 + 72 * i);
+ chip->oob_poi[eccpos[j + 64]] = reg_bch_gen & 0xff;
+ chip->oob_poi[eccpos[j + 65]] = (reg_bch_gen >> 8) & 0xff;
+ chip->oob_poi[eccpos[j + 66]] = (reg_bch_gen >> 16) & 0xff;
+ chip->oob_poi[eccpos[j + 67]] = (reg_bch_gen >> 24) & 0xff;
+ reg_bch_gen =
+ read_flash_ctrl_reg(FLASH_NF_BCH_GEN0_17 + 72 * i);
+ chip->oob_poi[eccpos[j + 68]] = reg_bch_gen & 0xff;
+ chip->oob_poi[eccpos[j + 69]] = (reg_bch_gen >> 8) & 0xff;
+
+#endif
+#else
+
+ ecc_gen0.wrd = read_flash_ctrl_reg(FLASH_NF_ECC_GEN0 + 4 * i);
+ chip->oob_poi[eccpos[j]] = ecc_gen0.wrd & 0xff;
+ chip->oob_poi[eccpos[j + 1]] = (ecc_gen0.wrd >> 8) & 0xff;
+ chip->oob_poi[eccpos[j + 2]] = (ecc_gen0.wrd >> 16) & 0xff;
+ /* printf("%x ", ecc_gen0.wrd); */
+#endif
+ }
+ /*printf("\n"); */
+
+ /* Disable ECC/BCH after read out */
+#if defined(CONFIG_NAND_CORTINA_ECC_HW_BCH)
+ /*disable ecc gen */
+ bch_ctrl.wrd = read_flash_ctrl_reg(FLASH_NF_BCH_CONTROL);
+ bch_ctrl.bf.bchen = BCH_DISABLE;
+ write_flash_ctrl_reg(FLASH_NF_BCH_CONTROL, bch_ctrl.wrd);
+
+ /* jenfeng clear erase tag */
+ *(chip->oob_poi + chip->ecc.layout->oobfree[0].offset +
+ chip->ecc.layout->oobfree[0].length) = 0;
+#else
+ ecc_ctl.wrd = read_flash_ctrl_reg(FLASH_NF_ECC_CONTROL);
+ ecc_ctl.bf.eccen = 0;
+ /*disable ecc gen */
+ write_flash_ctrl_reg(FLASH_NF_ECC_CONTROL, ecc_ctl.wrd);
+#endif
+
+ tx_desc[dma_txq5_wptr.bf.index].word1.bf.own = OWN_DMA;
+ tx_desc[dma_txq5_wptr.bf.index].word1.bf.buf_len = mtd->oobsize;
+ tx_desc[dma_txq5_wptr.bf.index].buf_adr =
+ (unsigned long)(chip->oob_poi);
+
+ dma_txq5_wptr.bf.index = (dma_txq5_wptr.bf.index + 1) % FDMA_DESC_NUM;
+ write_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_TXQ_WPTR, dma_txq5_wptr.wrd);
+
+ dma_ssp_rxq5_intsts.wrd =
+ read_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_RXQ_COAL_INTERRUPT);
+ tmp_dma_ssp_rxq5_intsts.wrd = 0;
+ tmp_dma_ssp_rxq5_intsts.bf.rxq_eof = 1;
+
+ dma_wait(DMA_SEC_DMA_SSP_Q_RXQ_COAL_INTERRUPT,
+ tmp_dma_ssp_rxq5_intsts.wrd, tmp_dma_ssp_rxq5_intsts.wrd,
+ 1000);
+
+ dma_ssp_txq5_intsts.wrd =
+ read_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_TXQ_COAL_INTERRUPT);
+ tmp_dma_ssp_txq5_intsts.wrd = 0;
+ tmp_dma_ssp_txq5_intsts.bf.txq_eof = 1;
+
+ dma_wait(DMA_SEC_DMA_SSP_Q_TXQ_COAL_INTERRUPT,
+ tmp_dma_ssp_txq5_intsts.wrd, tmp_dma_ssp_txq5_intsts.wrd,
+ 1000);
+
+ flash_start.wrd = read_flash_ctrl_reg(FLASH_FLASH_ACCESS_START);
+
+ tmp_access.wrd = 0;
+ tmp_access.bf.nflashfiforeq = 1;
+ reg_wait(FLASH_FLASH_ACCESS_START, tmp_access.wrd, 0, 1000);
+
+ /* update rx read ptr */
+ dma_rxq5_rptr.bf.index = (dma_rxq5_rptr.bf.index + 1) % FDMA_DESC_NUM;
+ write_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_RXQ_RPTR, dma_rxq5_rptr.wrd);
+
+ return 0;
+}
+
+static int ca_do_bch_correction(unsigned int eccstep, unsigned int eccsize,
+ int eccbytes, u8 *p)
+{
+ int j, err_loc0, err_loc1;
+ int offset;
+
+ for (j = 0; j < ((bch_sts.bf.bcherrnum + 1) / 2); j++) {
+ bch_err_loc01.wrd =
+ read_flash_ctrl_reg(FLASH_NF_BCH_ERROR_LOC01 + j * 4);
+ err_loc0 = bch_err_loc01.bf.bcherrloc0;
+ err_loc1 = bch_err_loc01.bf.bcherrloc1;
+
+ if ((j + 1) * 2 <= bch_sts.bf.bcherrnum) {
+ if (((err_loc1 & 0x3fff) >> 3) < BCH_DATA_UNIT) {
+ offset = ((eccstep / eccbytes) * eccsize +
+ ((err_loc1 & 0x1fff) >> 3));
+ printf
+ ("pdata[%x]:%x =>", offset,
+ p[(err_loc1 & 0x1fff) >> 3]);
+ p[(err_loc1 & 0x3fff) >> 3] ^=
+ (1 << (err_loc1 & 0x07));
+ printf("%x\n", p[(err_loc1 & 0x1fff) >> 3]);
+ } else {
+ /* Skip bit correction if it's OOB area. */
+ }
+ }
+
+ if (((err_loc0 & 0x3fff) >> 3) < BCH_DATA_UNIT) {
+ offset = ((eccstep / eccbytes) * eccsize +
+ ((err_loc0 & 0x1fff) >> 3));
+ printf
+ ("pdata[%x]:%x =>", offset,
+ p[(err_loc0 & 0x1fff) >> 3]);
+ p[(err_loc0 & 0x3fff) >> 3] ^=
+ (1 << (err_loc0 & 0x07));
+ printf("%x\n", p[(err_loc0 & 0x1fff) >> 3]);
+ } else {
+ /* Skip bit correction if it's OOB area. */
+ }
+ }
+
+ return 0;
+}
+
+/*
+ * ca_nand_read_page_hwecc - [REPLACEABLE] hardware ecc based page read function
+ * @mtd: mtd info structure
+ * @chip: nand chip info structure
+ * @buf: buffer to store read data
+ * @page: page number to read
+ *
+ * Not for syndrome calculating ecc controllers which need a special oob layout
+ */
+int ca_nand_read_page_hwecc(struct mtd_info *mtd, struct nand_chip *chip,
+ u8 *buf, int oob_required, int page)
+{
+ int i, eccsize = chip->ecc.size;
+ int eccbytes = chip->ecc.bytes;
+ int eccsteps = chip->ecc.steps;
+ u8 *p = buf;
+ /*u8 *ecc_calc = chip->buffers->ecccalc; */
+ u8 *ecc_code = chip->buffers->ecccode;
+ u32 *eccpos = chip->ecc.layout->eccpos, *addr;
+ union DMA_SEC_DMA_SSP_Q_RXQ_COAL_INTERRUPT_t tmp_dma_ssp_rxq5_intsts;
+ union DMA_SEC_DMA_SSP_Q_TXQ_COAL_INTERRUPT_t tmp_dma_ssp_txq5_intsts;
+ union FLASH_FLASH_ACCESS_START_t tmp_access;
+#if defined(CONFIG_NAND_CORTINA_ECC_HW_BCH)
+ union FLASH_NF_BCH_STATUS_t tmp_bsc_sts;
+#else
+ union FLASH_NF_ECC_STATUS_t tmp_ecc_sts;
+#endif
+ union FLASH_FIFO_CONTROL_t flash_fifo_ctrl;
+ //FLASH_NF_ECC_RESET_t ecc_rst;
+
+ check_flash_ctrl_status();
+
+ p = buf;
+ ecc_reset.wrd = 0;
+ ecc_reset.bf.eccclear = ECC_CLR;
+ write_flash_ctrl_reg(FLASH_NF_ECC_RESET, ecc_reset.wrd);
+
+ flash_int_sts.bf.regirq = 1;
+ write_flash_ctrl_reg(FLASH_FLASH_INTERRUPT, flash_int_sts.wrd);
+
+ ecc_reset.wrd = 0;
+ ecc_reset.bf.eccclear = 1;
+ write_flash_ctrl_reg(FLASH_NF_ECC_RESET, ecc_reset.wrd);
+
+#ifdef CONFIG_NAND_CORTINA_ECC_HW_BCH
+ bch_ctrl.wrd = 0;
+ bch_ctrl.bf.bchen = BCH_ENABLE;
+ bch_ctrl.bf.bchopcode = BCH_DECODE;
+#if (CONFIG_NAND_CORTINA_ECC_LEVEL == 2)
+ bch_ctrl.bf.bcherrcap = BCH_ERR_CAP_8;
+#elif (CONFIG_NAND_CORTINA_ECC_LEVEL == 3)
+ bch_ctrl.bf.bcherrcap = BCH_ERR_CAP_16;
+#elif (CONFIG_NAND_CORTINA_ECC_LEVEL == 4)
+ bch_ctrl.bf.bcherrcap = BCH_ERR_CAP_24;
+#elif (CONFIG_NAND_CORTINA_ECC_LEVEL == 5)
+ bch_ctrl.bf.bcherrcap = BCH_ERR_CAP_40;
+#else
+ printf("BCH Level is not recognized! %s:%d\n", __func__, __LINE__);
+#endif
+ write_flash_ctrl_reg(FLASH_NF_BCH_CONTROL, bch_ctrl.wrd);
+
+#else
+
+ ecc_ctl.wrd = 0;
+ if ((eccsize - 1) == NCNT_512P_DATA)
+ ecc_ctl.bf.eccgenmode = ECC_GEN_512;
+ else
+ ecc_ctl.bf.eccgenmode = ECC_GEN_256;
+ ecc_ctl.bf.eccen = ECC_ENABLE;
+ write_flash_ctrl_reg(FLASH_NF_ECC_CONTROL, ecc_ctl.wrd);
+#endif
+
+ /*disable txq5 */
+ dma_txq5_ctrl.bf.txq_en = 0;
+ write_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_TXQ_CONTROL, dma_txq5_ctrl.wrd);
+
+ dma_ssp_txq5_intsts.wrd =
+ read_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_TXQ_COAL_INTERRUPT);
+ dma_ssp_txq5_intsts.bf.txq_eof = 0;
+ write_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_TXQ_COAL_INTERRUPT,
+ dma_ssp_txq5_intsts.wrd);
+ dma_ssp_rxq5_intsts.wrd =
+ read_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_RXQ_COAL_INTERRUPT);
+ dma_ssp_rxq5_intsts.bf.rxq_eof = 0;
+ write_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_RXQ_COAL_INTERRUPT,
+ dma_ssp_rxq5_intsts.wrd);
+
+ /*for indirect access with DMA, because DMA not ready */
+ nf_cnt.wrd = 0;
+ nf_cmd.wrd = 0;
+ nf_addr1.wrd = 0;
+ nf_addr2.wrd = 0;
+ nf_cnt.wrd = 0;
+ nf_cnt.bf.nflashregoobcount = mtd->oobsize - 1;
+ nf_cnt.bf.nflashregdatacount = mtd->writesize - 1;
+
+ if (chip->chipsize < (32 << 20)) {
+ nf_cnt.bf.nflashregaddrcount = NCNT_ADDR_3;
+ nf_cnt.bf.nflashregcmdcount = NCNT_CMD_1;
+ nf_cmd.bf.nflashregcmd0 = NAND_CMD_READ0;
+ nf_addr1.wrd = (((page & 0x00ffffff) << 8));
+ nf_addr2.wrd = ((page & 0xff000000) >> 24);
+ } else if ((chip->chipsize >= (32 << 20)) &&
+ (chip->chipsize <= (128 << 20))) {
+ nf_cnt.bf.nflashregaddrcount = NCNT_ADDR_4;
+ nf_cnt.bf.nflashregcmdcount = NCNT_CMD_1;
+ nf_cmd.bf.nflashregcmd0 = NAND_CMD_READ0;
+
+ if (mtd->writesize > NCNT_512P_DATA) {
+ nf_cnt.bf.nflashregcmdcount = NCNT_CMD_2;
+ nf_cmd.bf.nflashregcmd1 = NAND_CMD_READSTART;
+ }
+ nf_addr1.wrd = (((page & 0xffff) << 16));
+ nf_addr2.wrd = ((page & 0xffff0000) >> 16);
+ } else { /*if((chip->chipsize > (128 << 20)) )) */
+
+ nf_cnt.bf.nflashregaddrcount = NCNT_ADDR_5;
+ nf_cnt.bf.nflashregcmdcount = NCNT_CMD_2;
+ nf_cmd.bf.nflashregcmd0 = NAND_CMD_READ0;
+ nf_cmd.bf.nflashregcmd1 = NAND_CMD_READSTART;
+ nf_addr1.wrd = (((page & 0xffff) << 16));
+ nf_addr2.wrd = ((page & 0xffff0000) >> 16);
+ }
+
+ write_flash_ctrl_reg(FLASH_NF_COUNT, nf_cnt.wrd);
+ /*write read id command */
+ write_flash_ctrl_reg(FLASH_NF_COMMAND, nf_cmd.wrd);
+ /*write address 0x0 */
+ write_flash_ctrl_reg(FLASH_NF_ADDRESS_1, nf_addr1.wrd);
+ write_flash_ctrl_reg(FLASH_NF_ADDRESS_2, nf_addr2.wrd);
+
+ nf_access.wrd = 0;
+ nf_access.bf.nflashcealt = CHIP_EN;
+ nf_access.bf.nflashregwidth = NFLASH_WIDTH8;
+ nf_access.bf.nflashextaddr = ((page << chip->page_shift) / 0x8000000);
+ write_flash_ctrl_reg(FLASH_NF_ACCESS, nf_access.wrd);
+
+ addr =
+ (unsigned int *)(((unsigned long)page << chip->page_shift) %
+ 0x8000000);
+ addr =
+ (unsigned int *)((unsigned long)addr +
+ (unsigned int)(CONFIG_SYS_FLASH_BASE));
+
+ dma_txq5_wptr.wrd = read_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_TXQ_WPTR);
+
+ tx_desc[dma_txq5_wptr.bf.index].word1.bf.own = OWN_DMA;
+ tx_desc[dma_txq5_wptr.bf.index].word1.bf.buf_len = mtd->writesize;
+ tx_desc[dma_txq5_wptr.bf.index].buf_adr = (unsigned long)addr;
+
+ /*oob tx desc */
+ dma_txq5_wptr.bf.index = (dma_txq5_wptr.bf.index + 1) % FDMA_DESC_NUM;
+
+ addr = (unsigned int *)((unsigned long)addr + mtd->writesize);
+ tx_desc[dma_txq5_wptr.bf.index].word1.bf.own = OWN_DMA;
+ tx_desc[dma_txq5_wptr.bf.index].word1.bf.buf_len = mtd->oobsize;
+ tx_desc[dma_txq5_wptr.bf.index].buf_adr = (unsigned long)addr;
+
+ /*page data rx desc */
+ dma_rxq5_rptr.wrd = read_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_RXQ_RPTR);
+ rx_desc[dma_rxq5_rptr.bf.index].word1.bf.own = OWN_DMA;
+ rx_desc[dma_rxq5_rptr.bf.index].word1.bf.buf_len = mtd->writesize;
+
+ rx_desc[dma_rxq5_rptr.bf.index].buf_adr = (unsigned long)(buf);
+
+ /*oob rx desc */
+ dma_rxq5_rptr.bf.index = (dma_rxq5_rptr.bf.index + 1) % FDMA_DESC_NUM;
+ rx_desc[dma_rxq5_rptr.bf.index].word1.bf.own = OWN_DMA;
+ rx_desc[dma_rxq5_rptr.bf.index].word1.bf.buf_len = mtd->oobsize;
+ rx_desc[dma_rxq5_rptr.bf.index].buf_adr =
+ (unsigned long)(chip->oob_poi);
+
+ flash_fifo_ctrl.wrd = read_flash_ctrl_reg(FLASH_FIFO_CONTROL);
+ flash_fifo_ctrl.bf.fifocmd = FIFO_CMD_READ;
+ write_flash_ctrl_reg(FLASH_FIFO_CONTROL, flash_fifo_ctrl.wrd);
+
+ flash_start.wrd = 0;
+ flash_start.bf.nflashfiforeq = FLASH_GO;
+ /*flash_start.bf.nflashRegCmd = FLASH_RD; */
+ write_flash_ctrl_reg(FLASH_FLASH_ACCESS_START, flash_start.wrd);
+
+ /*update tx write ptr */
+ dma_txq5_wptr.bf.index = (dma_txq5_wptr.bf.index + 1) % FDMA_DESC_NUM;
+ write_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_TXQ_WPTR, dma_txq5_wptr.wrd);
+ /* enable txq5 */
+ dma_txq5_ctrl.bf.txq_en = 1;
+ write_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_TXQ_CONTROL, dma_txq5_ctrl.wrd);
+
+ tmp_dma_ssp_rxq5_intsts.wrd = 0;
+ tmp_dma_ssp_rxq5_intsts.bf.rxq_eof = 1;
+
+ dma_wait(DMA_SEC_DMA_SSP_Q_RXQ_COAL_INTERRUPT,
+ tmp_dma_ssp_rxq5_intsts.wrd, tmp_dma_ssp_rxq5_intsts.wrd,
+ 1000);
+
+ tmp_dma_ssp_txq5_intsts.wrd = 0;
+ tmp_dma_ssp_txq5_intsts.bf.txq_eof = 1;
+
+ dma_wait(DMA_SEC_DMA_SSP_Q_TXQ_COAL_INTERRUPT,
+ tmp_dma_ssp_txq5_intsts.wrd, tmp_dma_ssp_txq5_intsts.wrd,
+ 1000);
+
+ tmp_access.wrd = 0;
+ tmp_access.bf.nflashfiforeq = 1;
+ reg_wait(FLASH_FLASH_ACCESS_START, tmp_access.wrd, 0, 1000);
+
+ dma_rxq5_rptr.bf.index = (dma_rxq5_rptr.bf.index + 1) % FDMA_DESC_NUM;
+ write_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_RXQ_RPTR, dma_rxq5_rptr.wrd);
+
+#if defined(CONFIG_NAND_CORTINA_ECC_HW_BCH)
+ bch_sts.wrd = read_flash_ctrl_reg(FLASH_NF_BCH_STATUS);
+
+ tmp_bsc_sts.wrd = 0;
+ tmp_bsc_sts.bf.bchgendone = 1;
+
+ reg_wait(FLASH_NF_BCH_STATUS, tmp_bsc_sts.wrd, tmp_bsc_sts.wrd, 1000);
+
+ /*write_flash_ctrl_reg(FLASH_NF_BCH_CONTROL, 0); */
+
+#else
+ ecc_sts.wrd = read_flash_ctrl_reg(FLASH_NF_ECC_STATUS);
+
+ tmp_ecc_sts.wrd = 0;
+ tmp_ecc_sts.bf.eccdone = 1;
+
+ reg_wait(FLASH_NF_ECC_STATUS, tmp_ecc_sts.wrd, tmp_ecc_sts.wrd, 1000);
+
+ ecc_ctl.wrd = read_flash_ctrl_reg(FLASH_NF_ECC_CONTROL);
+ ecc_ctl.bf.eccen = 0;
+ /*disable ecc gen */
+ write_flash_ctrl_reg(FLASH_NF_ECC_CONTROL, ecc_ctl.wrd);
+#endif
+
+#if defined(CONFIG_NAND_CORTINA_ECC_HW_BCH)
+ /* jenfeng */
+ if (0xff ==
+ *(chip->oob_poi + chip->ecc.layout->oobfree[0].offset +
+ chip->ecc.layout->oobfree[0].length)) {
+ /* Erase tga is on , No needs to check. */
+ goto BCH_EXIT;
+ }
+#endif
+ for (i = 0; i < chip->ecc.total; i++)
+ ecc_code[i] = chip->oob_poi[eccpos[i]];
+
+ for (i = 0; eccsteps; eccsteps--, i += eccbytes, p += eccsize) {
+#if defined(CONFIG_NAND_CORTINA_ECC_HW_BCH)
+ unsigned int reg_bch_oob;
+
+ reg_bch_oob =
+ ecc_code[i] | ecc_code[i + 1] << 8 | ecc_code[i +
+ 2] << 16 |
+ ecc_code[i + 3] << 24;
+ write_flash_ctrl_reg(FLASH_NF_BCH_OOB0, reg_bch_oob);
+
+ reg_bch_oob =
+ ecc_code[i + 4] | ecc_code[i + 5] << 8 | ecc_code[i +
+ 6] << 16 |
+ ecc_code[i + 7] << 24;
+ write_flash_ctrl_reg(FLASH_NF_BCH_OOB1, reg_bch_oob);
+
+ reg_bch_oob =
+ ecc_code[i + 8] | ecc_code[i + 9] << 8 | ecc_code[i +
+ 10] << 16
+ | ecc_code[i + 11] << 24;
+ write_flash_ctrl_reg(FLASH_NF_BCH_OOB2, reg_bch_oob);
+
+ reg_bch_oob = ecc_code[i + 12] | ecc_code[i + 13] << 8;
+ write_flash_ctrl_reg(FLASH_NF_BCH_OOB3, reg_bch_oob);
+
+#if (CONFIG_NAND_CORTINA_ECC_LEVEL > 2)
+ reg_bch_oob =
+ ecc_code[i + 12] | ecc_code[i + 13] << 8 | ecc_code[i +
+ 14] <<
+ 16 | ecc_code[i + 15] << 24;
+ write_flash_ctrl_reg(FLASH_NF_BCH_OOB3, reg_bch_oob);
+
+ reg_bch_oob =
+ ecc_code[i + 16] | ecc_code[i + 17] << 8 | ecc_code[i +
+ 18] <<
+ 16 | ecc_code[i + 19] << 24;
+ write_flash_ctrl_reg(FLASH_NF_BCH_OOB4, reg_bch_oob);
+
+ reg_bch_oob =
+ ecc_code[i + 20] | ecc_code[i + 21] << 8 | ecc_code[i +
+ 22] <<
+ 16 | ecc_code[i + 23] << 24;
+ write_flash_ctrl_reg(FLASH_NF_BCH_OOB5, reg_bch_oob);
+
+ reg_bch_oob =
+ ecc_code[i + 24] | ecc_code[i + 25] << 8 | ecc_code[i +
+ 26] <<
+ 16 | ecc_code[i + 27] << 24;
+ write_flash_ctrl_reg(FLASH_NF_BCH_OOB6, reg_bch_oob);
+#endif
+#if (CONFIG_NAND_CORTINA_ECC_LEVEL > 3)
+ reg_bch_oob =
+ ecc_code[i + 28] | ecc_code[i + 29] << 8 | ecc_code[i +
+ 30] <<
+ 16 | ecc_code[i + 31] << 24;
+ write_flash_ctrl_reg(FLASH_NF_BCH_OOB7, reg_bch_oob);
+
+ reg_bch_oob =
+ ecc_code[i + 32] | ecc_code[i + 33] << 8 | ecc_code[i +
+ 34] <<
+ 16 | ecc_code[i + 35] << 24;
+ write_flash_ctrl_reg(FLASH_NF_BCH_OOB8, reg_bch_oob);
+
+ reg_bch_oob =
+ ecc_code[i + 36] | ecc_code[i + 37] << 8 | ecc_code[i +
+ 38] <<
+ 16 | ecc_code[i + 39] << 24;
+ write_flash_ctrl_reg(FLASH_NF_BCH_OOB9, reg_bch_oob);
+
+ reg_bch_oob = ecc_code[i + 40] | ecc_code[i + 41] << 8;
+ write_flash_ctrl_reg(FLASH_NF_BCH_OOB10, reg_bch_oob);
+#endif
+#if (CONFIG_NAND_CORTINA_ECC_LEVEL > 4)
+ reg_bch_oob =
+ ecc_code[i + 40] | ecc_code[i + 41] << 8 | ecc_code[i +
+ 42] <<
+ 16 | ecc_code[i + 43] << 24;
+ write_flash_ctrl_reg(FLASH_NF_BCH_OOB10, reg_bch_oob);
+
+ reg_bch_oob =
+ ecc_code[i + 44] | ecc_code[i + 45] << 8 | ecc_code[i +
+ 46] <<
+ 16 | ecc_code[i + 47] << 24;
+ write_flash_ctrl_reg(FLASH_NF_BCH_OOB11, reg_bch_oob);
+
+ reg_bch_oob =
+ ecc_code[i + 48] | ecc_code[i + 49] << 8 | ecc_code[i +
+ 50] <<
+ 16 | ecc_code[i + 51] << 24;
+ write_flash_ctrl_reg(FLASH_NF_BCH_OOB12, reg_bch_oob);
+
+ reg_bch_oob =
+ ecc_code[i + 52] | ecc_code[i + 53] << 8 | ecc_code[i +
+ 54] <<
+ 16 | ecc_code[i + 55] << 24;
+ write_flash_ctrl_reg(FLASH_NF_BCH_OOB13, reg_bch_oob);
+
+ reg_bch_oob =
+ ecc_code[i + 56] | ecc_code[i + 57] << 8 | ecc_code[i +
+ 58] <<
+ 16 | ecc_code[i + 59] << 24;
+ write_flash_ctrl_reg(FLASH_NF_BCH_OOB14, reg_bch_oob);
+
+ reg_bch_oob =
+ ecc_code[i + 60] | ecc_code[i + 61] << 8 | ecc_code[i +
+ 62] <<
+ 16 | ecc_code[i + 63] << 24;
+ write_flash_ctrl_reg(FLASH_NF_BCH_OOB15, reg_bch_oob);
+
+ reg_bch_oob =
+ ecc_code[i + 64] | ecc_code[i + 65] << 8 | ecc_code[i +
+ 66] <<
+ 16 | ecc_code[i + 67] << 24;
+ write_flash_ctrl_reg(FLASH_NF_BCH_OOB16, reg_bch_oob);
+
+ reg_bch_oob = ecc_code[i + 68] | ecc_code[i + 69] << 8;
+ write_flash_ctrl_reg(FLASH_NF_BCH_OOB17, reg_bch_oob);
+
+#endif
+
+ ecc_reset.wrd = read_flash_ctrl_reg(FLASH_NF_ECC_RESET);
+ ecc_reset.bf.eccclear = ECC_CLR;
+ write_flash_ctrl_reg(FLASH_NF_ECC_RESET, ecc_reset.wrd);
+
+ ecc_reset.wrd = 0;
+ ecc_reset.bf.eccclear = 1;
+ udelay(10);
+ reg_wait(FLASH_NF_ECC_RESET, ecc_reset.wrd, 0, 1000);
+
+ bch_ctrl.wrd = read_flash_ctrl_reg(FLASH_NF_BCH_CONTROL);
+ bch_ctrl.bf.bchen = 0;
+ write_flash_ctrl_reg(FLASH_NF_BCH_CONTROL, bch_ctrl.wrd);
+
+ /* enable ecc compare */
+ bch_ctrl.wrd = read_flash_ctrl_reg(FLASH_NF_BCH_CONTROL);
+ bch_ctrl.bf.bchcodesel = (i / eccbytes);
+ bch_ctrl.bf.bchen = 1;
+ write_flash_ctrl_reg(FLASH_NF_BCH_CONTROL, bch_ctrl.wrd);
+ udelay(10);
+ bch_ctrl.bf.bchcompare = 1;
+ write_flash_ctrl_reg(FLASH_NF_BCH_CONTROL, bch_ctrl.wrd);
+
+ tmp_bsc_sts.wrd = 0;
+ tmp_bsc_sts.bf.bchdecdone = 1;
+
+ reg_wait(FLASH_NF_BCH_STATUS, tmp_bsc_sts.wrd, tmp_bsc_sts.wrd,
+ 1000);
+
+ /* disable ecc compare */
+ bch_ctrl.wrd = read_flash_ctrl_reg(FLASH_NF_BCH_CONTROL);
+ bch_ctrl.bf.bchcompare = 0;
+ write_flash_ctrl_reg(FLASH_NF_BCH_CONTROL, bch_ctrl.wrd);
+
+ bch_sts.wrd = read_flash_ctrl_reg(FLASH_NF_BCH_STATUS);
+
+ switch (bch_sts.bf.bchdecstatus) {
+ case BCH_CORRECTABLE_ERR:
+ printf
+ ("Correctable error(%x)!! addr:%lx\n",
+ bch_sts.bf.bcherrnum,
+ (unsigned long)addr - mtd->writesize);
+ printf
+ ("Dst buf: %p [ColSel:%x ]\n",
+ buf + bch_ctrl.bf.bchcodesel * BCH_DATA_UNIT,
+ bch_ctrl.bf.bchcodesel);
+ ca_do_bch_correction(i, eccsize, eccbytes, p);
+ break;
+ case BCH_UNCORRECTABLE:
+ printf("uncorrectable error!!step %d\n",
+ (i / eccbytes));
+ if ((i / eccbytes > 2) || (i / eccbytes) == 0)
+ mtd->ecc_stats.failed++;
+
+ break;
+ }
+
+ if (dbg_ecc_check && i == 0) {
+ unsigned char *free =
+ buf + mtd->writesize + mtd->oobsize;
+ *free = bch_sts.bf.bchdecstatus;
+ *(free + 1) = bch_sts.bf.bcherrnum;
+ }
+#else
+
+ ecc_oob.wrd =
+ ecc_code[i] | ecc_code[i + 1] << 8 | ecc_code[i + 2] << 16;
+ write_flash_ctrl_reg(FLASH_NF_ECC_OOB, ecc_oob.wrd);
+
+ ecc_ctl.wrd = read_flash_ctrl_reg(FLASH_NF_ECC_CONTROL);
+ ecc_ctl.bf.ecccodesel = (i / eccbytes);
+ write_flash_ctrl_reg(FLASH_NF_ECC_CONTROL, ecc_ctl.wrd);
+
+ ecc_sts.wrd = read_flash_ctrl_reg(FLASH_NF_ECC_STATUS);
+
+ switch (ecc_sts.bf.eccstatus) {
+ case ECC_NO_ERR:
+
+ break;
+ case ECC_1BIT_DATA_ERR:
+ /* flip the bit */
+ p[ecc_sts.bf.eccerrbyte] ^= (1 << ecc_sts.bf.eccerrbit);
+ ecc_gen0.wrd =
+ read_flash_ctrl_reg(FLASH_NF_ECC_GEN0 +
+ (4 * (i / eccbytes)));
+ printf("\nECC one bit data error(%x)!!(org: %x)"
+ (i / eccbytes), ecc_oob.wrd);
+ printf(" HW(%xs) page(%x)\n",
+ ecc_gen0.wrd, page);
+ break;
+ case ECC_1BIT_ECC_ERR:
+ ecc_gen0.wrd =
+ read_flash_ctrl_reg(FLASH_NF_ECC_GEN0 +
+ (4 * (i / eccbytes)));
+ printf("\nECC one bit ECC error(%x)!!(org: %x)"
+ (i / eccbytes), ecc_oob.wrd);
+ printf(" HW(%xs) page(%x)\n",
+ ecc_gen0.wrd, page);
+ break;
+ case ECC_UNCORRECTABLE:
+ mtd->ecc_stats.failed++;
+ ecc_gen0.wrd =
+ read_flash_ctrl_reg(FLASH_NF_ECC_GEN0 +
+ (4 * (i / eccbytes)));
+ printf("\nECC uncorrectable error(%x)!!(org: %x)"
+ (i / eccbytes), ecc_oob.wrd);
+ printf(" HW(%xs) page(%x)\n",
+ ecc_gen0.wrd, page);
+ break;
+ }
+
+ if (dbg_ecc_check && i == 0) {
+ unsigned char *free =
+ buf + mtd->writesize + mtd->oobsize;
+ *free = ecc_sts.bf.eccstatus;
+ }
+#endif
+ }
+
+#if defined(CONFIG_NAND_CORTINA_ECC_HW_BCH)
+ BCH_EXIT:
+ /* diasble bch */
+ bch_ctrl.wrd = 0;
+ write_flash_ctrl_reg(FLASH_NF_BCH_CONTROL, bch_ctrl.wrd);
+#endif
+
+ return 0;
+}
+
+/*
+ * ca_nand_write_page_raw - [Intern] raw page write function
+ * @mtd: mtd info structure
+ * @chip: nand chip info structure
+ * @buf: data buffer
+ *
+ * Not for syndrome calculating ecc controllers, which use a special oob layout
+ */
+int ca_nand_write_page_raw(struct mtd_info *mtd, struct nand_chip *chip,
+ const u8 *buf, int oob_required, int page)
+{
+ /*u8 *ecc_calc = chip->buffers->ecccalc; */
+ /*const u8 *p = buf; */
+ u32 *addr;
+ union DMA_SEC_DMA_SSP_Q_RXQ_COAL_INTERRUPT_t tmp_dma_ssp_rxq5_intsts;
+ union DMA_SEC_DMA_SSP_Q_TXQ_COAL_INTERRUPT_t tmp_dma_ssp_txq5_intsts;
+ union FLASH_FLASH_ACCESS_START_t tmp_access;
+#ifndef CONFIG_NAND_CORTINA_ECC_HW_BCH
+ union FLASH_NF_ECC_STATUS_t __attribute__ ((unused)) tmp_ecc_sts;
+#endif
+ union FLASH_FIFO_CONTROL_t flash_fifo_ctrl;
+
+ check_flash_ctrl_status();
+
+ //page = host->page_addr;
+
+ ecc_reset.wrd = 3;
+ ecc_reset.bf.eccclear = ECC_CLR;
+ ecc_reset.bf.fifoclear = FIFO_CLR;
+ write_flash_ctrl_reg(FLASH_NF_ECC_RESET, ecc_reset.wrd);
+
+ flash_int_sts.bf.regirq = 1;
+ write_flash_ctrl_reg(FLASH_FLASH_INTERRUPT, flash_int_sts.wrd);
+
+ ecc_reset.wrd = 0;
+ ecc_reset.bf.eccclear = 1;
+ write_flash_ctrl_reg(FLASH_NF_ECC_RESET, ecc_reset.wrd);
+
+#ifdef CONFIG_NAND_CORTINA_ECC_HW_BCH
+ write_flash_ctrl_reg(FLASH_NF_BCH_CONTROL, 0);
+#else
+ write_flash_ctrl_reg(FLASH_NF_ECC_CONTROL, 0);
+#endif
+
+ /*disable txq5 */
+ dma_txq5_ctrl.bf.txq_en = 0;
+ write_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_TXQ_CONTROL, dma_txq5_ctrl.wrd);
+ /*clr tx/rx eof */
+ dma_ssp_txq5_intsts.wrd =
+ read_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_TXQ_COAL_INTERRUPT);
+ dma_ssp_txq5_intsts.bf.txq_eof = 0;
+ write_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_TXQ_COAL_INTERRUPT,
+ dma_ssp_txq5_intsts.wrd);
+ dma_ssp_rxq5_intsts.wrd =
+ read_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_RXQ_COAL_INTERRUPT);
+ dma_ssp_rxq5_intsts.bf.rxq_eof = 0;
+ write_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_RXQ_COAL_INTERRUPT,
+ dma_ssp_rxq5_intsts.wrd);
+
+ nf_cnt.wrd = 0;
+ nf_cmd.wrd = 0;
+ nf_addr1.wrd = 0;
+ nf_addr2.wrd = 0;
+ nf_cnt.wrd = 0;
+ nf_cnt.bf.nflashregoobcount = mtd->oobsize - 1;
+ nf_cnt.bf.nflashregdatacount = mtd->writesize - 1;
+
+ if (chip->chipsize < (32 << 20)) {
+ nf_cnt.bf.nflashregaddrcount = NCNT_ADDR_3;
+ nf_cnt.bf.nflashregcmdcount = NCNT_CMD_2;
+ nf_cmd.bf.nflashregcmd0 = NAND_CMD_SEQIN;
+ nf_cmd.bf.nflashregcmd1 = NAND_CMD_PAGEPROG;
+ nf_addr1.wrd = (((page & 0x00ffffff) << 8));
+ nf_addr2.wrd = ((page & 0xff000000) >> 24);
+
+ } else if ((chip->chipsize >= (32 << 20)) &&
+ (chip->chipsize <= (128 << 20))) {
+ nf_cnt.bf.nflashregaddrcount = NCNT_ADDR_4;
+ nf_cnt.bf.nflashregcmdcount = NCNT_CMD_2;
+ nf_cmd.bf.nflashregcmd0 = NAND_CMD_SEQIN;
+ nf_cmd.bf.nflashregcmd1 = NAND_CMD_PAGEPROG;
+ nf_addr1.wrd = (((page & 0xffff) << 16));
+ nf_addr2.wrd = ((page & 0xffff0000) >> 16);
+
+ } else { /*if((chip->chipsize > (128 << 20)) )) */
+
+ nf_cnt.bf.nflashregaddrcount = NCNT_ADDR_5;
+ nf_cnt.bf.nflashregcmdcount = NCNT_CMD_2;
+ nf_cmd.bf.nflashregcmd0 = NAND_CMD_SEQIN;
+ nf_cmd.bf.nflashregcmd1 = NAND_CMD_PAGEPROG;
+ nf_addr1.wrd = (((page & 0xffff) << 16));
+ nf_addr2.wrd = ((page & 0xffff0000) >> 16);
+ }
+
+ write_flash_ctrl_reg(FLASH_NF_COUNT, nf_cnt.wrd);
+ write_flash_ctrl_reg(FLASH_NF_COMMAND, nf_cmd.wrd);
+ write_flash_ctrl_reg(FLASH_NF_ADDRESS_1, nf_addr1.wrd);
+ write_flash_ctrl_reg(FLASH_NF_ADDRESS_2, nf_addr2.wrd);
+
+ /*dma_map_single( NULL, (void *)buf, mtd->writesize, DMA_TO_DEVICE); */
+
+ nf_access.wrd = 0;
+ nf_access.bf.nflashcealt = CHIP_EN;
+ nf_access.bf.nflashregwidth = NFLASH_WIDTH8;
+ nf_access.bf.nflashextaddr = ((page << chip->page_shift) / 0x8000000);
+ write_flash_ctrl_reg(FLASH_NF_ACCESS, nf_access.wrd);
+
+ addr =
+ (unsigned int *)(((unsigned long)page << chip->page_shift) %
+ 0x8000000);
+ addr =
+ (unsigned int *)((unsigned long)addr +
+ (unsigned int)(CONFIG_SYS_FLASH_BASE));
+
+ /*page data tx desc */
+ dma_txq5_wptr.wrd = read_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_TXQ_WPTR);
+ tx_desc[dma_txq5_wptr.bf.index].word1.bf.own = OWN_DMA;
+ tx_desc[dma_txq5_wptr.bf.index].word1.bf.buf_len = mtd->writesize;
+ tx_desc[dma_txq5_wptr.bf.index].buf_adr = (unsigned long)(buf);
+
+ dma_rxq5_rptr.wrd = read_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_RXQ_RPTR);
+ rx_desc[dma_rxq5_rptr.bf.index].word1.bf.own = OWN_DMA;
+ rx_desc[dma_rxq5_rptr.bf.index].word1.bf.buf_len = mtd->writesize;
+ rx_desc[dma_rxq5_rptr.bf.index].buf_adr = (unsigned long)addr;
+
+ /*oob rx desc */
+ addr = (unsigned int *)((unsigned long)addr + mtd->writesize);
+
+ dma_rxq5_rptr.bf.index = (dma_rxq5_rptr.bf.index + 1) % FDMA_DESC_NUM;
+ rx_desc[dma_rxq5_rptr.bf.index].word1.bf.own = OWN_DMA;
+ rx_desc[dma_rxq5_rptr.bf.index].word1.bf.buf_len = mtd->oobsize;
+ rx_desc[dma_rxq5_rptr.bf.index].buf_adr = (unsigned long)addr;
+
+ /*update page tx write ptr */
+ dma_txq5_wptr.bf.index = (dma_txq5_wptr.bf.index + 1) % FDMA_DESC_NUM;
+ write_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_TXQ_WPTR, dma_txq5_wptr.wrd);
+
+ flash_fifo_ctrl.wrd = read_flash_ctrl_reg(FLASH_FIFO_CONTROL);
+ flash_fifo_ctrl.bf.fifocmd = FIFO_CMD_WRITE;
+ write_flash_ctrl_reg(FLASH_FIFO_CONTROL, flash_fifo_ctrl.wrd);
+
+ flash_start.wrd = 0;
+ flash_start.bf.nflashfiforeq = FLASH_GO;
+ /*flash_start.bf.nflashRegCmd = FLASH_WT; */
+ write_flash_ctrl_reg(FLASH_FLASH_ACCESS_START, flash_start.wrd);
+
+ /*enable txq5 */
+ dma_txq5_ctrl.bf.txq_en = 1;
+ write_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_TXQ_CONTROL, dma_txq5_ctrl.wrd);
+
+ dma_ssp_rxq5_intsts.wrd =
+ read_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_RXQ_COAL_INTERRUPT);
+ tmp_dma_ssp_rxq5_intsts.wrd = 0;
+ tmp_dma_ssp_rxq5_intsts.bf.rxq_eof = 1;
+
+ dma_wait(DMA_SEC_DMA_SSP_Q_RXQ_COAL_INTERRUPT,
+ tmp_dma_ssp_rxq5_intsts.wrd, tmp_dma_ssp_rxq5_intsts.wrd,
+ 1000);
+
+ dma_ssp_txq5_intsts.wrd =
+ read_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_TXQ_COAL_INTERRUPT);
+ tmp_dma_ssp_txq5_intsts.wrd = 0;
+ tmp_dma_ssp_txq5_intsts.bf.txq_eof = 1;
+
+ dma_wait(DMA_SEC_DMA_SSP_Q_TXQ_COAL_INTERRUPT,
+ tmp_dma_ssp_txq5_intsts.wrd, tmp_dma_ssp_txq5_intsts.wrd,
+ 1000);
+
+ /*clr tx/rx eof */
+
+ dma_ssp_txq5_intsts.bf.txq_eof = 0;
+ write_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_TXQ_COAL_INTERRUPT,
+ dma_ssp_txq5_intsts.wrd);
+
+ dma_ssp_rxq5_intsts.bf.rxq_eof = 0;
+ write_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_RXQ_COAL_INTERRUPT,
+ dma_ssp_rxq5_intsts.wrd);
+
+#if defined(CONFIG_NAND_CORTINA_ECC_HW_BCH)
+ /* jenfeng clear erase tag */
+ *(chip->oob_poi + chip->ecc.layout->oobfree[0].offset +
+ chip->ecc.layout->oobfree[0].length) = 0;
+#endif
+
+ tx_desc[dma_txq5_wptr.bf.index].word1.bf.own = OWN_DMA;
+ tx_desc[dma_txq5_wptr.bf.index].word1.bf.buf_len = mtd->oobsize;
+ tx_desc[dma_txq5_wptr.bf.index].buf_adr =
+ (unsigned long)(chip->oob_poi);
+
+ /* dma_cache_sync(NULL, chip->oob_poi, mtd->oobsize, DMA_BIDIRECTIONAL);
+ * update tx write ptr
+ */
+ dma_txq5_wptr.bf.index = (dma_txq5_wptr.bf.index + 1) % FDMA_DESC_NUM;
+ write_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_TXQ_WPTR, dma_txq5_wptr.wrd);
+
+ dma_ssp_rxq5_intsts.wrd =
+ read_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_RXQ_COAL_INTERRUPT);
+ tmp_dma_ssp_rxq5_intsts.wrd = 0;
+ tmp_dma_ssp_rxq5_intsts.bf.rxq_eof = 1;
+
+ dma_wait(DMA_SEC_DMA_SSP_Q_RXQ_COAL_INTERRUPT,
+ tmp_dma_ssp_rxq5_intsts.wrd, tmp_dma_ssp_rxq5_intsts.wrd,
+ 1000);
+
+ dma_ssp_txq5_intsts.wrd =
+ read_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_TXQ_COAL_INTERRUPT);
+ tmp_dma_ssp_txq5_intsts.wrd = 0;
+ tmp_dma_ssp_txq5_intsts.bf.txq_eof = 1;
+
+ dma_wait(DMA_SEC_DMA_SSP_Q_TXQ_COAL_INTERRUPT,
+ tmp_dma_ssp_txq5_intsts.wrd, tmp_dma_ssp_txq5_intsts.wrd,
+ 1000);
+
+ flash_start.wrd = read_flash_ctrl_reg(FLASH_FLASH_ACCESS_START);
+
+ tmp_access.wrd = 0;
+ tmp_access.bf.nflashfiforeq = 1;
+ reg_wait(FLASH_FLASH_ACCESS_START, tmp_access.wrd, 0, 1000);
+
+ /* update rx read ptr
+ * dma_rxq5_rptr.wrd = read_dma_ctrl_reg(DMA_DMA_SSP_RXQ5_RPTR);
+ */
+ dma_rxq5_rptr.bf.index = (dma_rxq5_rptr.bf.index + 1) % FDMA_DESC_NUM;
+ write_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_RXQ_RPTR, dma_rxq5_rptr.wrd);
+
+ /*chip->write_buf(mtd, chip->oob_poi, mtd->oobsize); */
+ return 0;
+}
+
+/*
+ * ca_nand_read_page_raw - [Intern] read raw page data without ecc
+ * @mtd: mtd info structure
+ * @chip: nand chip info structure
+ * @buf: buffer to store read data
+ */
+int ca_nand_read_page_raw(struct mtd_info *mtd, struct nand_chip *chip,
+ u8 *buf, int oob_required, int page)
+{
+ int __attribute__ ((unused)) eccbytes = chip->ecc.bytes;
+ int __attribute__ ((unused)) eccsteps = chip->ecc.steps;
+ int __attribute__ ((unused)) eccsize = eccsize = chip->ecc.size;
+ u32 *addr;
+ union DMA_SEC_DMA_SSP_Q_RXQ_COAL_INTERRUPT_t tmp_dma_ssp_rxq5_intsts;
+ union DMA_SEC_DMA_SSP_Q_TXQ_COAL_INTERRUPT_t tmp_dma_ssp_txq5_intsts;
+ union FLASH_FLASH_ACCESS_START_t tmp_access;
+#ifndef CONFIG_NAND_CORTINA_ECC_HW_BCH
+ union FLASH_NF_ECC_STATUS_t __attribute__ ((unused)) tmp_ecc_sts;
+#endif
+ union FLASH_FIFO_CONTROL_t flash_fifo_ctrl;
+
+ ecc_reset.wrd = 0;
+ ecc_reset.bf.eccclear = ECC_CLR;
+ ecc_reset.bf.fifoclear = FIFO_CLR;
+ write_flash_ctrl_reg(FLASH_NF_ECC_RESET, ecc_reset.wrd);
+
+ flash_int_sts.bf.regirq = 1;
+ write_flash_ctrl_reg(FLASH_FLASH_INTERRUPT, flash_int_sts.wrd);
+
+ ecc_reset.wrd = 0;
+ ecc_reset.bf.eccclear = 1;
+ write_flash_ctrl_reg(FLASH_NF_ECC_RESET, ecc_reset.wrd);
+
+#ifdef CONFIG_NAND_CORTINA_ECC_HW_BCH
+ bch_ctrl.wrd = 0;
+ bch_ctrl.bf.bchen = BCH_ENABLE;
+ bch_ctrl.bf.bchopcode = BCH_DECODE;
+#if (CONFIG_NAND_CORTINA_ECC_LEVEL == 2)
+ bch_ctrl.bf.bcherrcap = BCH_ERR_CAP_8;
+#elif (CONFIG_NAND_CORTINA_ECC_LEVEL == 3)
+ bch_ctrl.bf.bcherrcap = BCH_ERR_CAP_16;
+#elif (CONFIG_NAND_CORTINA_ECC_LEVEL == 4)
+ bch_ctrl.bf.bcherrcap = BCH_ERR_CAP_24;
+#elif (CONFIG_NAND_CORTINA_ECC_LEVEL == 5)
+ bch_ctrl.bf.bcherrcap = BCH_ERR_CAP_40;
+#else
+ printf("BCH Level is not recognized! %s:%d\n", __func__, __LINE__);
+#endif
+ write_flash_ctrl_reg(FLASH_NF_BCH_CONTROL, 0);
+#else
+
+ ecc_ctl.wrd = 0;
+ if ((eccsize - 1) == NCNT_512P_DATA)
+ ecc_ctl.bf.eccgenmode = ECC_GEN_512;
+ else
+ ecc_ctl.bf.eccgenmode = ECC_GEN_256;
+ ecc_ctl.bf.eccen = ECC_ENABLE;
+ write_flash_ctrl_reg(FLASH_NF_ECC_CONTROL, ecc_ctl.wrd);
+#endif
+
+ /*disable txq5 */
+ dma_txq5_ctrl.bf.txq_en = 0;
+ write_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_TXQ_CONTROL, dma_txq5_ctrl.wrd);
+
+ dma_ssp_txq5_intsts.wrd =
+ read_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_TXQ_COAL_INTERRUPT);
+ dma_ssp_txq5_intsts.bf.txq_eof = 0;
+ write_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_TXQ_COAL_INTERRUPT,
+ dma_ssp_txq5_intsts.wrd);
+ dma_ssp_rxq5_intsts.wrd =
+ read_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_RXQ_COAL_INTERRUPT);
+ dma_ssp_rxq5_intsts.bf.rxq_eof = 0;
+ write_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_RXQ_COAL_INTERRUPT,
+ dma_ssp_rxq5_intsts.wrd);
+
+ /*for indirect access with DMA, because DMA not ready */
+ nf_cnt.wrd = 0;
+ nf_cmd.wrd = 0;
+ nf_addr1.wrd = 0;
+ nf_addr2.wrd = 0;
+ nf_cnt.wrd = 0;
+ nf_cnt.bf.nflashregoobcount = mtd->oobsize - 1;
+ nf_cnt.bf.nflashregdatacount = mtd->writesize - 1;
+
+ if (chip->chipsize < (32 << 20)) {
+ nf_cnt.bf.nflashregaddrcount = NCNT_ADDR_3;
+ nf_cnt.bf.nflashregcmdcount = NCNT_CMD_1;
+ nf_cmd.bf.nflashregcmd0 = NAND_CMD_READ0;
+ nf_addr1.wrd = (((page & 0x00ffffff) << 8));
+ nf_addr2.wrd = ((page & 0xff000000) >> 24);
+ } else if ((chip->chipsize >= (32 << 20)) &&
+ (chip->chipsize <= (128 << 20))) {
+ nf_cnt.bf.nflashregaddrcount = NCNT_ADDR_4;
+ nf_cnt.bf.nflashregcmdcount = NCNT_CMD_1;
+ nf_cmd.bf.nflashregcmd0 = NAND_CMD_READ0;
+
+ if (mtd->writesize > NCNT_512P_DATA) {
+ nf_cnt.bf.nflashregcmdcount = NCNT_CMD_2;
+ nf_cmd.bf.nflashregcmd1 = NAND_CMD_READSTART;
+ }
+ nf_addr1.wrd = (((page & 0xffff) << 16));
+ nf_addr2.wrd = ((page & 0xffff0000) >> 16);
+ } else { /*if((chip->chipsize > (128 << 20)) )) */
+ nf_cnt.bf.nflashregaddrcount = NCNT_ADDR_5;
+ nf_cnt.bf.nflashregcmdcount = NCNT_CMD_2;
+ nf_cmd.bf.nflashregcmd0 = NAND_CMD_READ0;
+ nf_cmd.bf.nflashregcmd1 = NAND_CMD_READSTART;
+ nf_addr1.wrd = (((page & 0xffff) << 16));
+ nf_addr2.wrd = ((page & 0xffff0000) >> 16);
+ }
+
+ write_flash_ctrl_reg(FLASH_NF_COUNT, nf_cnt.wrd);
+ /*write read id command */
+ write_flash_ctrl_reg(FLASH_NF_COMMAND, nf_cmd.wrd);
+ /*write address 0x0 */
+ write_flash_ctrl_reg(FLASH_NF_ADDRESS_1, nf_addr1.wrd);
+ write_flash_ctrl_reg(FLASH_NF_ADDRESS_2, nf_addr2.wrd);
+
+ nf_access.wrd = 0;
+ nf_access.bf.nflashcealt = CHIP_EN;
+ nf_access.bf.nflashregwidth = NFLASH_WIDTH8;
+
+ nf_access.bf.nflashextaddr = ((page << chip->page_shift) / 0x8000000);
+ write_flash_ctrl_reg(FLASH_NF_ACCESS, nf_access.wrd);
+
+ addr =
+ (unsigned int *)(((unsigned long)page << chip->page_shift) %
+ 0x8000000);
+ addr =
+ (unsigned int *)((unsigned long)addr +
+ (unsigned int)(CONFIG_SYS_FLASH_BASE));
+
+ dma_txq5_wptr.wrd = read_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_TXQ_WPTR);
+
+ tx_desc[dma_txq5_wptr.bf.index].word1.bf.own = OWN_DMA;
+ tx_desc[dma_txq5_wptr.bf.index].word1.bf.buf_len = mtd->writesize;
+ tx_desc[dma_txq5_wptr.bf.index].buf_adr = (unsigned long)addr;
+
+ /*oob tx desc */
+ dma_txq5_wptr.bf.index = (dma_txq5_wptr.bf.index + 1) % FDMA_DESC_NUM;
+
+ addr = (unsigned int *)((unsigned long)addr + mtd->writesize);
+ tx_desc[dma_txq5_wptr.bf.index].word1.bf.own = OWN_DMA;
+ tx_desc[dma_txq5_wptr.bf.index].word1.bf.buf_len = mtd->oobsize;
+ tx_desc[dma_txq5_wptr.bf.index].buf_adr = (unsigned long)addr;
+
+ /*page data rx desc */
+ dma_rxq5_rptr.wrd = read_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_RXQ_RPTR);
+ rx_desc[dma_rxq5_rptr.bf.index].word1.bf.own = OWN_DMA;
+ rx_desc[dma_rxq5_rptr.bf.index].word1.bf.buf_len = mtd->writesize;
+
+ rx_desc[dma_rxq5_rptr.bf.index].buf_adr = (unsigned long)(buf);
+
+ /*oob rx desc */
+ dma_rxq5_rptr.bf.index = (dma_rxq5_rptr.bf.index + 1) % FDMA_DESC_NUM;
+ rx_desc[dma_rxq5_rptr.bf.index].word1.bf.own = OWN_DMA;
+ rx_desc[dma_rxq5_rptr.bf.index].word1.bf.buf_len = mtd->oobsize;
+ rx_desc[dma_rxq5_rptr.bf.index].buf_adr = (unsigned long)chip->oob_poi;
+
+ flash_fifo_ctrl.wrd = read_flash_ctrl_reg(FLASH_FIFO_CONTROL);
+ flash_fifo_ctrl.bf.fifocmd = FIFO_CMD_READ;
+ write_flash_ctrl_reg(FLASH_FIFO_CONTROL, flash_fifo_ctrl.wrd);
+
+ flash_start.wrd = 0;
+ flash_start.bf.nflashfiforeq = FLASH_GO;
+ /*flash_start.bf.nflashRegCmd = FLASH_RD; */
+ write_flash_ctrl_reg(FLASH_FLASH_ACCESS_START, flash_start.wrd);
+
+ /*update tx write ptr */
+ dma_txq5_wptr.bf.index = (dma_txq5_wptr.bf.index + 1) % FDMA_DESC_NUM;
+ write_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_TXQ_WPTR, dma_txq5_wptr.wrd);
+
+ /* enable txq5 */
+ dma_txq5_ctrl.bf.txq_en = 1;
+ write_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_TXQ_CONTROL, dma_txq5_ctrl.wrd);
+
+ tmp_dma_ssp_rxq5_intsts.wrd = 0;
+ tmp_dma_ssp_rxq5_intsts.bf.rxq_eof = 1;
+
+ dma_wait(DMA_SEC_DMA_SSP_Q_RXQ_COAL_INTERRUPT,
+ tmp_dma_ssp_rxq5_intsts.wrd, tmp_dma_ssp_rxq5_intsts.wrd,
+ 1000);
+
+ tmp_dma_ssp_txq5_intsts.wrd = 0;
+ tmp_dma_ssp_txq5_intsts.bf.txq_eof = 1;
+
+ dma_wait(DMA_SEC_DMA_SSP_Q_TXQ_COAL_INTERRUPT,
+ tmp_dma_ssp_txq5_intsts.wrd, tmp_dma_ssp_txq5_intsts.wrd,
+ 1000);
+
+ tmp_access.wrd = 0;
+ tmp_access.bf.nflashfiforeq = 1;
+ reg_wait(FLASH_FLASH_ACCESS_START, tmp_access.wrd, 0, 1000);
+
+ dma_rxq5_rptr.bf.index = (dma_rxq5_rptr.bf.index + 1) % FDMA_DESC_NUM;
+ write_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_RXQ_RPTR, dma_rxq5_rptr.wrd);
+
+ return 0;
+}
+
+/*
+ * ca_nand_write_page - [REPLACEABLE] write one page
+ * @mtd: MTD device structure
+ * @chip: NAND chip descr
+ * @buf: the data to write
+ * @page: page number to write
+ * @cached: cached programming
+ * @raw: use _raw version of write_page
+ */
+int ca_nand_write_page(struct mtd_info *mtd, struct nand_chip *chip,
+ u32 offset, int data_len, const u8 *buf,
+ int oob_required, int page, int raw)
+{
+ int status;
+
+ chip->cmdfunc(mtd, NAND_CMD_SEQIN, 0x00, page);
+
+ if (unlikely(raw))
+ chip->ecc.write_page_raw(mtd, chip, buf, 1, page);
+ else
+ chip->ecc.write_page(mtd, chip, buf, 1, page);
+
+ /*
+ * Cached progamming disabled for now, Not sure if its worth the
+ * trouble. The speed gain is not very impressive. (2.3->2.6Mib/s)
+ */
+ int cached = 0;
+
+ if (!cached || !(chip->options & NAND_CACHEPRG)) {
+ chip->cmdfunc(mtd, NAND_CMD_PAGEPROG, -1, -1);
+ status = chip->waitfunc(mtd, chip);
+
+ if (status & NAND_STATUS_FAIL)
+ return -EIO;
+ } else {
+ chip->cmdfunc(mtd, NAND_CMD_CACHEDPROG, -1, -1);
+ status = chip->waitfunc(mtd, chip);
+ }
+
+#ifdef CONFIG_MTD_NAND_VERIFY_WRITE
+ /* Send command to read back the data */
+ chip->cmdfunc(mtd, NAND_CMD_READ0, 0, page);
+
+ if (chip->verify_buf(mtd, buf, mtd->writesize))
+ return -EIO;
+#endif
+ return 0;
+}
+
+/* Extract the bits of per cell from the 3rd byte of the extended ID */
+int nand_get_bits_per_cell(u8 cellinfo)
+{
+ int bits;
+
+ bits = cellinfo & NAND_CI_CELLTYPE_MSK;
+ bits >>= NAND_CI_CELLTYPE_SHIFT;
+ return bits + 1;
+}
+
+static inline bool is_full_id_nand(struct nand_flash_dev *type)
+{
+ return type->id_len;
+}
+
+static bool find_full_id_nand(struct mtd_info *mtd, struct nand_chip *chip,
+ struct nand_flash_dev *type, u8 *id_data,
+ int *busw)
+{
+#ifndef __UBOOT__
+ if (!strncmp(type->id, id_data, type->id_len)) {
+#else
+ if (!strncmp((char *)type->id, (char *)id_data, type->id_len)) {
+#endif
+ mtd->writesize = type->pagesize;
+ mtd->erasesize = type->erasesize;
+ mtd->oobsize = type->oobsize;
+
+ chip->bits_per_cell = nand_get_bits_per_cell(id_data[2]);
+ chip->chipsize = (uint64_t)type->chipsize << 20;
+ chip->options |= type->options;
+ chip->ecc_strength_ds = NAND_ECC_STRENGTH(type);
+ chip->ecc_step_ds = NAND_ECC_STEP(type);
+
+ *busw = type->options & NAND_BUSWIDTH_16;
+
+ if (!mtd->name)
+ mtd->name = type->name;
+
+ return true;
+ }
+ return false;
+}
+
+/*
+ * Get the flash and manufacturer id and lookup if the type is supported
+ */
+struct nand_flash_dev *ca_nand_get_flash_type(struct mtd_info *mtd,
+ struct nand_chip *chip, int busw,
+ int *maf_id)
+{
+ struct nand_flash_dev *type = NULL;
+ int maf_idx = 0;
+ unsigned char id[8];
+ u16 oobsize_8kp[] = { 0, 128, 218, 400, 436, 512, 640, 0 };
+ union FLASH_TYPE_t flash_type;
+
+ /* Select the device */
+ chip->select_chip(mtd, 0);
+
+ /*
+ * Reset the chip, required by some chips (e.g. Micron MT29FxGxxxxx)
+ * after power-up
+ */
+ chip->cmdfunc(mtd, NAND_CMD_RESET, -1, -1);
+
+ /* Try if this is ONFI supported chip */
+ if (ca_nand_flash_detect_onfi(mtd, chip, &busw) == 1) {
+ printf("ONFI\n");
+ goto SET_FLASH_TYPE;
+ } else {
+ printf("Legacy\n");
+ }
+
+ /* Send the command for reading device ID */
+ chip->cmdfunc(mtd, NAND_CMD_RESET, -1, -1);
+ chip->cmdfunc(mtd, NAND_CMD_READID, 0x00, -1);
+
+ /* Read manufacturer and device IDs */
+ memset(id, 0, sizeof(id));
+ ca_nand_read_id(0, &id[0]);
+ chip->cmdfunc(mtd, NAND_CMD_RESET, -1, -1);
+ *maf_id = id[0];
+ //dev_id = id[1];
+ printf("id[0:7]=0x%02x, 0x%02x, 0x%02x, 0x%02x,",
+ id[0], id[1], id[2], id[3]);
+ printf(" 0x%02x, 0x%02x, 0x%02x, 0x%02x\n",
+ id[4], id[5], id[6], id[7]);
+ /* Try again to make sure, as some systems the bus-hold or other
+ * interface concerns can cause random data which looks like a
+ * possibly credible NAND flash to appear. If the two results do
+ * not match, ignore the device completely.
+ */
+
+ chip->cmdfunc(mtd, NAND_CMD_READID, 0x00, -1);
+
+ if (!type)
+ type = nand_flash_ids;
+
+ for (; type->name; type++) {
+ if (is_full_id_nand(type)) {
+ if (find_full_id_nand(mtd, chip, type, id, &busw))
+ goto IDENT_DONE;
+ } else if (id[1] == type->dev_id) {
+ break;
+ }
+ }
+
+ if (!type)
+ return ERR_PTR(-ENODEV);
+
+ if (!mtd->name)
+ mtd->name = type->name;
+
+ chip->chipsize = (uint64_t)type->chipsize << 20;
+
+ /* Newer devices have all the information in additional id bytes */
+ if (!type->pagesize) {
+ int extid;
+ /* The 3rd id byte holds MLC / multichip data */
+ //chip->cellinfo = id[2];//chip->read_byte(mtd);
+ chip->bits_per_cell = nand_get_bits_per_cell(id[2]);
+ /* The 4th id byte is the important one */
+ extid = id[3];
+ if (id[0] == id[6] && id[1] == id[7] &&
+ id[0] == NAND_MFR_SAMSUNG && !nand_is_slc(chip) &&
+ id[5] != 0x00) {
+ mtd->writesize = 2048 * (1 << (extid & 0x3));
+
+ /* Calc oobsize */
+ mtd->oobsize =
+ oobsize_8kp[((extid & 0x40) >> 4) +
+ ((extid >> 2) & 0x03)];
+
+ /* Calc blocksize. Blocksize is multiples of 128KB */
+ mtd->erasesize =
+ (1 <<
+ (((extid & 0x80) >> 5) +
+ ((extid >> 4) & 0x03))) * (128 * 1024);
+ busw = 0;
+ } else {
+ /* Calc pagesize */
+ mtd->writesize = 1024 << (extid & 0x3);
+ extid >>= 2;
+ /* Calc oobsize */
+ mtd->oobsize =
+ (8 << (extid & 0x01)) * (mtd->writesize >> 9);
+ extid >>= 2;
+ /* Calc blocksize. Blocksize is multiples of 64KiB */
+ mtd->erasesize = (64 * 1024) << (extid & 0x03);
+ extid >>= 2;
+ /* Get buswidth information */
+ busw = (extid & 0x01) ? NAND_BUSWIDTH_16 : 0;
+ }
+ } else {
+ /*
+ * Old devices have chip data hardcoded in the device id table
+ */
+ mtd->name = type->name;
+ mtd->erasesize = type->erasesize;
+ mtd->writesize = type->pagesize;
+ mtd->oobsize = type->oobsize;
+// mtd->oobsize = mtd->writesize / 32;
+ busw = type->options & NAND_BUSWIDTH_16;
+ }
+
+ IDENT_DONE:
+ /* Try to identify manufacturer */
+ for (maf_idx = 0; nand_manuf_ids[maf_idx].id != 0x0; maf_idx++) {
+ if (nand_manuf_ids[maf_idx].id == *maf_id)
+ break;
+ }
+
+ SET_FLASH_TYPE:
+/////// middle debug : oob size not 4 bytes alignment
+ if (mtd->oobsize % 8)
+ mtd->oobsize = mtd->oobsize - (mtd->oobsize % 8);
+///////
+
+ printf("P-NAND : %s\n", mtd->name);
+ printf("Chip Size: %lldMB\n", chip->chipsize / (1024 * 1024));
+ printf("Block Size: %dKB\n", mtd->erasesize / 1024);
+ printf("Page Size: %dB\n", mtd->writesize);
+ printf("OOB Size: %dB\n", mtd->oobsize);
+
+ /*
+ * Check, if buswidth is correct. Hardware drivers should set
+ * chip correct !
+ */
+ if (busw != (chip->options & NAND_BUSWIDTH_16)) {
+ printf("NAND dev: Manufacturer ID 0x%02x, ",
+ *maf_id);
+ printf("Chip ID: 0x%02x (%s %s)\n",
+ id[1], nand_manuf_ids[maf_idx].name, mtd->name);
+ printf("NAND bus width %d instead %d bit\n",
+ (chip->options & NAND_BUSWIDTH_16) ? 16 : 8, busw ? 16 : 8);
+ return ERR_PTR(-EINVAL);
+ }
+
+ /* Calculate the address shift from the page size */
+ chip->page_shift = ffs(mtd->writesize) - 1;
+ /* Convert chipsize to number of pages per chip -1. */
+ chip->pagemask = (chip->chipsize >> chip->page_shift) - 1;
+
+ chip->bbt_erase_shift = ffs(mtd->erasesize) - 1;
+ chip->phys_erase_shift = ffs(mtd->erasesize) - 1;
+ if (chip->chipsize & 0xffffffff)
+ chip->chip_shift = ffs((unsigned int)chip->chipsize) - 1;
+ else
+ chip->chip_shift =
+ ffs((unsigned int)(chip->chipsize >> 32)) + 32 - 1;
+
+ /* Set the bad block position */
+ chip->badblockpos =
+ mtd->writesize >
+ 512 ? NAND_LARGE_BADBLOCK_POS : NAND_SMALL_BADBLOCK_POS;
+
+ /* Get chip options, preserve non chip based options */
+ //chip->options &= ~NAND_CHIPOPTIONS_MSK;
+ if (type)
+ chip->options |= type->options;
+ else
+ chip->options = NAND_NO_SUBPAGE_WRITE;
+
+ /*
+ * Set chip as a default. Board drivers can override it, if necessary
+ */
+ //chip->options |= NAND_NO_AUTOINCR;
+
+ /* Check if chip is a not a samsung device. Do not clear the
+ * options for chips which are not having an extended id.
+ */
+ if (*maf_id != NAND_MFR_SAMSUNG && !mtd->writesize)
+ chip->options &= ~NAND_SAMSUNG_LP_OPTIONS;
+
+#ifdef DEBUG
+ printf("NAND dev: Manufacturer ID: 0x%02x, Chip ID: 0x%02x (%s %s)\n",
+ *maf_id, dev_id, nand_manuf_ids[maf_idx].name, type->name);
+#endif
+
+ flash_type.wrd = read_flash_ctrl_reg(FLASH_TYPE);
+ switch (mtd->writesize) {
+ case 512:
+ flash_type.bf.flashtype = 0 | 0x4;
+ break;
+ case 2048:
+ flash_type.bf.flashtype = 1 | 0x4;
+ break;
+ case 4096:
+ flash_type.bf.flashtype = 2 | 0x4;
+ break;
+ case 8192:
+ flash_type.bf.flashtype = 3 | 0x4;
+ break;
+ }
+ flash_type.bf.flashsize = 0;
+ write_flash_ctrl_reg(FLASH_TYPE, flash_type.wrd);
+
+ return type;
+}
+
+/*
+ * hardware specific access to control-lines
+ * ctrl:
+ */
+void ca_nand_hwcontrol(struct mtd_info *mtd, int cmd, unsigned int ctrl)
+{
+ /* Nothing to do */
+}
+
+/*
+ * ca_nand_default_block_markbad - [DEFAULT] mark a block bad
+ * @mtd: MTD device structure
+ * @ofs: offset from device start
+ *
+ * This is the default implementation, which can be overridden by
+ * a hardware specific driver.
+ */
+int ca_nand_default_block_markbad(struct mtd_info *mtd, loff_t ofs)
+{
+ struct nand_chip *chip = mtd->priv;
+ u8 buf[2] = { 0, 0 };
+ struct mtd_oob_ops ops;
+ int block, ret;
+
+ /* Get block number */
+ block = (int)(ofs >> chip->bbt_erase_shift);
+ if (chip->bbt)
+ chip->bbt[block >> 2] |= 0x01 << ((block & 0x03) << 1);
+
+ /* We write two bytes, so we don't have to mess with 16 bit
+ * access
+ */
+ ca_nand_get_device(chip, mtd, FL_WRITING);
+ ofs += mtd->oobsize;
+ ops.mode = MTD_OPS_PLACE_OOB;
+ ops.ooblen = 2;
+ ops.len = 2;
+ ops.datbuf = NULL;
+ ops.oobbuf = buf;
+ ops.ooboffs = chip->badblockpos & ~0x01;
+
+ ret = ca_nand_do_write_oob(mtd, ofs, &ops);
+ ca_nand_release_device(mtd);
+
+ if (!ret)
+ mtd->ecc_stats.badblocks++;
+
+#ifdef CONFIG_NAND_HIDE_BAD
+ if (!ret)
+ update_bad_block_list(block << chip->bbt_erase_shift, 1);
+#endif
+ return ret;
+}
+
+/*
+ * ca_nand_block_bad - [DEFAULT] Read bad block marker from the chip
+ * @mtd: MTD device structure
+ * @ofs: offset from device start
+ * @getchip: 0, if the chip is already selected
+ *
+ * Check, if the block is bad.
+ */
+int ca_nand_block_bad(struct mtd_info *mtd, loff_t ofs)
+{
+#ifdef CONFIG_NAND_HIDE_BAD
+ if (!acc_phy_offset)
+ return 0;
+#endif
+
+ int page, res = 0;
+ struct nand_chip *chip = mtd->priv;
+
+ page = (int)(ofs >> chip->page_shift) & chip->pagemask;
+
+ ca_nand_read_oob_std(mtd, chip, page);
+
+ if (chip->oob_poi[chip->badblockpos] != 0xff)
+ return 1;
+
+ return res;
+}
+
+#define NOTALIGNED(x) (((x) & (chip->subpagesize - 1)) != 0)
+/*
+ * ca_nand_do_write_ops - [Internal] NAND write with ECC
+ * @mtd: MTD device structure
+ * @to: offset to write to
+ * @ops: oob operations description structure
+ *
+ * NAND write with ECC
+ */
+static int ca_nand_do_write_ops(struct mtd_info *mtd, loff_t to,
+ struct mtd_oob_ops *ops)
+{
+ int chipnr, realpage, page, column;
+ struct nand_chip *chip = mtd->priv;
+ u32 writelen = ops->len;
+ u8 *oob = ops->oobbuf;
+ u8 *buf = ops->datbuf;
+ int ret, subpage;
+ int oob_required = oob ? 1 : 0;
+
+ ops->retlen = 0;
+ if (!writelen)
+ return 0;
+
+ /* reject writes, which are not page aligned */
+ if (NOTALIGNED(to) || NOTALIGNED(ops->len)) {
+ printf("%s: Attempt to write non page aligned data\n",
+ __func__);
+ return -EINVAL;
+ }
+
+ column = to & (mtd->writesize - 1);
+ subpage = column || (writelen & (mtd->writesize - 1));
+
+ if (subpage && oob)
+ return -EINVAL;
+
+ chipnr = (int)(to >> chip->chip_shift);
+ chip->select_chip(mtd, chipnr);
+
+ /* Check, if it is write protected */
+ if (ca_nand_check_wp(mtd))
+ return -EIO;
+
+ realpage = (int)(to >> chip->page_shift);
+ page = realpage & chip->pagemask;
+
+ /* Invalidate the page cache, when we write to the cached page */
+ if (to <= (chip->pagebuf << chip->page_shift) &&
+ (chip->pagebuf << chip->page_shift) < (to + ops->len))
+ chip->pagebuf = -1;
+
+ /* If we're not given explicit OOB data, let it be 0xFF */
+ if (likely(!oob))
+ memset(chip->oob_poi, 0xff, mtd->oobsize);
+
+ while (1) {
+#ifdef CONFIG_NAND_HIDE_BAD
+ if (!acc_phy_offset)
+ page = xlat_offset_to_skip_bad(mtd, page);
+#endif
+
+ int bytes = mtd->writesize;
+ u8 *wbuf = buf;
+
+ /* Partial page write ? */
+ if (unlikely(column || writelen < (mtd->writesize - 1))) {
+ bytes = min_t(int, bytes - column, (int)writelen);
+ chip->pagebuf = -1;
+ chip->ecc.read_page(mtd, chip, chip->buffers->databuf,
+ 1, page);
+ memcpy(&chip->buffers->databuf[column], buf, bytes);
+ wbuf = chip->buffers->databuf;
+ }
+
+ if (unlikely(oob))
+ oob = ca_nand_fill_oob(chip, oob, ops);
+
+ ret =
+ chip->write_page(mtd, chip, column, bytes, wbuf,
+ oob_required, page,
+ (ops->mode == MTD_OPS_RAW));
+ if (ret)
+ break;
+
+ writelen -= bytes;
+ if (!writelen)
+ break;
+
+ column = 0;
+ buf += bytes;
+ realpage++;
+ page = realpage & chip->pagemask;
+
+ /* Check, if we cross a chip boundary */
+ if (!page) {
+ chipnr++;
+ chip->select_chip(mtd, -1);
+ chip->select_chip(mtd, chipnr);
+ }
+ }
+
+ ops->retlen = ops->len - writelen;
+ if (unlikely(oob))
+ ops->oobretlen = ops->ooblen;
+ return ret;
+}
+
+/*
+ * ca_nand_wait - [DEFAULT] wait until the command is done
+ * @mtd: MTD device structure
+ * @chip: NAND chip structure
+ *
+ * Wait for command done. This applies to erase and program only
+ * Erase can take up to 400ms and program up to 20ms according to
+ * general NAND and SmartMedia specs
+ */
+/* XXX U-BOOT XXX */
+int ca_nand_wait(struct mtd_info *mtd, struct nand_chip *this)
+{
+ unsigned long timeo;
+ int state = this->state;
+
+ if (state == FL_ERASING)
+ timeo = (CONFIG_SYS_HZ * 400) / 1000;
+ else
+ timeo = (CONFIG_SYS_HZ * 20) / 1000;
+
+ timeo = (state == FL_ERASING ? 400 : 20);
+
+ /* reset_timer(); */
+ timeo += get_timer(0);
+
+ while (1) {
+ if (get_timer(0) > timeo) {
+ printf("Timeout!");
+ return 0x01;
+ }
+
+ if (this->dev_ready) {
+ if (this->dev_ready(mtd))
+ break;
+ } else {
+ /* if (this->read_byte(mtd) & NAND_STATUS_READY) */
+ break;
+ }
+ }
+
+ state = read_flash_ctrl_reg(FLASH_NF_DATA) & 0xff;
+ return state;
+}
+
+void ca_nand_enable_hwecc(struct mtd_info *mtd, int mode)
+{
+ /* Always enabled! */
+}
+
+/*
+ * ca_nand_verify_buf - [DEFAULT] Verify chip data against buffer
+ * @mtd: MTD device structure
+ * @buf: buffer containing the data to compare
+ * @len: number of bytes to compare
+ *
+ * Default verify function for 8bit buswith
+ */
+#ifdef CONFIG_MTD_NAND_VERIFY_WRITE
+int ca_nand_verify_buf(struct mtd_info *mtd, const u8 *buf, int len)
+{
+ int i, page = 0;
+ struct nand_chip *chip = mtd->priv;
+ //u_char *tmpdata, *tmpoob;tmpdata ,tmpoob
+ size_t retlen;
+
+ retlen = 0;
+ page = host->page_addr;
+ memset(chip->buffers->databuf, 0, mtd->writesize);
+ chip->ecc.read_page(mtd, chip, chip->buffers->databuf, page);
+
+ if (len == mtd->writesize) {
+ for (i = 0; i < len; i++) {
+ if (buf[i] != chip->buffers->databuf[i]) {
+ printf("Data verify error -> page: ");
+ printf("%x, byte: %x, buf[i]:%x ",
+ host->page_addr, i, buf[i]);
+ printf("chip->buffers->databuf[i]:%x\n",
+ chip->buffers->databuf[i]);
+ return i;
+ }
+ }
+ } else if (len == mtd->oobsize) {
+ for (i = 0; i < len; i++) {
+ if (buf[i] != chip->oob_poi[i]) {
+ printf("OOB verify error -> page: %x, byte: %x,",
+ host->page_addr, i);
+ printf("buf[i]:%x chip->oob_poi[i]:%x\n",
+ buf[i], chip->oob_poi[i]);
+ return i;
+ }
+ }
+ } else {
+ printf("verify length not match 0x%08x\n", len);
+
+ return -1;
+ }
+
+ return 0;
+}
+#endif
+
+/*
+ * ca_nand_read_buf - [DEFAULT] read chip data into buffer
+ * @mtd: MTD device structure
+ * @buf: buffer to store date
+ * @len: number of bytes to read
+ *
+ * Default read function for 8bit buswith
+ */
+void ca_nand_read_buf(struct mtd_info *mtd, u8 *buf, int len)
+{
+ int page, col;
+ struct nand_chip *this = mtd->priv;
+ struct ca_nand_host *host = nand_chip->priv;
+
+ if (len <= (mtd->writesize + mtd->oobsize)) {
+ page = host->page_addr;
+ col = host->col_addr;
+
+ this->ecc.read_page(mtd, this, this->buffers->databuf, 1, page);
+ memcpy(buf, &this->buffers->databuf[col], len);
+ }
+}
+
+/*
+ * ca_nand_write_buf - [DEFAULT] write buffer to chip
+ * @mtd: MTD device structure
+ * @buf: data buffer
+ * @len: number of bytes to write
+ *
+ * Default write function for 8bit buswith
+ */
+void ca_nand_write_buf(struct mtd_info *mtd, const u8 *buf, int len)
+{
+ int i, page = 0, col = 0;
+ struct nand_chip *chip = mtd->priv;
+ struct ca_nand_host *host = nand_chip->priv;
+
+ /* if(len <= (mtd->writesize+mtd->oobsize)) */
+ if (len <= (mtd->writesize + mtd->oobsize)) {
+ page = host->page_addr;
+ col = host->col_addr;
+
+ chip->ecc.read_page(mtd, chip, chip->buffers->databuf, 1, page);
+
+ for (i = 0; i < len; i++)
+ chip->buffers->databuf[col + i] = buf[i];
+
+ chip->ecc.write_page(mtd, chip, chip->buffers->databuf, 1,
+ page);
+ }
+}
+
+/*
+ * ca_nand_read_byte - [DEFAULT] read one byte from the chip
+ * @mtd: MTD device structure
+ *
+ * Default read function for 8bit buswith
+ */
+u8 ca_nand_read_byte(struct mtd_info *mtd)
+{
+ struct nand_chip *chip = mtd->priv;
+ struct ca_nand_host *host = nand_chip->priv;
+ unsigned int data = 0, page = 0, col = 0;
+
+ page = host->page_addr;
+ col = host->col_addr;
+
+ ca_nand_read_page_raw(mtd, chip, chip->buffers->databuf, 1, page);
+ data = *(chip->buffers->databuf + col);
+
+ return data & 0xff;
+}
+
+/*
+ * ca_nand_select_chip - [DEFAULT] control CE line
+ * @mtd: MTD device structure
+ * @chipnr: chipnumber to select, -1 for deselect
+ *
+ * Default select function for 1 chip devices.
+ */
+void ca_nand_select_chip(struct mtd_info *mtd, int chipnr)
+{
+ switch (chipnr) {
+ case -1:
+ CHIP_EN = NFLASH_CHIP0_EN;
+ break;
+ case 0:
+ CHIP_EN = NFLASH_CHIP0_EN;
+ break;
+ case 1:
+ CHIP_EN = NFLASH_CHIP1_EN;
+ break;
+
+ default:
+ CHIP_EN = NFLASH_CHIP0_EN;
+ /* BUG(); */
+ }
+}
+
+/*
+ * Wait for the ready pin, after a command
+ * The timeout is catched later.
+ */
+void ca_nand_wait_ready(struct mtd_info *mtd)
+{
+ struct nand_chip *chip = mtd->priv;
+ u32 timeo = (CONFIG_SYS_HZ * 20) / 1000;
+
+ /* reset_timer(); */
+ timeo += get_timer(0);
+ /* wait until command is processed or timeout occures */
+ while (get_timer(0) < timeo) {
+ if (chip->dev_ready)
+ if (chip->dev_ready(mtd))
+ break;
+ }
+}
+
+/*
+ * ca_nand_command - [DEFAULT] Send command to NAND device
+ * @mtd: MTD device structure
+ * @command: the command to be sent
+ * @column: the column address for this command, -1 if none
+ * @page_addr: the page address for this command, -1 if none
+ *
+ * Send command to NAND device. This function is used for small page
+ * devices (256/512 Bytes per page)
+ */
+static void ca_nand_command(struct mtd_info *mtd, unsigned int command,
+ int column, int page_addr)
+{
+ register struct nand_chip *chip = mtd->priv;
+
+ int ctrl = NAND_CTRL_CLE | NAND_CTRL_CHANGE;
+ struct ca_nand_host *host = nand_chip->priv;
+
+ union FLASH_FLASH_ACCESS_START_t tmp_access;
+
+ /*
+ * Write out the command to the device.
+ */
+ if (command == NAND_CMD_SEQIN) {
+ int readcmd;
+
+ if (column >= mtd->writesize) {
+ /* OOB area */
+ column -= mtd->writesize;
+ readcmd = NAND_CMD_READOOB;
+ } else if (column < 256) {
+ /* First 256 bytes --> READ0 */
+ readcmd = NAND_CMD_READ0;
+ } else {
+ column -= 256;
+ readcmd = NAND_CMD_READ1;
+ }
+ chip->cmd_ctrl(mtd, readcmd, ctrl);
+ ctrl &= ~NAND_CTRL_CHANGE;
+ }
+ chip->cmd_ctrl(mtd, command, ctrl);
+
+ /*
+ * Address cycle, when necessary
+ */
+ ctrl = NAND_CTRL_ALE | NAND_CTRL_CHANGE;
+ /* Serially input address */
+ if (column != -1) {
+ /* Adjust columns for 16 bit buswidth */
+ if (chip->options & NAND_BUSWIDTH_16)
+ column >>= 1;
+ chip->cmd_ctrl(mtd, column, ctrl);
+ ctrl &= ~NAND_CTRL_CHANGE;
+ host->col_addr = column;
+ }
+ if (page_addr != -1) {
+ chip->cmd_ctrl(mtd, page_addr, ctrl);
+ ctrl &= ~NAND_CTRL_CHANGE;
+ chip->cmd_ctrl(mtd, page_addr >> 8, ctrl);
+ /* One more address cycle for devices > 32MiB */
+ if (chip->chipsize > (32 << 20))
+ chip->cmd_ctrl(mtd, page_addr >> 16, ctrl);
+
+ host->page_addr = page_addr;
+ }
+ chip->cmd_ctrl(mtd, NAND_CMD_NONE, NAND_NCE | NAND_CTRL_CHANGE);
+
+ /*
+ * program and erase have their own busy handlers
+ * status and sequential in needs no delay
+ */
+ switch (command) {
+ case NAND_CMD_PAGEPROG:
+ case NAND_CMD_ERASE1:
+ case NAND_CMD_ERASE2:
+ case NAND_CMD_SEQIN:
+ case NAND_CMD_STATUS:
+ /*
+ * Write out the command to the device.
+ */
+ if (column != -1 || page_addr != -1) {
+ /* Serially input address */
+ if (column != -1)
+ /* FLASH_WRITE_REG(NFLASH_ADDRESS,column); */
+ host->col_addr = column;
+
+ if (page_addr != -1)
+ /* FLASH_WRITE_REG(NFLASH_ADDRESS,opcode|(page_addr<<8)); */
+ host->page_addr = page_addr;
+ }
+ return;
+
+ case NAND_CMD_RESET:
+ check_flash_ctrl_status();
+ udelay(chip->chip_delay);
+ /* disable ecc gen */
+ write_flash_ctrl_reg(FLASH_NF_ECC_CONTROL, 0x0);
+ nf_cnt.wrd = 0;
+ nf_cnt.bf.nflashregoobcount = NCNT_EMPTY_OOB;
+ nf_cnt.bf.nflashregdatacount = NCNT_EMPTY_DATA;
+ nf_cnt.bf.nflashregaddrcount = NCNT_EMPTY_ADDR;
+ nf_cnt.bf.nflashregcmdcount = NCNT_CMD_1;
+ write_flash_ctrl_reg(FLASH_NF_COUNT, nf_cnt.wrd);
+
+ nf_cmd.wrd = 0;
+ nf_cmd.bf.nflashregcmd0 = NAND_CMD_RESET;
+ /* write read id command */
+ write_flash_ctrl_reg(FLASH_NF_COMMAND, nf_cmd.wrd);
+ nf_addr1.wrd = 0;
+ /* write address 0x00 */
+ write_flash_ctrl_reg(FLASH_NF_ADDRESS_1, nf_addr1.wrd);
+ nf_addr2.wrd = 0;
+ /* write address 0x00 */
+ write_flash_ctrl_reg(FLASH_NF_ADDRESS_2, nf_addr2.wrd);
+
+ nf_access.wrd = 0;
+ nf_access.bf.nflashcealt = CHIP_EN;
+ /* nf_access.bf.nflashDirWr = ; */
+ nf_access.bf.nflashregwidth = NFLASH_WIDTH8;
+
+ write_flash_ctrl_reg(FLASH_NF_ACCESS, nf_access.wrd);
+ flash_start.wrd = 0;
+ flash_start.bf.nflashregreq = FLASH_GO;
+ flash_start.bf.nflashregcmd = FLASH_WT;
+ write_flash_ctrl_reg(FLASH_FLASH_ACCESS_START, flash_start.wrd);
+
+ tmp_access.wrd = 0;
+ tmp_access.bf.nflashregreq = 1;
+ reg_wait(FLASH_FLASH_ACCESS_START, tmp_access.wrd, 0, 1000);
+ flash_start.wrd = read_flash_ctrl_reg(FLASH_FLASH_ACCESS_START);
+
+ udelay(100);
+
+ /* FALLTHROUGH */
+ default:
+ /*
+ * If we don't have access to the busy pin, we apply the given
+ * command delay
+ */
+ if (!chip->dev_ready) {
+ udelay(chip->chip_delay);
+ return;
+ }
+ }
+ /* Apply this short delay always to ensure that we do wait tWB in
+ * any case on any machine.
+ */
+ udelay(100);
+
+ ca_nand_wait_ready(mtd);
+}
+
+/*
+ * ca_nand_command_lp - [DEFAULT] Send command to NAND large page device
+ * @mtd: MTD device structure
+ * @command: the command to be sent
+ * @column: the column address for this command, -1 if none
+ * @page_addr: the page address for this command, -1 if none
+ *
+ * Send command to NAND device. This is the version for the new large page
+ * devices We dont have the separate regions as we have in the small page
+ * devices. We must emulate NAND_CMD_READOOB to keep the code compatible.
+ */
+static void ca_nand_command_lp(struct mtd_info *mtd, unsigned int command,
+ int column, int page_addr)
+{
+ register struct nand_chip *chip = mtd->priv;
+ struct ca_nand_host *host = nand_chip->priv;
+ union FLASH_FLASH_ACCESS_START_t tmp_access;
+
+ /* Emulate NAND_CMD_READOOB */
+ if (command == NAND_CMD_READOOB) {
+ column += mtd->writesize;
+ command = NAND_CMD_READ0;
+ }
+
+ /* Command latch cycle */
+ chip->cmd_ctrl(mtd, command & 0xff,
+ NAND_NCE | NAND_CLE | NAND_CTRL_CHANGE);
+
+ if (column != -1 || page_addr != -1) {
+ int ctrl = NAND_CTRL_CHANGE | NAND_NCE | NAND_ALE;
+
+ /* Serially input address */
+ if (column != -1) {
+ /* Adjust columns for 16 bit buswidth */
+ if (chip->options & NAND_BUSWIDTH_16)
+ column >>= 1;
+ chip->cmd_ctrl(mtd, column, ctrl);
+ ctrl &= ~NAND_CTRL_CHANGE;
+ chip->cmd_ctrl(mtd, column >> 8, ctrl);
+ }
+ if (page_addr != -1) {
+ chip->cmd_ctrl(mtd, page_addr, ctrl);
+ chip->cmd_ctrl(mtd, page_addr >> 8,
+ NAND_NCE | NAND_ALE);
+ /* One more address cycle for devices > 128MiB */
+ if (chip->chipsize > (128 << 20))
+ chip->cmd_ctrl(mtd, page_addr >> 16,
+ NAND_NCE | NAND_ALE);
+ }
+ }
+ chip->cmd_ctrl(mtd, NAND_CMD_NONE, NAND_NCE | NAND_CTRL_CHANGE);
+
+ /*
+ * program and erase have their own busy handlers
+ * status, sequential in, and deplete1 need no delay
+ */
+ switch (command) {
+ case NAND_CMD_CACHEDPROG:
+ case NAND_CMD_PAGEPROG:
+ case NAND_CMD_ERASE1:
+ case NAND_CMD_ERASE2:
+ case NAND_CMD_SEQIN:
+ case NAND_CMD_RNDIN:
+ case NAND_CMD_STATUS:
+ case NAND_CMD_DEPLETE1:
+ /*
+ * Write out the command to the device.
+ */
+ if (column != -1 || page_addr != -1) {
+ /* Serially input address */
+ if (column != -1)
+ /* FLASH_WRITE_REG(NFLASH_ADDRESS,column); */
+ host->col_addr = column;
+
+ if (page_addr != -1)
+ /* FLASH_WRITE_REG(NFLASH_ADDRESS,opcode|(page_addr<<8)); */
+ host->page_addr = page_addr;
+ }
+ return;
+
+ /*
+ * read error status commands require only a short delay
+ */
+ case NAND_CMD_STATUS_ERROR:
+ case NAND_CMD_STATUS_ERROR0:
+ case NAND_CMD_STATUS_ERROR1:
+ case NAND_CMD_STATUS_ERROR2:
+ case NAND_CMD_STATUS_ERROR3:
+ udelay(chip->chip_delay);
+ return;
+
+ case NAND_CMD_RESET:
+
+ check_flash_ctrl_status();
+ udelay(chip->chip_delay);
+ /* disable ecc gen */
+ write_flash_ctrl_reg(FLASH_NF_ECC_CONTROL, 0x0);
+ nf_cnt.wrd = 0;
+ nf_cnt.bf.nflashregoobcount = NCNT_EMPTY_OOB;
+ nf_cnt.bf.nflashregdatacount = NCNT_EMPTY_DATA;
+ nf_cnt.bf.nflashregaddrcount = NCNT_EMPTY_ADDR;
+ nf_cnt.bf.nflashregcmdcount = NCNT_CMD_1;
+ write_flash_ctrl_reg(FLASH_NF_COUNT, nf_cnt.wrd);
+
+ nf_cmd.wrd = 0;
+ nf_cmd.bf.nflashregcmd0 = NAND_CMD_RESET;
+ /* write read id command */
+ write_flash_ctrl_reg(FLASH_NF_COMMAND, nf_cmd.wrd);
+ nf_addr1.wrd = 0;
+ /* write address 0x00 */
+ write_flash_ctrl_reg(FLASH_NF_ADDRESS_1, nf_addr1.wrd);
+ nf_addr2.wrd = 0;
+ /* write address 0x00 */
+ write_flash_ctrl_reg(FLASH_NF_ADDRESS_2, nf_addr2.wrd);
+
+ nf_access.wrd = 0;
+ nf_access.bf.nflashcealt = CHIP_EN;
+ nf_access.bf.nflashregwidth = NFLASH_WIDTH8;
+
+ write_flash_ctrl_reg(FLASH_NF_ACCESS, nf_access.wrd);
+ flash_start.wrd = 0;
+ flash_start.bf.nflashregreq = FLASH_GO;
+ flash_start.bf.nflashregcmd = FLASH_WT;
+ write_flash_ctrl_reg(FLASH_FLASH_ACCESS_START, flash_start.wrd);
+
+ tmp_access.wrd = 0;
+ tmp_access.bf.nflashregreq = 1;
+ reg_wait(FLASH_FLASH_ACCESS_START, tmp_access.wrd, 0, 1000);
+ flash_start.wrd = read_flash_ctrl_reg(FLASH_FLASH_ACCESS_START);
+
+ udelay(100);
+ return;
+
+ case NAND_CMD_RNDOUT:
+ /* No ready / busy check necessary */
+ chip->cmd_ctrl(mtd, NAND_CMD_RNDOUTSTART,
+ NAND_NCE | NAND_CLE | NAND_CTRL_CHANGE);
+ chip->cmd_ctrl(mtd, NAND_CMD_NONE, NAND_NCE | NAND_CTRL_CHANGE);
+ return;
+
+ case NAND_CMD_READ0:
+ chip->cmd_ctrl(mtd, NAND_CMD_READSTART,
+ NAND_NCE | NAND_CLE | NAND_CTRL_CHANGE);
+ chip->cmd_ctrl(mtd, NAND_CMD_NONE, NAND_NCE | NAND_CTRL_CHANGE);
+
+ /* FALLTHROUGH */
+ default:
+ /*
+ * If we don't have access to the busy pin, we apply the given
+ * command delay
+ */
+ if (!chip->dev_ready) {
+ udelay(chip->chip_delay);
+ return;
+ }
+ }
+
+ /* Apply this short delay always to ensure that we do wait tWB in
+ * any case on any machine.
+ */
+ udelay(100);
+
+ ca_nand_wait_ready(mtd);
+}
+
+int ca_nand_dev_ready(struct mtd_info *mtd)
+{
+ int ready;
+ union FLASH_FLASH_ACCESS_START_t tmp_access;
+
+ check_flash_ctrl_status();
+
+ write_flash_ctrl_reg(FLASH_NF_DATA, 0xffffffff);
+ RD_STATUS:
+ /* disable ecc gen */
+ write_flash_ctrl_reg(FLASH_NF_ECC_CONTROL, 0x0);
+ nf_cnt.wrd = 0;
+ nf_cnt.bf.nflashregoobcount = NCNT_EMPTY_OOB;
+ nf_cnt.bf.nflashregdatacount = NCNT_DATA_1;
+ nf_cnt.bf.nflashregaddrcount = NCNT_EMPTY_ADDR;
+ nf_cnt.bf.nflashregcmdcount = NCNT_CMD_1;
+
+ write_flash_ctrl_reg(FLASH_NF_COUNT, nf_cnt.wrd);
+
+ nf_cmd.wrd = 0;
+ nf_cmd.bf.nflashregcmd0 = NAND_CMD_STATUS;
+
+ /* write read id command */
+ write_flash_ctrl_reg(FLASH_NF_COMMAND, nf_cmd.wrd);
+ nf_addr1.wrd = 0;
+ /* write address 0x00 */
+ write_flash_ctrl_reg(FLASH_NF_ADDRESS_1, nf_addr1.wrd);
+ nf_addr2.wrd = 0;
+ /* write address 0x00 */
+ write_flash_ctrl_reg(FLASH_NF_ADDRESS_2, nf_addr2.wrd);
+
+ nf_access.wrd = 0;
+ nf_access.bf.nflashcealt = CHIP_EN;
+ nf_access.bf.nflashregwidth = NFLASH_WIDTH8;
+
+ write_flash_ctrl_reg(FLASH_NF_ACCESS, nf_access.wrd);
+ flash_start.wrd = 0;
+ flash_start.bf.nflashregreq = FLASH_GO;
+ flash_start.bf.nflashregcmd = FLASH_RD;
+ write_flash_ctrl_reg(FLASH_FLASH_ACCESS_START, flash_start.wrd);
+
+ flash_start.wrd = read_flash_ctrl_reg(FLASH_FLASH_ACCESS_START);
+ tmp_access.wrd = 0;
+ tmp_access.bf.nflashregreq = 1;
+ reg_wait(FLASH_FLASH_ACCESS_START, tmp_access.wrd, 0, 1000);
+
+ check_flash_ctrl_status();
+
+ ready = read_flash_ctrl_reg(FLASH_NF_DATA) & 0xff;
+ if (ready == 0xff) {
+ printf("%s : %x\n", __func__,
+ read_flash_ctrl_reg(FLASH_STATUS));
+ goto RD_STATUS;
+ }
+
+ return (ready & NAND_STATUS_READY);
+}
+
+int ca_board_nand_init(struct nand_chip *this)
+{
+ struct mtd_info *mtd;
+ int err = 0;
+ union FLASH_TYPE_t flash_type;
+
+ /* structures must be linked */
+ mtd = &host->mtd;
+ mtd->priv = this;
+ host->nand = this;
+
+ /* 5 us command delay time */
+ this->chip_delay = 20;
+
+ this->priv = host;
+ this->dev_ready = ca_nand_dev_ready;
+ this->cmdfunc = ca_nand_command;
+ this->select_chip = ca_nand_select_chip;
+ this->read_byte = ca_nand_read_byte;
+ /* this->read_word = ca_nand_read_word; */
+ this->write_buf = ca_nand_write_buf;
+ this->read_buf = ca_nand_read_buf;
+#ifdef CONFIG_MTD_NAND_VERIFY_WRITE
+ this->verify_buf = ca_nand_verify_buf;
+#endif
+
+/* #ifdef CONFIG_G3_NAND_HWECC*/
+ this->ecc.calculate = ca_nand_calculate_ecc;
+ this->ecc.hwctl = ca_nand_enable_hwecc;
+ this->ecc.correct = ca_nand_correct_data;
+ this->ecc.mode = NAND_ECC_HW;
+
+#if defined(CONFIG_NAND_CORTINA_ECC_HW_BCH)
+ this->ecc.size = BCH_DATA_UNIT;
+#if (CONFIG_NAND_CORTINA_ECC_LEVEL > 4)
+ this->ecc.bytes = (BCH_GF_PARAM_M * 40) / 8;
+#elif (CONFIG_NAND_CORTINA_ECC_LEVEL > 3)
+ this->ecc.bytes = (BCH_GF_PARAM_M * 24) / 8;
+#elif (CONFIG_NAND_CORTINA_ECC_LEVEL > 2)
+ this->ecc.bytes = (BCH_GF_PARAM_M * 16) / 8;
+#else
+ this->ecc.bytes = (BCH_GF_PARAM_M * 8) / 8;
+#endif
+#elif (CONFIG_NAND_CORTINA_ECC_LEVEL == 1)
+ this->ecc.size = 512;
+ this->ecc.bytes = 3;
+#else
+ this->ecc.size = 256;
+ this->ecc.bytes = 3;
+#endif
+/* #endif*/
+
+ /* check, if a user supplied wait function given */
+ this->waitfunc = ca_nand_wait;
+ this->block_bad = ca_nand_block_bad;
+ this->block_markbad = ca_nand_default_block_markbad;
+
+ if (!this->scan_bbt)
+ this->scan_bbt = nand_default_bbt;
+
+ flash_type.wrd = read_flash_ctrl_reg(FLASH_TYPE);
+ flash_type.bf.flashtype = FLASH_NAND_8KP;
+ flash_type.bf.flashpin = 1; /* Assume > 256MB */
+ flash_type.bf.flashsize = 2;
+ flash_type.bf.flashwidth = 0;
+ write_flash_ctrl_reg(FLASH_TYPE, flash_type.wrd);
+
+ this->cmd_ctrl = ca_nand_hwcontrol;
+ /* Reset NAND */
+ this->cmdfunc(mtd, NAND_CMD_RESET, -1, -1);
+
+ return err;
+}
+
+/*
+ * ca_nand_scan_tail - [NAND Interface] Scan for the NAND device
+ * @mtd: MTD device structure
+ * @maxchips: Number of chips to scan for
+ *
+ * This is the second phase of the normal nand_scan() function. It
+ * fills out all the uninitialized function pointers with the defaults
+ * and scans for a bad block table if appropriate.
+ */
+int ca_nand_scan_tail(struct mtd_info *mtd)
+{
+ int i, eccstartoffset;
+ struct nand_chip *chip = mtd->priv;
+
+ if (!(chip->options & NAND_OWN_BUFFERS))
+ chip->buffers = kmalloc(sizeof(*chip->buffers), GFP_KERNEL);
+ if (!chip->buffers)
+ return -ENOMEM;
+
+ /* Set the internal oob buffer location, just after the page data */
+ chip->oob_poi = chip->buffers->databuf + mtd->writesize;
+
+ /*
+ * If no default placement scheme is given, select an appropriate one
+ */
+ if (!chip->ecc.layout) {
+#if defined(CONFIG_NAND_CORTINA_ECC_HW_BCH)
+ if (mtd->oobsize == 16) {
+ chip->ecc.layout = &ca_nand_bch_oob_16;
+ } else {
+#elif (CONFIG_NAND_CORTINA_ECC_LEVEL == 0) || \
+ (CONFIG_NAND_CORTINA_ECC_LEVEL == 1)
+ if (mtd->oobsize == 8) {
+ chip->ecc.layout = &ca_nand_oob_8;
+ } else if (mtd->oobsize == 16) {
+ chip->ecc.layout = &ca_nand_oob_16;
+ } else {
+#endif
+ memset(&ca_nand_ecclayout, 0,
+ sizeof(ca_nand_ecclayout));
+ ca_nand_ecclayout.eccbytes =
+ mtd->writesize / chip->ecc.size * chip->ecc.bytes;
+ if (sizeof(ca_nand_ecclayout.eccpos) <
+ 4 * ca_nand_ecclayout.eccbytes) {
+ printf
+ ("eccpos memory is less than needed eccbytes");
+ return 1;
+ }
+
+ if (ca_nand_ecclayout.eccbytes > mtd->oobsize) {
+ printf
+ ("BCH%d need %d ECC but OOB size is %d!!\n",
+ (chip->ecc.bytes / BCH_GF_PARAM_M) * 8,
+ ca_nand_ecclayout.eccbytes, mtd->oobsize);
+ printf("You have to reduce ECC level!\n");
+ return 1;
+ }
+
+ memset(ca_nand_ecclayout.eccpos, 0,
+ sizeof(ca_nand_ecclayout.eccpos));
+ eccstartoffset =
+ mtd->oobsize - ca_nand_ecclayout.eccbytes;
+ for (i = 0; i < ca_nand_ecclayout.eccbytes; ++i) {
+ if ((i + eccstartoffset) == chip->badblockpos)
+ continue;
+
+ ca_nand_ecclayout.eccpos[i] =
+ i + eccstartoffset;
+ }
+
+ ca_nand_ecclayout.oobfree[0].offset = 2;
+ ca_nand_ecclayout.oobfree[0].length =
+ mtd->oobsize - ca_nand_ecclayout.eccbytes -
+ ca_nand_ecclayout.oobfree[0].offset;
+
+#ifdef CONFIG_NAND_CORTINA_ECC_HW_BCH
+ /* BCH algorithm needs one extra byte to tag erase status */
+ if (ca_nand_ecclayout.oobfree[0].length == 0) {
+ printf("eccbytes is less than required");
+ return 1;
+ };
+ ca_nand_ecclayout.oobfree[0].length -= 1;
+#endif
+ chip->ecc.layout = &ca_nand_ecclayout;
+ }
+ }
+
+ if (!chip->write_page)
+ chip->write_page = ca_nand_write_page;
+
+ /*
+ * check ECC mode, default to software if 3byte/512byte hardware ECC is
+ * selected and we have 256 byte pagesize fallback to software ECC
+ */
+ if (!chip->ecc.read_page_raw)
+ chip->ecc.read_page_raw = ca_nand_read_page_raw;
+ if (!chip->ecc.write_page_raw)
+ chip->ecc.write_page_raw = ca_nand_write_page_raw;
+
+ /* Use standard hwecc read page function ? */
+ if (!chip->ecc.read_page)
+ chip->ecc.read_page = ca_nand_read_page_hwecc;
+ if (!chip->ecc.write_page)
+ chip->ecc.write_page = ca_nand_write_page_hwecc;
+ if (!chip->ecc.read_oob)
+ chip->ecc.read_oob = ca_nand_read_oob_std;
+ if (!chip->ecc.write_oob)
+ chip->ecc.write_oob = ca_nand_write_oob_std;
+
+ /*
+ * The number of bytes available for a client to place data into
+ * the out of band area
+ */
+ chip->ecc.layout->oobavail = 0;
+ for (i = 0; chip->ecc.layout->oobfree[i].length; i++)
+ chip->ecc.layout->oobavail +=
+ chip->ecc.layout->oobfree[i].length;
+ mtd->oobavail = chip->ecc.layout->oobavail;
+
+ /*
+ * Set the number of read / write steps for one page depending on ECC
+ * mode
+ */
+ chip->ecc.steps = mtd->writesize / chip->ecc.size;
+ if (chip->ecc.steps * chip->ecc.size != mtd->writesize) {
+ printf("Invalid ecc parameters\n");
+ return 1;
+ }
+ chip->ecc.total = chip->ecc.steps * chip->ecc.bytes;
+
+ /*
+ * Allow subpage writes up to ecc.steps. Not possible for MLC
+ * FLASH.
+ */
+ if (!(chip->options & NAND_NO_SUBPAGE_WRITE) && nand_is_slc(chip)) {
+ switch (chip->ecc.steps) {
+ case 2:
+ mtd->subpage_sft = 1;
+ break;
+ case 4:
+ case 8:
+ mtd->subpage_sft = 2;
+ break;
+ }
+ }
+ chip->subpagesize = mtd->writesize >> mtd->subpage_sft;
+
+ /* Initialize state */
+ chip->state = FL_READY;
+
+ /* De-select the device */
+ chip->select_chip(mtd, -1);
+
+ /* Invalidate the pagebuffer reference */
+ chip->pagebuf = -1;
+
+ /* Fill in remaining MTD driver data */
+ mtd->type = MTD_NANDFLASH;
+ mtd->flags = MTD_CAP_NANDFLASH;
+ mtd->_erase = ca_nand_erase;
+ mtd->_read = ca_nand_read;
+ mtd->_write = ca_nand_write;
+ mtd->_read_oob = ca_nand_read_oob;
+ mtd->_write_oob = ca_nand_write_oob;
+ mtd->_sync = ca_nand_sync;
+ mtd->_lock = NULL;
+ mtd->_unlock = NULL;
+ mtd->_block_isbad = ca_nand_block_isbad;
+ mtd->_block_markbad = ca_nand_block_markbad;
+ mtd->writebufsize = mtd->writesize;
+
+ /* propagate ecc.layout to mtd_info */
+ mtd->ecclayout = chip->ecc.layout;
+
+ /* Check, if we should skip the bad block table scan */
+ if (chip->options & NAND_SKIP_BBTSCAN)
+ chip->options |= NAND_BBT_SCANNED;
+
+ return 0;
+}
+
+/*
+ * ca_nand_scan_ident - [NAND Interface] Scan for the NAND device
+ * @mtd: MTD device structure
+ * @maxchips: Number of chips to scan for
+ *
+ * This is the first phase of the normal nand_scan() function. It
+ * reads the flash ID and sets up MTD fields accordingly.
+ *
+ * The mtd->owner field must be set to the module of the caller.
+ */
+int ca_nand_scan_ident(struct mtd_info *mtd, int maxchips)
+{
+ int i, busw, nand_maf_id = 0, nand_dev_id = 0;
+ struct nand_chip *chip = mtd->priv;
+ struct nand_flash_dev *type;
+ unsigned char id[8];
+
+ /* Get buswidth to select the correct functions */
+ busw = chip->options & NAND_BUSWIDTH_16;
+
+ /* Read the flash type */
+ type = ca_nand_get_flash_type(mtd, chip, busw, &nand_maf_id);
+
+ if (IS_ERR(type)) {
+#ifndef CONFIG_SYS_NAND_QUIET_TEST
+ printf("No NAND device found!!!\n");
+#endif
+ chip->select_chip(mtd, -1);
+ return PTR_ERR(type);
+ }
+
+ /* Check for a chip array */
+ for (i = 1; i < maxchips; i++) {
+ chip->select_chip(mtd, i);
+ /* See comment in nand_get_flash_type for reset */
+ chip->cmdfunc(mtd, NAND_CMD_RESET, -1, -1);
+ /* Send the command for reading device ID */
+ ca_nand_read_id(0, id);
+ /* Read manufacturer and device IDs */
+ if (nand_maf_id != id[0] || nand_dev_id != id[1])
+ break;
+ }
+#ifdef DEBUG
+ if (i > 1)
+ printf("%d NAND chips detected\n", i);
+#endif
+
+ /* Store the number of chips and calc total size for mtd */
+ chip->numchips = i;
+ mtd->size = i * chip->chipsize;
+
+ return 0;
+}
+
+int init_DMA_SSP(void)
+{
+ int i;
+ union DMA_SEC_DMA_GLB_DMA_LSO_CTRL_t dma_lso_ctrl;
+ union DMA_SEC_DMA_GLB_DMA_SSP_RX_CTRL_t dma_rxdma_ctrl;
+ union DMA_SEC_DMA_GLB_DMA_SSP_TX_CTRL_t dma_txdma_ctrl;
+ union DMA_SEC_DMA_SSP_Q_RXQ_BASE_DEPTH_t dma_rxq5_base_depth;
+ union DMA_SEC_DMA_SSP_Q_TXQ_BASE_DEPTH_t dma_txq5_base_depth;
+#ifdef CONFIG_TARGET_VENUS
+ printf("Configure DMA ordering\n");
+ /* Workaround for DMA-reordering issue */
+ writel(8, DMA_AXI_REO_AXI_REO_RD_ORIG_ID);
+ writel(9, DMA_AXI_REO_AXI_REO_RD_ORIG_ID + 0x80);
+ writel(10, DMA_AXI_REO_AXI_REO_RD_ORIG_ID + 0x100);
+ writel(11, DMA_AXI_REO_AXI_REO_RD_ORIG_ID + 0x180);
+ writel(12, DMA_AXI_REO_AXI_REO_RD_ORIG_ID + 0x200);
+ writel(8, DMA_AXI_REO_AXI_REO_WR_ORIG_ID);
+ writel(9, DMA_AXI_REO_AXI_REO_WR_ORIG_ID + 0x80);
+ writel(10, DMA_AXI_REO_AXI_REO_WR_ORIG_ID + 0x100);
+#endif
+
+ dma_lso_ctrl.wrd = read_dma_global_reg(DMA_SEC_DMA_GLB_DMA_LSO_CTRL);
+ dma_lso_ctrl.bf.tx_dma_enable = 1;
+ write_dma_global_reg(DMA_SEC_DMA_GLB_DMA_LSO_CTRL, dma_lso_ctrl.wrd);
+
+ dma_rxdma_ctrl.wrd =
+ read_dma_global_reg(DMA_SEC_DMA_GLB_DMA_SSP_RX_CTRL);
+ dma_txdma_ctrl.wrd =
+ read_dma_global_reg(DMA_SEC_DMA_GLB_DMA_SSP_TX_CTRL);
+
+ if (dma_rxdma_ctrl.bf.rx_check_own != 1 &&
+ dma_rxdma_ctrl.bf.rx_dma_enable != 1) {
+ dma_rxdma_ctrl.bf.rx_check_own = 1;
+ dma_rxdma_ctrl.bf.rx_dma_enable = 1;
+ write_dma_global_reg(DMA_SEC_DMA_GLB_DMA_SSP_RX_CTRL,
+ dma_rxdma_ctrl.wrd);
+ }
+ if (dma_txdma_ctrl.bf.tx_check_own != 1 &&
+ dma_txdma_ctrl.bf.tx_dma_enable != 1) {
+ dma_txdma_ctrl.bf.tx_check_own = 1;
+ dma_txdma_ctrl.bf.tx_dma_enable = 1;
+ write_dma_global_reg(DMA_SEC_DMA_GLB_DMA_SSP_TX_CTRL,
+ dma_txdma_ctrl.wrd);
+ }
+
+ i = 16;
+ tx_desc = (struct tx_descriptor_t *)((uint64_t)
+ malloc((sizeof(struct tx_descriptor_t) *
+ FDMA_DESC_NUM) + i - 1) & ~(i - 1));
+ rx_desc = (struct rx_descriptor_t *)((uint64_t)
+ malloc((sizeof(struct rx_descriptor_t) *
+ FDMA_DESC_NUM) + i - 1) & ~(i - 1));
+
+ if (!rx_desc || !tx_desc) {
+ printf("Buffer allocation for failed!\n");
+ kfree(rx_desc);
+ kfree(tx_desc);
+ return 0;
+ }
+
+ /* set base address and depth */
+ dma_rxq5_base_depth.bf.base = (unsigned long)rx_desc >> 4;
+ dma_rxq5_base_depth.bf.depth = FDMA_DEPTH;
+ write_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_RXQ_BASE_DEPTH,
+ dma_rxq5_base_depth.wrd);
+
+ dma_txq5_base_depth.bf.base = (unsigned long)tx_desc >> 4;
+ dma_txq5_base_depth.bf.depth = FDMA_DEPTH;
+ write_dma_ctrl_reg(DMA_SEC_DMA_SSP_Q_TXQ_BASE_DEPTH,
+ dma_txq5_base_depth.wrd);
+
+ memset((unsigned char *)tx_desc, 0,
+ (sizeof(struct tx_descriptor_t) * FDMA_DESC_NUM));
+ memset((unsigned char *)rx_desc, 0,
+ (sizeof(struct rx_descriptor_t) * FDMA_DESC_NUM));
+
+ for (i = 0; i < FDMA_DESC_NUM; i++) {
+ /* set own by sw */
+ tx_desc[i].word1.bf.own = OWN_SW;
+ /* enable q5 Scatter-Gather memory copy */
+ tx_desc[i].word1.bf.sgm = 0x1;
+ }
+
+ return 1;
+}
+
+int ca_nand_scan(struct mtd_info *mtd, int maxchips)
+{
+ int ret;
+
+ ret = ca_nand_scan_ident(mtd, maxchips);
+ if (!ret)
+ ret = ca_nand_scan_tail(mtd);
+ return ret;
+}
+
+int ca_nand_init_chip(struct mtd_info *mtd, struct nand_chip *nand,
+ ulong base_addr)
+{
+ int ret, __attribute__ ((unused)) i = 0;
+
+ int maxchips = CONFIG_SYS_NAND_MAX_CHIPS;
+
+ ret = 0;
+
+ if (init_DMA_SSP() == 0)
+ printf("desc alloc error!!\n");
+
+ flash_reset();
+ if (maxchips < 1)
+ maxchips = 1;
+ mtd->priv = nand;
+
+ /* set to NAND data register */
+ nand->IO_ADDR_R = (void __iomem *)FLASH_NF_DATA; /* base_addr; */
+ nand->IO_ADDR_W = (void __iomem *)FLASH_NF_DATA; /* base_addr; */
+ if (ca_board_nand_init(nand) == 0) {
+ if (ca_nand_scan(mtd, maxchips) == 0) {
+ if (!mtd->name)
+ mtd->name = (char *)default_nand_name;
+#ifndef CONFIG_RELOC_FIXUP_WORKS
+ else
+ mtd->name += gd->reloc_off;
+#endif
+
+#ifdef CONFIG_MTD
+ /*
+ * Add MTD device so that we can reference it later
+ * via the mtdcore infrastructure (e.g. ubi).
+ */
+ sprintf(dev_name[i], "nand%d", i);
+ mtd->name = dev_name[i++];
+ add_mtd_device(mtd);
+#endif
+#ifdef CONFIG_NAND_HIDE_BAD
+ scan_parallel_nand_bad_blocks(mtd, 0, nand->chipsize);
+#endif
+ } else {
+ mtd->name = NULL;
+ ret = 1;
+ }
+ } else {
+ mtd->name = NULL;
+ mtd->size = 0;
+ ret = 1;
+ }
+
+ return ret;
+}
+
+void cortina_nand_init(void)
+{
+ int i, ret;
+ unsigned int size = 0;
+
+ base_address[0] = CORTINA_FLASH_CTRL_BASE;
+ for (i = 0; i < CONFIG_SYS_MAX_NAND_DEVICE; i++) {
+ ret =
+ ca_nand_init_chip(&cortina_nand_info[i], &nand_chip[i],
+ base_address[i]);
+ if (ret != 0) {
+ memset(&cortina_nand_info[i], 0,
+ sizeof(struct mtd_info));
+ return;
+ }
+
+ size += cortina_nand_info[i].size / 1024;
+ if (nand_curr_device == -1)
+ nand_curr_device = i;
+ }
+
+ nand_register(0, &cortina_nand_info[0]);
+#ifdef CONFIG_SYS_NAND_SELECT_DEVICE
+ /*
+ * Select the chip in the board/cpu specific driver
+ */
+ board_nand_select_device(cortina_nand_info[nand_curr_device].priv,
+ nand_curr_device);
+#endif
+}
+
+void board_nand_init(void)
+{
+ cortina_nand_init();
+}
diff --git a/drivers/mtd/nand/raw/ca_nand.h b/drivers/mtd/nand/raw/ca_nand.h
new file mode 100644
index 0000000..061a106
--- /dev/null
+++ b/drivers/mtd/nand/raw/ca_nand.h
@@ -0,0 +1,3899 @@
+/* SPDX-License-Identifier: GPL-2.0+ */
+/*
+ * Copyright (C) 2015-2020, Cortina-Access Incorporation.
+ * Author: Jason Li <jason.li at cortina-access.com>
+ *
+ * Parallel NAND Controller Driver for CAxxxx based SoCs
+ */
+#ifndef _CA_NAND_H_
+#define _CA_NAND_H_
+#define NCNT_EMPTY_OOB 0x3FF
+#define NCNT_EMPTY_DATA 0x3FFF
+#define NCNT_512P_DATA 0x1FF
+#define NCNT_DATA_1 0x0
+#define NCNT_DATA_2 0x1
+#define NCNT_DATA_3 0x2
+#define NCNT_DATA_4 0x3
+#define NCNT_DATA_5 0x4
+#define NCNT_DATA_6 0x5
+#define NCNT_DATA_7 0x6
+#define NCNT_DATA_8 0x7
+#define NCNT_EMPTY_ADDR 0x7
+#define NCNT_ADDR_5 0x4
+#define NCNT_ADDR_4 0x3
+#define NCNT_ADDR_3 0x2
+#define NCNT_ADDR_2 0x1
+#define NCNT_ADDR_1 0x0
+#define NCNT_EMPTY_CMD 0x3
+#define NCNT_CMD_3 0x2
+#define NCNT_CMD_2 0x1
+#define NCNT_CMD_1 0x0
+#define NFLASH_WIDTH8 0x0
+#define NFLASH_WIDTH16 0x1
+#define NFLASH_WIDTH32 0x2
+#define NFLASH_CHIP0_EN 0x0
+#define NFLASH_CHIP1_EN 0x1
+//#define NFLASH_DIRECT 0x00004000
+//#define NFLASH_INDIRECT 0x00000000
+#define ECC_DONE 0x1 //ECC generation complete
+#define NF_RESET 0x1 //ECC generation complete
+#define FIFO_CLR 0x1 //ECC generation complete
+#define ECC_CLR 0x1 //ECC generation complete
+#define FLASH_GO 0x1 //ECC generation complete
+// ECC comparison result,
+#define ECC_UNCORRECTABLE 0x3
+#define ECC_1BIT_DATA_ERR 0x1
+#define ECC_1BIT_ECC_ERR 0x2
+#define ECC_NO_ERR 0x0
+#define ECC_ENABLE 0x1 //ECC generation complete
+#define ECC_GEN_256 0x0
+#define ECC_GEN_512 0x1
+#define ECC_PAUSE_EN 0x1
+#define FLASH_RD 0x2
+#define FLASH_WT 0x3
+#define FLASH_SERIAL 0x0
+#define FLASH_PARALLEL 0x1
+#define FLASH_NAND_512P 0x4
+#define FLASH_NAND_2KP 0x5
+#define FLASH_NAND_4KP 0x6
+#define FLASH_NAND_M4KP 0x7
+#define FLASH_NAND_8KP 0x7
+#define FLASH_WIDTH8_STM 0x0
+#define FLASH_WIDTH16_AT 0x1
+#define FLASH_SIZE_STM16MB 0x0
+#define FLASH_SIZE_STM32MB 0x1
+#define FLASH_SIZE_AT1MB 0x0
+#define FLASH_SIZE_AT2MB 0x1
+#define FLASH_SIZE_AT8MB 0x2
+#define FLASH_SIZE_AT16MB 0x3
+#define FLASH_SIZE_NP512_32MB 0x0
+#define FLASH_SIZE_NP512_64MB 0x1
+#define FLASH_SIZE_NP512_128MB 0x2
+#define FLASH_SIZE_NP2K_128MB 0x0
+#define FLASH_SIZE_NP2K_256MB 0x1
+#define FLASH_SIZE_NP2K_512MB 0x2
+#define FLASH_SIZE_NP2K_1GMB 0x3
+#define FLASH_SIZE_NP4K_1GMB 0x0
+#define FLASH_SIZE_NP4K_2GMB 0x1
+#define FLASH_SIZE_NP4K_4GMB 0x2
+#define FLASH_SIZE_NP8K_CONF 0x4
+//bch
+#define BCH_ENABLE 0x1
+#define BCH_DISABLE 0x0
+#define BCH_DECODE 0x1
+#define BCH_ENCODE 0x0
+// BCH ECC comparison result,
+#define BCH_UNCORRECTABLE 0x3
+#define BCH_CORRECTABLE_ERR 0x2
+#define BCH_NO_ERR 0x1
+#define BCH_ING 0x0
+//#define BCH_ERR_CAP_8_512 0x0
+//#define BCH_ERR_CAP_12_512 0x1
+#define BCH_ERR_CAP_8 0x0
+#define BCH_ERR_CAP_16 0x1
+#define BCH_ERR_CAP_24 0x2
+#define BCH_ERR_CAP_40 0x3
+#define BCH_GF_PARAM_M 14
+#define BCH_DATA_UNIT 1024
+#define FIFO_CMD_READ 2
+#define FIFO_CMD_WRITE 3
+#define FLASH_CLR_FIFO 0x8000
+#define STS_WP 0x80
+#define STS_READY 0x40
+#define STS_TRUE_READY 0x40
+#define NFLASH_ENABLE 0x00000004
+#define FDMA_DEPTH 3
+#define FDMA_DESC_NUM BIT(FDMA_DEPTH)
+
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+struct tx_descriptor_t {
+ unsigned int buf_adr; /* data buffer address */
+ union tx_word1_t {
+ struct {
+#ifdef CS_BIG_ENDIAN
+ unsigned int own:1; /* bits 31:31 */
+ unsigned int share_rsrvd:1; /* bits 30 */
+ unsigned int cache_rsrvd:1; /* bits 29 */
+ unsigned int sof_eof_rsrvd:2; /* bits 28:27 */
+ unsigned int sgm_rsrvd:5; /* bits 26:22 */
+ unsigned int desccnt:6; /* bits 21:16 */
+ unsigned int buf_size:16; /* bits 15:0 */
+#else /* CS_LITTLE_ENDIAN */
+ unsigned int buf_adr_hi:8; /* bits 7:0 */
+ unsigned int buf_len:16; /* bits 23:8 */
+ unsigned int sgm:1; /* bits 24 */
+ unsigned int rsrvd:6; /* bits 30:25 */
+ unsigned int own:1; /* bits 31:31 */
+#endif
+ } bf;
+ unsigned int wrd;
+ } word1;
+};
+
+struct rx_descriptor_t {
+ unsigned int buf_adr; /* data buffer address */
+ union rx_word1_t {
+ struct {
+#ifdef CS_BIG_ENDIAN
+ unsigned int own:1; /* bits 31 */
+ unsigned int share_rsrvd:1; /* bits 30 */
+ unsigned int cache_rsrvd:1; /* bits 29 */
+ unsigned int rqsts_rsrvd:7; /* bits 28:22 */
+ unsigned int desccnt:6; /* bits 21:16 */
+ unsigned int buf_size:16; /* bits 15:0 */
+#else /* CS_LITTLE_ENDIAN */
+ unsigned int buf_adr_hi:8; /* bits 7:0 */
+ unsigned int buf_len:16; /* bits 23:8 */
+ unsigned int rsrvd:7; /* bits 30:24 */
+ unsigned int own:1; /* bits 31:31 */
+#endif
+ } bf;
+ unsigned int wrd;
+ } word1;
+};
+#endif /* !__ASSEMBLER__ */
+
+/* Flash registers */
+#define FLASH_ID 0x00000000
+#define FLASH_ID_dft 0x00000101
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_ID_t {
+ struct {
+ unsigned int flashrevid:8; /* bits 7:0 */
+ unsigned int flashdevid:24; /* bits 31:8 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_TIMEOUT 0x00000004
+#define FLASH_TIMEOUT_dft 0xffffffff
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_TIMEOUT_t {
+ struct {
+ unsigned int timeout_load:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_STATUS 0x00000008
+#define FLASH_STATUS_dft 0x06000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_STATUS_t {
+ struct {
+ unsigned int sstate:4; /* bits 3:0 */
+ unsigned int pstate:4; /* bits 7:4 */
+ unsigned int nstate:4; /* bits 11:8 */
+ unsigned int rsrvd1:13;
+ unsigned int pflash_rbin_d:1; /* bits 25:25 */
+ unsigned int nflash_rbin_d:1; /* bits 26:26 */
+ unsigned int rsrvd2:5;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_TYPE 0x0000000c
+#define FLASH_TYPE_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_TYPE_t {
+ struct {
+ unsigned int rsrvd1:9;
+ unsigned int flashsize:2; /* bits 10:9 */
+ unsigned int flashwidth:1; /* bits 11:11 */
+ unsigned int flashtype:3; /* bits 14:12 */
+ unsigned int flashpin:1; /* bits 15:15 */
+ unsigned int rsrvd2:16;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_FLASH_ACCESS_START 0x00000010
+#define FLASH_FLASH_ACCESS_START_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_FLASH_ACCESS_START_t {
+ struct {
+ unsigned int nflashregreq:1; /* bits 0:0 */
+ unsigned int sflashregreq:1; /* bits 1:1 */
+ unsigned int nflashfiforeq:1; /* bits 2:2 */
+ unsigned int sflashfiforeq:1; /* bits 3:3 */
+ unsigned int rsrvd1:5;
+ unsigned int sflashregcmd:1; /* bits 9:9 */
+ unsigned int rsrvd2:2;
+ unsigned int nflashregcmd:2; /* bits 13:12 */
+ unsigned int rsrvd3:18;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_FLASH_INTERRUPT 0x00000014
+#define FLASH_FLASH_INTERRUPT_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_FLASH_INTERRUPT_t {
+ struct {
+ unsigned int regirq:1; /* bits 0:0 */
+ unsigned int fifoirq:1; /* bits 1:1 */
+ unsigned int f_addr_err:1; /* bits 2:2 */
+ unsigned int eccirq:1; /* bits 3:3 */
+ unsigned int nfwdtirq:1; /* bits 4:4 */
+ unsigned int rsrvd1:1;
+ unsigned int bchgenirq:1; /* bits 6:6 */
+ unsigned int bchdecirq:1; /* bits 7:7 */
+ unsigned int rsrvd2:24;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_FLASH_MASK 0x00000018
+#define FLASH_FLASH_MASK_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_FLASH_MASK_t {
+ struct {
+ unsigned int flashregirqmask:1; /* bits 0:0 */
+ unsigned int fifoirqmask:1; /* bits 1:1 */
+ unsigned int f_addr_irqmask:1; /* bits 2:2 */
+ unsigned int eccirqmask:1; /* bits 3:3 */
+ unsigned int nfwdtirqmask:1; /* bits 4:4 */
+ unsigned int rsrvd1:1;
+ unsigned int bchgenirqmask:1; /* bits 6:6 */
+ unsigned int bchdecirqmask:1; /* bits 7:7 */
+ unsigned int rsrvd2:24;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_FIFO_CONTROL 0x0000001c
+#define FLASH_FIFO_CONTROL_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_FIFO_CONTROL_t {
+ struct {
+ unsigned int fifocmd:2; /* bits 1:0 */
+ unsigned int rsrvd1:2;
+ unsigned int fifodbgsel:4; /* bits 7:4 */
+ unsigned int fifoclear:1; /* bits 8:8 */
+ unsigned int rsrvd2:15;
+ unsigned int fifordth:2; /* bits 25:24 */
+ unsigned int fifowrth:2; /* bits 27:26 */
+ unsigned int rsrvd3:4;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_FIFO_STATUS 0x00000020
+#define FLASH_FIFO_STATUS_dft 0x00000004
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_FIFO_STATUS_t {
+ struct {
+ unsigned int f_state:2; /* bits 1:0 */
+ unsigned int f_empty:1; /* bits 2:2 */
+ unsigned int f_full:1; /* bits 3:3 */
+ unsigned int f_ptr_rd:5; /* bits 8:4 */
+ unsigned int f_ptr_wr:5; /* bits 13:9 */
+ unsigned int rsrvd1:2;
+ unsigned int f_addr_count:8; /* bits 23:16 */
+ unsigned int rsrvd2:8;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_FIFO_ADDRESS 0x00000024
+#define FLASH_FIFO_ADDRESS_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_FIFO_ADDRESS_t {
+ struct {
+ unsigned int f_axaddr:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_FIFO_MATCH_ADDRESS 0x00000028
+#define FLASH_FIFO_MATCH_ADDRESS_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_FIFO_MATCH_ADDRESS_t {
+ struct {
+ unsigned int f_axaddr_compare:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_FIFO_DATA 0x0000002c
+#define FLASH_FIFO_DATA_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_FIFO_DATA_t {
+ struct {
+ unsigned int f_ebuf_mem1:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_SF_ACCESS 0x00000030
+#define FLASH_SF_ACCESS_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_SF_ACCESS_t {
+ struct {
+ unsigned int sflashopcode:8; /* bits 7:0 */
+ unsigned int sflashaccode:4; /* bits 11:8 */
+ unsigned int sflashforceterm:1; /* bits 12:12 */
+ unsigned int sflashforceburst:1; /* bits 13:13 */
+ unsigned int rsrvd1:1;
+ unsigned int sflashcnmode:1; /* bits 15:15 */
+ unsigned int sflashcealt:1; /* bits 16:16 */
+ unsigned int sflashhsrd:1; /* bits 17:17 */
+ unsigned int rsrvd2:6;
+ unsigned int sflashmdata:1; /* bits 24:24 */
+ unsigned int sflashmaddr:1; /* bits 25:25 */
+ unsigned int sflashmcmd:1; /* bits 26:26 */
+ unsigned int rsrvd3:1;
+ unsigned int sflashddr:2; /* bits 29:28 */
+ unsigned int sflashmio:2; /* bits 31:30 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_SF_EXT_ACCESS 0x00000034
+#define FLASH_SF_EXT_ACCESS_dft 0x1fffff00
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_SF_EXT_ACCESS_t {
+ struct {
+ unsigned int sflashopcode:8; /* bits 7:0 */
+ unsigned int sflashdatacount:13; /* bits 20:8 */
+ unsigned int sflashaddrcount:3; /* bits 23:21 */
+ unsigned int sflashdummycount:5; /* bits 28:24 */
+ unsigned int rsrvd1:2;
+ unsigned int sflashdirrdcmden:1; /* bits 31:31 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_SF_ADDRESS 0x00000038
+#define FLASH_SF_ADDRESS_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_SF_ADDRESS_t {
+ struct {
+ unsigned int sflashregaddr:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_SF_DATA 0x0000003c
+#define FLASH_SF_DATA_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_SF_DATA_t {
+ struct {
+ unsigned int sflashregwdata:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_SF_TIMING 0x00000040
+#define FLASH_SF_TIMING_dft 0x00373737
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_SF_TIMING_t {
+ struct {
+ unsigned int sflashidletime:8; /* bits 7:0 */
+ unsigned int sflashholdtime:8; /* bits 15:8 */
+ unsigned int sflashsetuptime:8; /* bits 23:16 */
+ unsigned int sflashclkwidth:3; /* bits 26:24 */
+ unsigned int rsrvd1:5;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_PF_ACCESS 0x00000050
+#define FLASH_PF_ACCESS_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_PF_ACCESS_t {
+ struct {
+ unsigned int pflashextaddr:5; /* bits 4:0 */
+ unsigned int rsrvd1:11;
+ unsigned int pflashcealt:1; /* bits 16:16 */
+ unsigned int rsrvd2:3;
+ unsigned int pflashbzchk:1; /* bits 20:20 */
+ unsigned int pflashbzpol:1; /* bits 21:21 */
+ unsigned int pflashrdpol:1; /* bits 22:22 */
+ unsigned int pflashwrpol:1; /* bits 23:23 */
+ unsigned int rsrvd3:8;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_PF_TIMING 0x00000054
+#define FLASH_PF_TIMING_dft 0x000f0f07
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_PF_TIMING_t {
+ struct {
+ unsigned int pflashidletime:8; /* bits 7:0 */
+ unsigned int pflashholdtime:8; /* bits 15:8 */
+ unsigned int pflashsetuptime:8; /* bits 23:16 */
+ unsigned int pflashclkwidth:2; /* bits 25:24 */
+ unsigned int rsrvd1:6;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_ACCESS 0x00000060
+#define FLASH_NF_ACCESS_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_ACCESS_t {
+ struct {
+ unsigned int nflashextaddr:8; /* bits 7:0 */
+ unsigned int rsrvd1:2;
+ unsigned int nflashregwidth:2; /* bits 11:10 */
+ unsigned int rsrvd2:3;
+ unsigned int nflashcealt:1; /* bits 15:15 */
+ unsigned int autoreset:1; /* bits 16:16 */
+ unsigned int rsrvd3:15;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_COUNT 0x00000064
+#define FLASH_NF_COUNT_dft 0xffffff00
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_COUNT_t {
+ struct {
+ unsigned int nflashregcmdcount:2; /* bits 1:0 */
+ unsigned int rsrvd1:2;
+ unsigned int nflashregaddrcount:3; /* bits 6:4 */
+ unsigned int rsrvd2:1;
+ unsigned int nflashregdatacount:14; /* bits 21:8 */
+ unsigned int nflashregoobcount:10; /* bits 31:22 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_COMMAND 0x00000068
+#define FLASH_NF_COMMAND_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_COMMAND_t {
+ struct {
+ unsigned int nflashregcmd0:8; /* bits 7:0 */
+ unsigned int nflashregcmd1:8; /* bits 15:8 */
+ unsigned int nflashregcmd2:8; /* bits 23:16 */
+ unsigned int rsrvd1:8;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_ADDRESS_1 0x0000006c
+#define FLASH_NF_ADDRESS_1_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_ADDRESS_1_t {
+ struct {
+ unsigned int nflashregaddr0:8; /* bits 7:0 */
+ unsigned int nflashregaddr1:8; /* bits 15:8 */
+ unsigned int nflashregaddr2:8; /* bits 23:16 */
+ unsigned int nflashregaddr3:8; /* bits 31:24 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_ADDRESS_2 0x00000070
+#define FLASH_NF_ADDRESS_2_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_ADDRESS_2_t {
+ struct {
+ unsigned int nflashregaddr4:8; /* bits 7:0 */
+ unsigned int rsrvd1:24;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_DATA 0x00000074
+#define FLASH_NF_DATA_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_DATA_t {
+ struct {
+ unsigned int nflashregwdata:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_TIMING 0x00000078
+#define FLASH_NF_TIMING_dft 0x00041703
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_TIMING_t {
+ struct {
+ unsigned int nflashidletime:8; /* bits 7:0 */
+ unsigned int nflashholdtime:8; /* bits 15:8 */
+ unsigned int nflashsetuptime:8; /* bits 23:16 */
+ unsigned int nflashclkwidth:3; /* bits 26:24 */
+ unsigned int rsrvd1:5;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_ECC_STATUS 0x0000007c
+#define FLASH_NF_ECC_STATUS_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_ECC_STATUS_t {
+ struct {
+ unsigned int eccstatus:2; /* bits 1:0 */
+ unsigned int rsrvd1:1;
+ unsigned int eccerrbit:4; /* bits 6:3 */
+ unsigned int eccerrbyte:9; /* bits 15:7 */
+ unsigned int eccerrword:8; /* bits 23:16 */
+ unsigned int rsrvd2:7;
+ unsigned int eccdone:1; /* bits 31:31 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_ECC_CONTROL 0x00000080
+#define FLASH_NF_ECC_CONTROL_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_ECC_CONTROL_t {
+ struct {
+ unsigned int rsrvd1:1;
+ unsigned int eccgenmode:1; /* bits 1:1 */
+ unsigned int rsrvd2:2;
+ unsigned int ecccodesel:4; /* bits 7:4 */
+ unsigned int eccen:1; /* bits 8:8 */
+ unsigned int rsrvd3:23;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_ECC_OOB 0x00000084
+#define FLASH_NF_ECC_OOB_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_ECC_OOB_t {
+ struct {
+ unsigned int ecccodeoob:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_ECC_GEN0 0x00000088
+#define FLASH_NF_ECC_GEN0_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_ECC_GEN0_t {
+ struct {
+ unsigned int ecccodegen0:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_ECC_GEN1 0x0000008c
+#define FLASH_NF_ECC_GEN1_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_ECC_GEN1_t {
+ struct {
+ unsigned int ecccodegen1:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_ECC_GEN2 0x00000090
+#define FLASH_NF_ECC_GEN2_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_ECC_GEN2_t {
+ struct {
+ unsigned int ecccodegen2:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_ECC_GEN3 0x00000094
+#define FLASH_NF_ECC_GEN3_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_ECC_GEN3_t {
+ struct {
+ unsigned int ecccodegen3:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_ECC_GEN4 0x00000098
+#define FLASH_NF_ECC_GEN4_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_ECC_GEN4_t {
+ struct {
+ unsigned int ecccodegen4:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_ECC_GEN5 0x0000009c
+#define FLASH_NF_ECC_GEN5_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_ECC_GEN5_t {
+ struct {
+ unsigned int ecccodegen5:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_ECC_GEN6 0x000000a0
+#define FLASH_NF_ECC_GEN6_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_ECC_GEN6_t {
+ struct {
+ unsigned int ecccodegen6:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_ECC_GEN7 0x000000a4
+#define FLASH_NF_ECC_GEN7_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_ECC_GEN7_t {
+ struct {
+ unsigned int ecccodegen7:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_ECC_GEN8 0x000000a8
+#define FLASH_NF_ECC_GEN8_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_ECC_GEN8_t {
+ struct {
+ unsigned int ecccodegen8:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_ECC_GEN9 0x000000ac
+#define FLASH_NF_ECC_GEN9_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_ECC_GEN9_t {
+ struct {
+ unsigned int ecccodegen9:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_ECC_GEN10 0x000000b0
+#define FLASH_NF_ECC_GEN10_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_ECC_GEN10_t {
+ struct {
+ unsigned int ecccodegen10:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_ECC_GEN11 0x000000b4
+#define FLASH_NF_ECC_GEN11_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_ECC_GEN11_t {
+ struct {
+ unsigned int ecccodegen11:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_ECC_GEN12 0x000000b8
+#define FLASH_NF_ECC_GEN12_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_ECC_GEN12_t {
+ struct {
+ unsigned int ecccodegen12:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_ECC_GEN13 0x000000bc
+#define FLASH_NF_ECC_GEN13_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_ECC_GEN13_t {
+ struct {
+ unsigned int ecccodegen13:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_ECC_GEN14 0x000000c0
+#define FLASH_NF_ECC_GEN14_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_ECC_GEN14_t {
+ struct {
+ unsigned int ecccodegen14:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_ECC_GEN15 0x000000c4
+#define FLASH_NF_ECC_GEN15_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_ECC_GEN15_t {
+ struct {
+ unsigned int ecccodegen15:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_ECC_RESET 0x000000c8
+#define FLASH_NF_ECC_RESET_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_ECC_RESET_t {
+ struct {
+ unsigned int eccclear:1; /* bits 0:0 */
+ unsigned int fifoclear:1; /* bits 1:1 */
+ unsigned int nflash_reset:1; /* bits 2:2 */
+ unsigned int rsrvd1:29;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_CONTROL 0x000000cc
+#define FLASH_NF_BCH_CONTROL_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_CONTROL_t {
+ struct {
+ unsigned int bchcompare:1; /* bits 0:0 */
+ unsigned int bchopcode:1; /* bits 1:1 */
+ unsigned int rsrvd1:2;
+ unsigned int bchcodesel:3; /* bits 6:4 */
+ unsigned int rsrvd2:1;
+ unsigned int bchen:1; /* bits 8:8 */
+ unsigned int bcherrcap:2; /* bits 10:9 */
+ unsigned int rsrvd3:5;
+ unsigned int bchtestctrl:4; /* bits 19:16 */
+ unsigned int rsrvd4:12;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_STATUS 0x000000d0
+#define FLASH_NF_BCH_STATUS_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_STATUS_t {
+ struct {
+ unsigned int bchdecstatus:2; /* bits 1:0 */
+ unsigned int rsrvd1:6;
+ unsigned int bcherrnum:6; /* bits 13:8 */
+ unsigned int rsrvd2:16;
+ unsigned int bchdecdone:1; /* bits 30:30 */
+ unsigned int bchgendone:1; /* bits 31:31 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_ERROR_LOC01 0x000000d4
+#define FLASH_NF_BCH_ERROR_LOC01_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_ERROR_LOC01_t {
+ struct {
+ unsigned int bcherrloc0:14; /* bits 13:0 */
+ unsigned int rsrvd1:2;
+ unsigned int bcherrloc1:14; /* bits 29:16 */
+ unsigned int rsrvd2:2;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_ERROR_LOC23 0x000000d8
+#define FLASH_NF_BCH_ERROR_LOC23_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_ERROR_LOC23_t {
+ struct {
+ unsigned int bcherrloc2:14; /* bits 13:0 */
+ unsigned int rsrvd1:2;
+ unsigned int bcherrloc3:14; /* bits 29:16 */
+ unsigned int rsrvd2:2;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_ERROR_LOC45 0x000000dc
+#define FLASH_NF_BCH_ERROR_LOC45_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_ERROR_LOC45_t {
+ struct {
+ unsigned int bcherrloc4:14; /* bits 13:0 */
+ unsigned int rsrvd1:2;
+ unsigned int bcherrloc5:14; /* bits 29:16 */
+ unsigned int rsrvd2:2;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_ERROR_LOC67 0x000000e0
+#define FLASH_NF_BCH_ERROR_LOC67_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_ERROR_LOC67_t {
+ struct {
+ unsigned int bcherrloc6:14; /* bits 13:0 */
+ unsigned int rsrvd1:2;
+ unsigned int bcherrloc7:14; /* bits 29:16 */
+ unsigned int rsrvd2:2;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_ERROR_LOC89 0x000000e4
+#define FLASH_NF_BCH_ERROR_LOC89_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_ERROR_LOC89_t {
+ struct {
+ unsigned int bcherrloc8:14; /* bits 13:0 */
+ unsigned int rsrvd1:2;
+ unsigned int bcherrloc9:14; /* bits 29:16 */
+ unsigned int rsrvd2:2;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_ERROR_LOC1011 0x000000e8
+#define FLASH_NF_BCH_ERROR_LOC1011_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_ERROR_LOC1011_t {
+ struct {
+ unsigned int bcherrloc10:14; /* bits 13:0 */
+ unsigned int rsrvd1:2;
+ unsigned int bcherrloc11:14; /* bits 29:16 */
+ unsigned int rsrvd2:2;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_ERROR_LOC1213 0x000000ec
+#define FLASH_NF_BCH_ERROR_LOC1213_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_ERROR_LOC1213_t {
+ struct {
+ unsigned int bcherrloc12:14; /* bits 13:0 */
+ unsigned int rsrvd1:2;
+ unsigned int bcherrloc13:14; /* bits 29:16 */
+ unsigned int rsrvd2:2;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_ERROR_LOC1415 0x000000f0
+#define FLASH_NF_BCH_ERROR_LOC1415_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_ERROR_LOC1415_t {
+ struct {
+ unsigned int bcherrloc14:14; /* bits 13:0 */
+ unsigned int rsrvd1:2;
+ unsigned int bcherrloc15:14; /* bits 29:16 */
+ unsigned int rsrvd2:2;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_ERROR_LOC1617 0x000000f4
+#define FLASH_NF_BCH_ERROR_LOC1617_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_ERROR_LOC1617_t {
+ struct {
+ unsigned int bcherrloc16:14; /* bits 13:0 */
+ unsigned int rsrvd1:2;
+ unsigned int bcherrloc17:14; /* bits 29:16 */
+ unsigned int rsrvd2:2;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_ERROR_LOC1819 0x000000f8
+#define FLASH_NF_BCH_ERROR_LOC1819_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_ERROR_LOC1819_t {
+ struct {
+ unsigned int bcherrloc18:14; /* bits 13:0 */
+ unsigned int rsrvd1:2;
+ unsigned int bcherrloc19:14; /* bits 29:16 */
+ unsigned int rsrvd2:2;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_ERROR_LOC2021 0x000000fc
+#define FLASH_NF_BCH_ERROR_LOC2021_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_ERROR_LOC2021_t {
+ struct {
+ unsigned int bcherrloc20:14; /* bits 13:0 */
+ unsigned int rsrvd1:2;
+ unsigned int bcherrloc21:14; /* bits 29:16 */
+ unsigned int rsrvd2:2;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_ERROR_LOC2223 0x00000100
+#define FLASH_NF_BCH_ERROR_LOC2223_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_ERROR_LOC2223_t {
+ struct {
+ unsigned int bcherrloc22:14; /* bits 13:0 */
+ unsigned int rsrvd1:2;
+ unsigned int bcherrloc23:14; /* bits 29:16 */
+ unsigned int rsrvd2:2;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_ERROR_LOC2425 0x00000104
+#define FLASH_NF_BCH_ERROR_LOC2425_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_ERROR_LOC2425_t {
+ struct {
+ unsigned int bcherrloc24:14; /* bits 13:0 */
+ unsigned int rsrvd1:2;
+ unsigned int bcherrloc25:14; /* bits 29:16 */
+ unsigned int rsrvd2:2;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_ERROR_LOC2627 0x00000108
+#define FLASH_NF_BCH_ERROR_LOC2627_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_ERROR_LOC2627_t {
+ struct {
+ unsigned int bcherrloc26:14; /* bits 13:0 */
+ unsigned int rsrvd1:2;
+ unsigned int bcherrloc27:14; /* bits 29:16 */
+ unsigned int rsrvd2:2;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_ERROR_LOC2829 0x0000010c
+#define FLASH_NF_BCH_ERROR_LOC2829_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_ERROR_LOC2829_t {
+ struct {
+ unsigned int bcherrloc28:14; /* bits 13:0 */
+ unsigned int rsrvd1:2;
+ unsigned int bcherrloc29:14; /* bits 29:16 */
+ unsigned int rsrvd2:2;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_ERROR_LOC3031 0x00000110
+#define FLASH_NF_BCH_ERROR_LOC3031_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_ERROR_LOC3031_t {
+ struct {
+ unsigned int bcherrloc30:14; /* bits 13:0 */
+ unsigned int rsrvd1:2;
+ unsigned int bcherrloc31:14; /* bits 29:16 */
+ unsigned int rsrvd2:2;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_ERROR_LOC3233 0x00000114
+#define FLASH_NF_BCH_ERROR_LOC3233_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_ERROR_LOC3233_t {
+ struct {
+ unsigned int bcherrloc32:14; /* bits 13:0 */
+ unsigned int rsrvd1:2;
+ unsigned int bcherrloc33:14; /* bits 29:16 */
+ unsigned int rsrvd2:2;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_ERROR_LOC3435 0x00000118
+#define FLASH_NF_BCH_ERROR_LOC3435_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_ERROR_LOC3435_t {
+ struct {
+ unsigned int bcherrloc34:14; /* bits 13:0 */
+ unsigned int rsrvd1:2;
+ unsigned int bcherrloc35:14; /* bits 29:16 */
+ unsigned int rsrvd2:2;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_ERROR_LOC3637 0x0000011c
+#define FLASH_NF_BCH_ERROR_LOC3637_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_ERROR_LOC3637_t {
+ struct {
+ unsigned int bcherrloc36:14; /* bits 13:0 */
+ unsigned int rsrvd1:2;
+ unsigned int bcherrloc37:14; /* bits 29:16 */
+ unsigned int rsrvd2:2;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_ERROR_LOC3839 0x00000120
+#define FLASH_NF_BCH_ERROR_LOC3839_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_ERROR_LOC3839_t {
+ struct {
+ unsigned int bcherrloc38:14; /* bits 13:0 */
+ unsigned int rsrvd1:2;
+ unsigned int bcherrloc39:14; /* bits 29:16 */
+ unsigned int rsrvd2:2;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_OOB0 0x00000124
+#define FLASH_NF_BCH_OOB0_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_OOB0_t {
+ struct {
+ unsigned int bchcodeoob0:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_OOB1 0x00000128
+#define FLASH_NF_BCH_OOB1_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_OOB1_t {
+ struct {
+ unsigned int bchcodeoob1:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_OOB2 0x0000012c
+#define FLASH_NF_BCH_OOB2_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_OOB2_t {
+ struct {
+ unsigned int bchcodeoob2:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_OOB3 0x00000130
+#define FLASH_NF_BCH_OOB3_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_OOB3_t {
+ struct {
+ unsigned int bchcodeoob3:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_OOB4 0x00000134
+#define FLASH_NF_BCH_OOB4_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_OOB4_t {
+ struct {
+ unsigned int bchcodeoob4:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_OOB5 0x00000138
+#define FLASH_NF_BCH_OOB5_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_OOB5_t {
+ struct {
+ unsigned int bchcodeoob5:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_OOB6 0x0000013c
+#define FLASH_NF_BCH_OOB6_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_OOB6_t {
+ struct {
+ unsigned int bchcodeoob6:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_OOB7 0x00000140
+#define FLASH_NF_BCH_OOB7_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_OOB7_t {
+ struct {
+ unsigned int bchcodeoob7:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_OOB8 0x00000144
+#define FLASH_NF_BCH_OOB8_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_OOB8_t {
+ struct {
+ unsigned int bchcodeoob8:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_OOB9 0x00000148
+#define FLASH_NF_BCH_OOB9_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_OOB9_t {
+ struct {
+ unsigned int bchcodeoob9:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_OOB10 0x0000014c
+#define FLASH_NF_BCH_OOB10_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_OOB10_t {
+ struct {
+ unsigned int bchcodeoob10:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_OOB11 0x00000150
+#define FLASH_NF_BCH_OOB11_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_OOB11_t {
+ struct {
+ unsigned int bchcodeoob11:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_OOB12 0x00000154
+#define FLASH_NF_BCH_OOB12_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_OOB12_t {
+ struct {
+ unsigned int bchcodeoob12:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_OOB13 0x00000158
+#define FLASH_NF_BCH_OOB13_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_OOB13_t {
+ struct {
+ unsigned int bchcodeoob13:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_OOB14 0x0000015c
+#define FLASH_NF_BCH_OOB14_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_OOB14_t {
+ struct {
+ unsigned int bchcodeoob14:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_OOB15 0x00000160
+#define FLASH_NF_BCH_OOB15_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_OOB15_t {
+ struct {
+ unsigned int bchcodeoob15:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_OOB16 0x00000164
+#define FLASH_NF_BCH_OOB16_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_OOB16_t {
+ struct {
+ unsigned int bchcodeoob16:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_OOB17 0x00000168
+#define FLASH_NF_BCH_OOB17_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_OOB17_t {
+ struct {
+ unsigned int bchcodeoob17:16; /* bits 15:0 */
+ unsigned int rsrvd1:16;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN0_0 0x0000016c
+#define FLASH_NF_BCH_GEN0_0_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN0_0_t {
+ struct {
+ unsigned int bchcodegen0_0:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN0_1 0x00000170
+#define FLASH_NF_BCH_GEN0_1_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN0_1_t {
+ struct {
+ unsigned int bchcodegen0_1:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN0_2 0x00000174
+#define FLASH_NF_BCH_GEN0_2_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN0_2_t {
+ struct {
+ unsigned int bchcodegen0_2:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN0_3 0x00000178
+#define FLASH_NF_BCH_GEN0_3_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN0_3_t {
+ struct {
+ unsigned int bchcodegen0_3:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN0_4 0x0000017c
+#define FLASH_NF_BCH_GEN0_4_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN0_4_t {
+ struct {
+ unsigned int bchcodegen0_4:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN0_5 0x00000180
+#define FLASH_NF_BCH_GEN0_5_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN0_5_t {
+ struct {
+ unsigned int bchcodegen0_5:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN0_6 0x00000184
+#define FLASH_NF_BCH_GEN0_6_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN0_6_t {
+ struct {
+ unsigned int bchcodegen0_6:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN0_7 0x00000188
+#define FLASH_NF_BCH_GEN0_7_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN0_7_t {
+ struct {
+ unsigned int bchcodegen0_7:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN0_8 0x0000018c
+#define FLASH_NF_BCH_GEN0_8_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN0_8_t {
+ struct {
+ unsigned int bchcodegen0_8:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN0_9 0x00000190
+#define FLASH_NF_BCH_GEN0_9_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN0_9_t {
+ struct {
+ unsigned int bchcodegen0_9:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN0_10 0x00000194
+#define FLASH_NF_BCH_GEN0_10_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN0_10_t {
+ struct {
+ unsigned int bchcodegen0_10:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN0_11 0x00000198
+#define FLASH_NF_BCH_GEN0_11_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN0_11_t {
+ struct {
+ unsigned int bchcodegen0_11:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN0_12 0x0000019c
+#define FLASH_NF_BCH_GEN0_12_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN0_12_t {
+ struct {
+ unsigned int bchcodegen0_12:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN0_13 0x000001a0
+#define FLASH_NF_BCH_GEN0_13_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN0_13_t {
+ struct {
+ unsigned int bchcodegen0_13:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN0_14 0x000001a4
+#define FLASH_NF_BCH_GEN0_14_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN0_14_t {
+ struct {
+ unsigned int bchcodegen0_14:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN0_15 0x000001a8
+#define FLASH_NF_BCH_GEN0_15_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN0_15_t {
+ struct {
+ unsigned int bchcodegen0_15:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN0_16 0x000001ac
+#define FLASH_NF_BCH_GEN0_16_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN0_16_t {
+ struct {
+ unsigned int bchcodegen0_16:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN0_17 0x000001b0
+#define FLASH_NF_BCH_GEN0_17_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN0_17_t {
+ struct {
+ unsigned int bchcodegen0_17:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN1_0 0x000001b4
+#define FLASH_NF_BCH_GEN1_0_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN1_0_t {
+ struct {
+ unsigned int bchcodegen1_0:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN1_1 0x000001b8
+#define FLASH_NF_BCH_GEN1_1_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN1_1_t {
+ struct {
+ unsigned int bchcodegen1_1:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN1_2 0x000001bc
+#define FLASH_NF_BCH_GEN1_2_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN1_2_t {
+ struct {
+ unsigned int bchcodegen1_2:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN1_3 0x000001c0
+#define FLASH_NF_BCH_GEN1_3_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN1_3_t {
+ struct {
+ unsigned int bchcodegen1_3:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN1_4 0x000001c4
+#define FLASH_NF_BCH_GEN1_4_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN1_4_t {
+ struct {
+ unsigned int bchcodegen1_4:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN1_5 0x000001c8
+#define FLASH_NF_BCH_GEN1_5_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN1_5_t {
+ struct {
+ unsigned int bchcodegen1_5:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN1_6 0x000001cc
+#define FLASH_NF_BCH_GEN1_6_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN1_6_t {
+ struct {
+ unsigned int bchcodegen1_6:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN1_7 0x000001d0
+#define FLASH_NF_BCH_GEN1_7_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN1_7_t {
+ struct {
+ unsigned int bchcodegen1_7:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN1_8 0x000001d4
+#define FLASH_NF_BCH_GEN1_8_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN1_8_t {
+ struct {
+ unsigned int bchcodegen1_8:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN1_9 0x000001d8
+#define FLASH_NF_BCH_GEN1_9_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN1_9_t {
+ struct {
+ unsigned int bchcodegen1_9:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN1_10 0x000001dc
+#define FLASH_NF_BCH_GEN1_10_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN1_10_t {
+ struct {
+ unsigned int bchcodegen1_10:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN1_11 0x000001e0
+#define FLASH_NF_BCH_GEN1_11_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN1_11_t {
+ struct {
+ unsigned int bchcodegen1_11:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN1_12 0x000001e4
+#define FLASH_NF_BCH_GEN1_12_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN1_12_t {
+ struct {
+ unsigned int bchcodegen1_12:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN1_13 0x000001e8
+#define FLASH_NF_BCH_GEN1_13_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN1_13_t {
+ struct {
+ unsigned int bchcodegen1_13:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN1_14 0x000001ec
+#define FLASH_NF_BCH_GEN1_14_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN1_14_t {
+ struct {
+ unsigned int bchcodegen1_14:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN1_15 0x000001f0
+#define FLASH_NF_BCH_GEN1_15_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN1_15_t {
+ struct {
+ unsigned int bchcodegen1_15:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN1_16 0x000001f4
+#define FLASH_NF_BCH_GEN1_16_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN1_16_t {
+ struct {
+ unsigned int bchcodegen1_16:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN1_17 0x000001f8
+#define FLASH_NF_BCH_GEN1_17_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN1_17_t {
+ struct {
+ unsigned int bchcodegen1_17:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN2_0 0x000001fc
+#define FLASH_NF_BCH_GEN2_0_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN2_0_t {
+ struct {
+ unsigned int bchcodegen2_0:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN2_1 0x00000200
+#define FLASH_NF_BCH_GEN2_1_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN2_1_t {
+ struct {
+ unsigned int bchcodegen2_1:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN2_2 0x00000204
+#define FLASH_NF_BCH_GEN2_2_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN2_2_t {
+ struct {
+ unsigned int bchcodegen2_2:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN2_3 0x00000208
+#define FLASH_NF_BCH_GEN2_3_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN2_3_t {
+ struct {
+ unsigned int bchcodegen2_3:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN2_4 0x0000020c
+#define FLASH_NF_BCH_GEN2_4_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN2_4_t {
+ struct {
+ unsigned int bchcodegen2_4:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN2_5 0x00000210
+#define FLASH_NF_BCH_GEN2_5_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN2_5_t {
+ struct {
+ unsigned int bchcodegen2_5:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN2_6 0x00000214
+#define FLASH_NF_BCH_GEN2_6_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN2_6_t {
+ struct {
+ unsigned int bchcodegen2_6:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN2_7 0x00000218
+#define FLASH_NF_BCH_GEN2_7_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN2_7_t {
+ struct {
+ unsigned int bchcodegen2_7:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN2_8 0x0000021c
+#define FLASH_NF_BCH_GEN2_8_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN2_8_t {
+ struct {
+ unsigned int bchcodegen2_8:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN2_9 0x00000220
+#define FLASH_NF_BCH_GEN2_9_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN2_9_t {
+ struct {
+ unsigned int bchcodegen2_9:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN2_10 0x00000224
+#define FLASH_NF_BCH_GEN2_10_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN2_10_t {
+ struct {
+ unsigned int bchcodegen2_10:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN2_11 0x00000228
+#define FLASH_NF_BCH_GEN2_11_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN2_11_t {
+ struct {
+ unsigned int bchcodegen2_11:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN2_12 0x0000022c
+#define FLASH_NF_BCH_GEN2_12_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN2_12_t {
+ struct {
+ unsigned int bchcodegen2_12:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN2_13 0x00000230
+#define FLASH_NF_BCH_GEN2_13_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN2_13_t {
+ struct {
+ unsigned int bchcodegen2_13:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN2_14 0x00000234
+#define FLASH_NF_BCH_GEN2_14_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN2_14_t {
+ struct {
+ unsigned int bchcodegen2_14:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN2_15 0x00000238
+#define FLASH_NF_BCH_GEN2_15_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN2_15_t {
+ struct {
+ unsigned int bchcodegen2_15:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN2_16 0x0000023c
+#define FLASH_NF_BCH_GEN2_16_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN2_16_t {
+ struct {
+ unsigned int bchcodegen2_16:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN2_17 0x00000240
+#define FLASH_NF_BCH_GEN2_17_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN2_17_t {
+ struct {
+ unsigned int bchcodegen2_17:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN3_0 0x00000244
+#define FLASH_NF_BCH_GEN3_0_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN3_0_t {
+ struct {
+ unsigned int bchcodegen3_0:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN3_1 0x00000248
+#define FLASH_NF_BCH_GEN3_1_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN3_1_t {
+ struct {
+ unsigned int bchcodegen3_1:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN3_2 0x0000024c
+#define FLASH_NF_BCH_GEN3_2_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN3_2_t {
+ struct {
+ unsigned int bchcodegen3_2:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN3_3 0x00000250
+#define FLASH_NF_BCH_GEN3_3_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN3_3_t {
+ struct {
+ unsigned int bchcodegen3_3:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN3_4 0x00000254
+#define FLASH_NF_BCH_GEN3_4_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN3_4_t {
+ struct {
+ unsigned int bchcodegen3_4:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN3_5 0x00000258
+#define FLASH_NF_BCH_GEN3_5_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN3_5_t {
+ struct {
+ unsigned int bchcodegen3_5:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN3_6 0x0000025c
+#define FLASH_NF_BCH_GEN3_6_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN3_6_t {
+ struct {
+ unsigned int bchcodegen3_6:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN3_7 0x00000260
+#define FLASH_NF_BCH_GEN3_7_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN3_7_t {
+ struct {
+ unsigned int bchcodegen3_7:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN3_8 0x00000264
+#define FLASH_NF_BCH_GEN3_8_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN3_8_t {
+ struct {
+ unsigned int bchcodegen3_8:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN3_9 0x00000268
+#define FLASH_NF_BCH_GEN3_9_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN3_9_t {
+ struct {
+ unsigned int bchcodegen3_9:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN3_10 0x0000026c
+#define FLASH_NF_BCH_GEN3_10_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN3_10_t {
+ struct {
+ unsigned int bchcodegen3_10:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN3_11 0x00000270
+#define FLASH_NF_BCH_GEN3_11_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN3_11_t {
+ struct {
+ unsigned int bchcodegen3_11:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN3_12 0x00000274
+#define FLASH_NF_BCH_GEN3_12_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN3_12_t {
+ struct {
+ unsigned int bchcodegen3_12:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN3_13 0x00000278
+#define FLASH_NF_BCH_GEN3_13_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN3_13_t {
+ struct {
+ unsigned int bchcodegen3_13:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN3_14 0x0000027c
+#define FLASH_NF_BCH_GEN3_14_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN3_14_t {
+ struct {
+ unsigned int bchcodegen3_14:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN3_15 0x00000280
+#define FLASH_NF_BCH_GEN3_15_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN3_15_t {
+ struct {
+ unsigned int bchcodegen3_15:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN3_16 0x00000284
+#define FLASH_NF_BCH_GEN3_16_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN3_16_t {
+ struct {
+ unsigned int bchcodegen3_16:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN3_17 0x00000288
+#define FLASH_NF_BCH_GEN3_17_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN3_17_t {
+ struct {
+ unsigned int bchcodegen3_17:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN4_0 0x0000028c
+#define FLASH_NF_BCH_GEN4_0_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN4_0_t {
+ struct {
+ unsigned int bchcodegen4_0:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN4_1 0x00000290
+#define FLASH_NF_BCH_GEN4_1_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN4_1_t {
+ struct {
+ unsigned int bchcodegen4_1:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN4_2 0x00000294
+#define FLASH_NF_BCH_GEN4_2_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN4_2_t {
+ struct {
+ unsigned int bchcodegen4_2:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN4_3 0x00000298
+#define FLASH_NF_BCH_GEN4_3_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN4_3_t {
+ struct {
+ unsigned int bchcodegen4_3:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN4_4 0x0000029c
+#define FLASH_NF_BCH_GEN4_4_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN4_4_t {
+ struct {
+ unsigned int bchcodegen4_4:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN4_5 0x000002a0
+#define FLASH_NF_BCH_GEN4_5_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN4_5_t {
+ struct {
+ unsigned int bchcodegen4_5:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN4_6 0x000002a4
+#define FLASH_NF_BCH_GEN4_6_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN4_6_t {
+ struct {
+ unsigned int bchcodegen4_6:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN4_7 0x000002a8
+#define FLASH_NF_BCH_GEN4_7_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN4_7_t {
+ struct {
+ unsigned int bchcodegen4_7:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN4_8 0x000002ac
+#define FLASH_NF_BCH_GEN4_8_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN4_8_t {
+ struct {
+ unsigned int bchcodegen4_8:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN4_9 0x000002b0
+#define FLASH_NF_BCH_GEN4_9_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN4_9_t {
+ struct {
+ unsigned int bchcodegen4_9:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN4_10 0x000002b4
+#define FLASH_NF_BCH_GEN4_10_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN4_10_t {
+ struct {
+ unsigned int bchcodegen4_10:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN4_11 0x000002b8
+#define FLASH_NF_BCH_GEN4_11_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN4_11_t {
+ struct {
+ unsigned int bchcodegen4_11:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN4_12 0x000002bc
+#define FLASH_NF_BCH_GEN4_12_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN4_12_t {
+ struct {
+ unsigned int bchcodegen4_12:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN4_13 0x000002c0
+#define FLASH_NF_BCH_GEN4_13_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN4_13_t {
+ struct {
+ unsigned int bchcodegen4_13:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN4_14 0x000002c4
+#define FLASH_NF_BCH_GEN4_14_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN4_14_t {
+ struct {
+ unsigned int bchcodegen4_14:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN4_15 0x000002c8
+#define FLASH_NF_BCH_GEN4_15_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN4_15_t {
+ struct {
+ unsigned int bchcodegen4_15:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN4_16 0x000002cc
+#define FLASH_NF_BCH_GEN4_16_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN4_16_t {
+ struct {
+ unsigned int bchcodegen4_16:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN4_17 0x000002d0
+#define FLASH_NF_BCH_GEN4_17_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN4_17_t {
+ struct {
+ unsigned int bchcodegen4_17:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN5_0 0x000002d4
+#define FLASH_NF_BCH_GEN5_0_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN5_0_t {
+ struct {
+ unsigned int bchcodegen5_0:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN5_1 0x000002d8
+#define FLASH_NF_BCH_GEN5_1_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN5_1_t {
+ struct {
+ unsigned int bchcodegen5_1:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN5_2 0x000002dc
+#define FLASH_NF_BCH_GEN5_2_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN5_2_t {
+ struct {
+ unsigned int bchcodegen5_2:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN5_3 0x000002e0
+#define FLASH_NF_BCH_GEN5_3_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN5_3_t {
+ struct {
+ unsigned int bchcodegen5_3:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN5_4 0x000002e4
+#define FLASH_NF_BCH_GEN5_4_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN5_4_t {
+ struct {
+ unsigned int bchcodegen5_4:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN5_5 0x000002e8
+#define FLASH_NF_BCH_GEN5_5_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN5_5_t {
+ struct {
+ unsigned int bchcodegen5_5:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN5_6 0x000002ec
+#define FLASH_NF_BCH_GEN5_6_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN5_6_t {
+ struct {
+ unsigned int bchcodegen5_6:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN5_7 0x000002f0
+#define FLASH_NF_BCH_GEN5_7_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN5_7_t {
+ struct {
+ unsigned int bchcodegen5_7:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN5_8 0x000002f4
+#define FLASH_NF_BCH_GEN5_8_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN5_8_t {
+ struct {
+ unsigned int bchcodegen5_8:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN5_9 0x000002f8
+#define FLASH_NF_BCH_GEN5_9_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN5_9_t {
+ struct {
+ unsigned int bchcodegen5_9:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN5_10 0x000002fc
+#define FLASH_NF_BCH_GEN5_10_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN5_10_t {
+ struct {
+ unsigned int bchcodegen5_10:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN5_11 0x00000300
+#define FLASH_NF_BCH_GEN5_11_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN5_11_t {
+ struct {
+ unsigned int bchcodegen5_11:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN5_12 0x00000304
+#define FLASH_NF_BCH_GEN5_12_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN5_12_t {
+ struct {
+ unsigned int bchcodegen5_12:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN5_13 0x00000308
+#define FLASH_NF_BCH_GEN5_13_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN5_13_t {
+ struct {
+ unsigned int bchcodegen5_13:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN5_14 0x0000030c
+#define FLASH_NF_BCH_GEN5_14_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN5_14_t {
+ struct {
+ unsigned int bchcodegen5_14:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN5_15 0x00000310
+#define FLASH_NF_BCH_GEN5_15_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN5_15_t {
+ struct {
+ unsigned int bchcodegen5_15:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN5_16 0x00000314
+#define FLASH_NF_BCH_GEN5_16_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN5_16_t {
+ struct {
+ unsigned int bchcodegen5_16:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN5_17 0x00000318
+#define FLASH_NF_BCH_GEN5_17_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN5_17_t {
+ struct {
+ unsigned int bchcodegen5_17:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN6_0 0x0000031c
+#define FLASH_NF_BCH_GEN6_0_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN6_0_t {
+ struct {
+ unsigned int bchcodegen6_0:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN6_1 0x00000320
+#define FLASH_NF_BCH_GEN6_1_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN6_1_t {
+ struct {
+ unsigned int bchcodegen6_1:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN6_2 0x00000324
+#define FLASH_NF_BCH_GEN6_2_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN6_2_t {
+ struct {
+ unsigned int bchcodegen6_2:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN6_3 0x00000328
+#define FLASH_NF_BCH_GEN6_3_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN6_3_t {
+ struct {
+ unsigned int bchcodegen6_3:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN6_4 0x0000032c
+#define FLASH_NF_BCH_GEN6_4_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN6_4_t {
+ struct {
+ unsigned int bchcodegen6_4:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN6_5 0x00000330
+#define FLASH_NF_BCH_GEN6_5_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN6_5_t {
+ struct {
+ unsigned int bchcodegen6_5:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN6_6 0x00000334
+#define FLASH_NF_BCH_GEN6_6_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN6_6_t {
+ struct {
+ unsigned int bchcodegen6_6:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN6_7 0x00000338
+#define FLASH_NF_BCH_GEN6_7_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN6_7_t {
+ struct {
+ unsigned int bchcodegen6_7:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN6_8 0x0000033c
+#define FLASH_NF_BCH_GEN6_8_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN6_8_t {
+ struct {
+ unsigned int bchcodegen6_8:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN6_9 0x00000340
+#define FLASH_NF_BCH_GEN6_9_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN6_9_t {
+ struct {
+ unsigned int bchcodegen6_9:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN6_10 0x00000344
+#define FLASH_NF_BCH_GEN6_10_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN6_10_t {
+ struct {
+ unsigned int bchcodegen6_10:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN6_11 0x00000348
+#define FLASH_NF_BCH_GEN6_11_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN6_11_t {
+ struct {
+ unsigned int bchcodegen6_11:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN6_12 0x0000034c
+#define FLASH_NF_BCH_GEN6_12_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN6_12_t {
+ struct {
+ unsigned int bchcodegen6_12:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN6_13 0x00000350
+#define FLASH_NF_BCH_GEN6_13_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN6_13_t {
+ struct {
+ unsigned int bchcodegen6_13:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN6_14 0x00000354
+#define FLASH_NF_BCH_GEN6_14_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN6_14_t {
+ struct {
+ unsigned int bchcodegen6_14:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN6_15 0x00000358
+#define FLASH_NF_BCH_GEN6_15_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN6_15_t {
+ struct {
+ unsigned int bchcodegen6_15:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN6_16 0x0000035c
+#define FLASH_NF_BCH_GEN6_16_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN6_16_t {
+ struct {
+ unsigned int bchcodegen6_16:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN6_17 0x00000360
+#define FLASH_NF_BCH_GEN6_17_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN6_17_t {
+ struct {
+ unsigned int bchcodegen6_17:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN7_0 0x00000364
+#define FLASH_NF_BCH_GEN7_0_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN7_0_t {
+ struct {
+ unsigned int bchcodegen7_0:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN7_1 0x00000368
+#define FLASH_NF_BCH_GEN7_1_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN7_1_t {
+ struct {
+ unsigned int bchcodegen7_1:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN7_2 0x0000036c
+#define FLASH_NF_BCH_GEN7_2_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN7_2_t {
+ struct {
+ unsigned int bchcodegen7_2:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN7_3 0x00000370
+#define FLASH_NF_BCH_GEN7_3_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN7_3_t {
+ struct {
+ unsigned int bchcodegen7_3:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN7_4 0x00000374
+#define FLASH_NF_BCH_GEN7_4_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN7_4_t {
+ struct {
+ unsigned int bchcodegen7_4:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN7_5 0x00000378
+#define FLASH_NF_BCH_GEN7_5_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN7_5_t {
+ struct {
+ unsigned int bchcodegen7_5:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN7_6 0x0000037c
+#define FLASH_NF_BCH_GEN7_6_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN7_6_t {
+ struct {
+ unsigned int bchcodegen7_6:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN7_7 0x00000380
+#define FLASH_NF_BCH_GEN7_7_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN7_7_t {
+ struct {
+ unsigned int bchcodegen7_7:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN7_8 0x00000384
+#define FLASH_NF_BCH_GEN7_8_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN7_8_t {
+ struct {
+ unsigned int bchcodegen7_8:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN7_9 0x00000388
+#define FLASH_NF_BCH_GEN7_9_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN7_9_t {
+ struct {
+ unsigned int bchcodegen7_9:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN7_10 0x0000038c
+#define FLASH_NF_BCH_GEN7_10_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN7_10_t {
+ struct {
+ unsigned int bchcodegen7_10:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN7_11 0x00000390
+#define FLASH_NF_BCH_GEN7_11_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN7_11_t {
+ struct {
+ unsigned int bchcodegen7_11:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN7_12 0x00000394
+#define FLASH_NF_BCH_GEN7_12_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN7_12_t {
+ struct {
+ unsigned int bchcodegen7_12:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN7_13 0x00000398
+#define FLASH_NF_BCH_GEN7_13_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN7_13_t {
+ struct {
+ unsigned int bchcodegen7_13:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN7_14 0x0000039c
+#define FLASH_NF_BCH_GEN7_14_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN7_14_t {
+ struct {
+ unsigned int bchcodegen7_14:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN7_15 0x000003a0
+#define FLASH_NF_BCH_GEN7_15_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN7_15_t {
+ struct {
+ unsigned int bchcodegen7_15:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN7_16 0x000003a4
+#define FLASH_NF_BCH_GEN7_16_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN7_16_t {
+ struct {
+ unsigned int bchcodegen7_16:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define FLASH_NF_BCH_GEN7_17 0x000003a8
+#define FLASH_NF_BCH_GEN7_17_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union FLASH_NF_BCH_GEN7_17_t {
+ struct {
+ unsigned int bchcodegen7_17:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+// DMA registers
+#define DMA_SEC_DMA_GLB_DMA_LSO_CTRL 0x00000000
+#define DMA_SEC_DMA_GLB_DMA_LSO_CTRL_dft 0x00000020
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_GLB_DMA_LSO_CTRL_t {
+ struct {
+ unsigned int tx_dma_enable:1; /* bits 0:0 */
+ unsigned int rsrvd1:1;
+ unsigned int tx_burst_len:2; /* bits 3:2 */
+ unsigned int rsrvd2:1;
+ unsigned int lso_padding_en:1; /* bits 5:5 */
+ unsigned int ss_unit_sel:2; /* bits 7:6 */
+ unsigned int dma_lso_sreset:1; /* bits 8:8 */
+ unsigned int dma_pktcnt_sel:1; /* bits 9:9 */
+ unsigned int rsrvd3:22;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_GLB_LSO_INTERRUPT 0x00000004
+#define DMA_SEC_DMA_GLB_LSO_INTERRUPT_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_GLB_LSO_INTERRUPT_t {
+ struct {
+ unsigned int ipv4_dec_err:1; /* bits 0:0 */
+ unsigned int ipv6_dec_err:1; /* bits 1:1 */
+ unsigned int tcp_dec_err:1; /* bits 2:2 */
+ unsigned int udp_dec_err:1; /* bits 3:3 */
+ unsigned int pkt_len_err:1; /* bits 4:4 */
+ unsigned int rsrvd1:27;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_GLB_LSO_INTENABLE 0x00000008
+#define DMA_SEC_DMA_GLB_LSO_INTENABLE_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_GLB_LSO_INTENABLE_t {
+ struct {
+ unsigned int ipv4_dec_err_en:1; /* bits 0:0 */
+ unsigned int ipv6_dec_err_en:1; /* bits 1:1 */
+ unsigned int tcp_dec_err_en:1; /* bits 2:2 */
+ unsigned int udp_dec_err_en:1; /* bits 3:3 */
+ unsigned int pkt_len_err_en:1; /* bits 4:4 */
+ unsigned int rsrvd1:27;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_GLB_DMA_LSO_VLAN_TAG_TYPE0 0x0000000c
+#define DMA_SEC_DMA_GLB_DMA_LSO_VLAN_TAG_TYPE0_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_GLB_DMA_LSO_VLAN_TAG_TYPE0_t {
+ struct {
+ unsigned int value:16; /* bits 15:0 */
+ unsigned int rsrvd1:15;
+ unsigned int enable:1; /* bits 31:31 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_GLB_DMA_LSO_VLAN_TAG_TYPE1 0x00000010
+#define DMA_SEC_DMA_GLB_DMA_LSO_VLAN_TAG_TYPE1_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_GLB_DMA_LSO_VLAN_TAG_TYPE1_t {
+ struct {
+ unsigned int value:16; /* bits 15:0 */
+ unsigned int rsrvd1:15;
+ unsigned int enable:1; /* bits 31:31 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_GLB_DMA_LSO_AXI_USER_SEL0 0x00000014
+#define DMA_SEC_DMA_GLB_DMA_LSO_AXI_USER_SEL0_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_GLB_DMA_LSO_AXI_USER_SEL0_t {
+ struct {
+ unsigned int vp0_rd_pat:2; /* bits 1:0 */
+ unsigned int vp1_rd_pat:2; /* bits 3:2 */
+ unsigned int vp2_rd_pat:2; /* bits 5:4 */
+ unsigned int vp3_rd_pat:2; /* bits 7:6 */
+ unsigned int vp4_rd_pat:2; /* bits 9:8 */
+ unsigned int vp5_rd_pat:2; /* bits 11:10 */
+ unsigned int vp6_rd_pat:2; /* bits 13:12 */
+ unsigned int vp7_rd_pat:2; /* bits 15:14 */
+ unsigned int vp8_rd_pat:2; /* bits 17:16 */
+ unsigned int vp9_rd_pat:2; /* bits 19:18 */
+ unsigned int vp10_rd_pat:2; /* bits 21:20 */
+ unsigned int vp11_rd_pat:2; /* bits 23:22 */
+ unsigned int rsrvd1:8;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_GLB_AXI_USER_PAT0 0x00000018
+#define DMA_SEC_DMA_GLB_AXI_USER_PAT0_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_GLB_AXI_USER_PAT0_t {
+ struct {
+ unsigned int usr_pat0:26; /* bits 25:0 */
+ unsigned int rsrvd1:6;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_GLB_AXI_USER_PAT1 0x0000001c
+#define DMA_SEC_DMA_GLB_AXI_USER_PAT1_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_GLB_AXI_USER_PAT1_t {
+ struct {
+ unsigned int usr_pat1:26; /* bits 25:0 */
+ unsigned int rsrvd1:6;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_GLB_AXI_USER_PAT2 0x00000020
+#define DMA_SEC_DMA_GLB_AXI_USER_PAT2_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_GLB_AXI_USER_PAT2_t {
+ struct {
+ unsigned int usr_pat2:26; /* bits 25:0 */
+ unsigned int rsrvd1:6;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_GLB_AXI_USER_PAT3 0x00000024
+#define DMA_SEC_DMA_GLB_AXI_USER_PAT3_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_GLB_AXI_USER_PAT3_t {
+ struct {
+ unsigned int usr_pat3:26; /* bits 25:0 */
+ unsigned int rsrvd1:6;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_GLB_FAST_REG_PE0 0x00000028
+#define DMA_SEC_DMA_GLB_FAST_REG_PE0_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_GLB_FAST_REG_PE0_t {
+ struct {
+ unsigned int pe0_en:12; /* bits 11:0 */
+ unsigned int rsrvd1:20;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_GLB_FAST_REG_PE1 0x0000002c
+#define DMA_SEC_DMA_GLB_FAST_REG_PE1_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_GLB_FAST_REG_PE1_t {
+ struct {
+ unsigned int pe1_en:12; /* bits 11:0 */
+ unsigned int rsrvd1:20;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_GLB_DMA_LSO_TX_FDES_ADDR0 0x00000030
+#define DMA_SEC_DMA_GLB_DMA_LSO_TX_FDES_ADDR0_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_GLB_DMA_LSO_TX_FDES_ADDR0_t {
+ struct {
+ unsigned int tx_fdaddr:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_GLB_DMA_LSO_TX_FDES_ADDR1 0x00000034
+#define DMA_SEC_DMA_GLB_DMA_LSO_TX_FDES_ADDR1_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_GLB_DMA_LSO_TX_FDES_ADDR1_t {
+ struct {
+ unsigned int tx_fdaddr:8; /* bits 7:0 */
+ unsigned int rsrvd1:24;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_GLB_DMA_LSO_TX_CDES_ADDR0 0x00000038
+#define DMA_SEC_DMA_GLB_DMA_LSO_TX_CDES_ADDR0_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_GLB_DMA_LSO_TX_CDES_ADDR0_t {
+ struct {
+ unsigned int tx_cdaddr:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_GLB_DMA_LSO_TX_CDES_ADDR1 0x0000003c
+#define DMA_SEC_DMA_GLB_DMA_LSO_TX_CDES_ADDR1_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_GLB_DMA_LSO_TX_CDES_ADDR1_t {
+ struct {
+ unsigned int tx_cdaddr:8; /* bits 7:0 */
+ unsigned int rsrvd1:24;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_GLB_DMA_LSO_TX_DES_WORD0 0x00000040
+#define DMA_SEC_DMA_GLB_DMA_LSO_TX_DES_WORD0_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_GLB_DMA_LSO_TX_DES_WORD0_t {
+ struct {
+ unsigned int data:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_GLB_DMA_LSO_TX_DES_WORD1 0x00000044
+#define DMA_SEC_DMA_GLB_DMA_LSO_TX_DES_WORD1_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_GLB_DMA_LSO_TX_DES_WORD1_t {
+ struct {
+ unsigned int data:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_GLB_DMA_LSO_LSO_PARA_WORD0 0x00000048
+#define DMA_SEC_DMA_GLB_DMA_LSO_LSO_PARA_WORD0_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_GLB_DMA_LSO_LSO_PARA_WORD0_t {
+ struct {
+ unsigned int data:22; /* bits 21:0 */
+ unsigned int rsrvd1:10;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_GLB_DMA_LSO_LSO_PARA_WORD1 0x0000004c
+#define DMA_SEC_DMA_GLB_DMA_LSO_LSO_PARA_WORD1_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_GLB_DMA_LSO_LSO_PARA_WORD1_t {
+ struct {
+ unsigned int data:18; /* bits 17:0 */
+ unsigned int rsrvd1:14;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_GLB_DMA_LSO_DEBUG0 0x00000050
+#define DMA_SEC_DMA_GLB_DMA_LSO_DEBUG0_dft 0x01000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_GLB_DMA_LSO_DEBUG0_t {
+ struct {
+ unsigned int dmatx_cs:3; /* bits 2:0 */
+ unsigned int rsrvd1:1;
+ unsigned int desc_cs:3; /* bits 6:4 */
+ unsigned int rsrvd2:1;
+ unsigned int txfer_cs:3; /* bits 10:8 */
+ unsigned int rsrvd3:1;
+ unsigned int dat_cs:2; /* bits 13:12 */
+ unsigned int rsrvd4:2;
+ unsigned int txfout_cs:4; /* bits 19:16 */
+ unsigned int base_cs:3; /* bits 22:20 */
+ unsigned int rsrvd5:1;
+ unsigned int pktcnt_cs:3; /* bits 26:24 */
+ unsigned int rsrvd6:5;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_GLB_DMA_LSO_DEBUG1 0x00000054
+#define DMA_SEC_DMA_GLB_DMA_LSO_DEBUG1_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_GLB_DMA_LSO_DEBUG1_t {
+ struct {
+ unsigned int dmaif_fifo_cs:5; /* bits 4:0 */
+ unsigned int dmaif_state:4; /* bits 8:5 */
+ unsigned int outctl_fout_cs:4; /* bits 12:9 */
+ unsigned int outctl_fin_cs:3; /* bits 15:13 */
+ unsigned int inctl_fout_cs:4; /* bits 19:16 */
+ unsigned int inctl_fin_cs:2; /* bits 21:20 */
+ unsigned int rsrvd1:10;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_GLB_DMA_LSO_DEBUG2 0x00000058
+#define DMA_SEC_DMA_GLB_DMA_LSO_DEBUG2_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_GLB_DMA_LSO_DEBUG2_t {
+ struct {
+ unsigned int udp_cs:4; /* bits 3:0 */
+ unsigned int tcp_cs:4; /* bits 7:4 */
+ unsigned int ip_cs:4; /* bits 11:8 */
+ unsigned int macif_macif_st:3; /* bits 14:12 */
+ unsigned int rsrvd1:17;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_GLB_DMA_LSO_SPARE0 0x0000005c
+#define DMA_SEC_DMA_GLB_DMA_LSO_SPARE0_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_GLB_DMA_LSO_SPARE0_t {
+ struct {
+ unsigned int dma_spare0:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_GLB_DMA_LSO_SPARE1 0x00000060
+#define DMA_SEC_DMA_GLB_DMA_LSO_SPARE1_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_GLB_DMA_LSO_SPARE1_t {
+ struct {
+ unsigned int dma_spare1:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_GLB_DMA_SSP_RX_CTRL 0x00000064
+#define DMA_SEC_DMA_GLB_DMA_SSP_RX_CTRL_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_GLB_DMA_SSP_RX_CTRL_t {
+ struct {
+ unsigned int rx_dma_enable:1; /* bits 0:0 */
+ unsigned int rx_check_own:1; /* bits 1:1 */
+ unsigned int rxdes_update_en:1; /* bits 2:2 */
+ unsigned int rsrvd1:29;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_GLB_DMA_SSP_TX_CTRL 0x00000068
+#define DMA_SEC_DMA_GLB_DMA_SSP_TX_CTRL_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_GLB_DMA_SSP_TX_CTRL_t {
+ struct {
+ unsigned int tx_dma_enable:1; /* bits 0:0 */
+ unsigned int tx_check_own:1; /* bits 1:1 */
+ unsigned int txdes_update_en:1; /* bits 2:2 */
+ unsigned int dma_ssp_sreset:1; /* bits 3:3 */
+ unsigned int rsrvd1:28;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_GLB_DMA_SSP_AXI_USER_SEL0 0x0000006c
+#define DMA_SEC_DMA_GLB_DMA_SSP_AXI_USER_SEL0_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_GLB_DMA_SSP_AXI_USER_SEL0_t {
+ struct {
+ unsigned int q5_rd_pat:2; /* bits 1:0 */
+ unsigned int q6_rd_pat:2; /* bits 3:2 */
+ unsigned int q7_rd_pat:2; /* bits 5:4 */
+ unsigned int rsrvd1:26;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_GLB_DMA_SSP_AXI_USER_SEL1 0x00000070
+#define DMA_SEC_DMA_GLB_DMA_SSP_AXI_USER_SEL1_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_GLB_DMA_SSP_AXI_USER_SEL1_t {
+ struct {
+ unsigned int q5_wr_pat:2; /* bits 1:0 */
+ unsigned int q6_wr_pat:2; /* bits 3:2 */
+ unsigned int q7_wr_pat:2; /* bits 5:4 */
+ unsigned int rsrvd1:26;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_GLB_DMA_SSP_RX_FDES_ADDR0 0x00000074
+#define DMA_SEC_DMA_GLB_DMA_SSP_RX_FDES_ADDR0_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_GLB_DMA_SSP_RX_FDES_ADDR0_t {
+ struct {
+ unsigned int rx_fdaddr:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_GLB_DMA_SSP_RX_FDES_ADDR1 0x00000078
+#define DMA_SEC_DMA_GLB_DMA_SSP_RX_FDES_ADDR1_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_GLB_DMA_SSP_RX_FDES_ADDR1_t {
+ struct {
+ unsigned int rx_fdaddr:8; /* bits 7:0 */
+ unsigned int rsrvd1:24;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_GLB_DMA_SSP_RX_CDES_ADDR0 0x0000007c
+#define DMA_SEC_DMA_GLB_DMA_SSP_RX_CDES_ADDR0_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_GLB_DMA_SSP_RX_CDES_ADDR0_t {
+ struct {
+ unsigned int rx_cdaddr:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_GLB_DMA_SSP_RX_CDES_ADDR1 0x00000080
+#define DMA_SEC_DMA_GLB_DMA_SSP_RX_CDES_ADDR1_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_GLB_DMA_SSP_RX_CDES_ADDR1_t {
+ struct {
+ unsigned int rx_cdaddr:8; /* bits 7:0 */
+ unsigned int rsrvd1:24;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_GLB_DMA_SSP_RX_DES_WORD0 0x00000084
+#define DMA_SEC_DMA_GLB_DMA_SSP_RX_DES_WORD0_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_GLB_DMA_SSP_RX_DES_WORD0_t {
+ struct {
+ unsigned int data:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_GLB_DMA_SSP_RX_DES_WORD1 0x00000088
+#define DMA_SEC_DMA_GLB_DMA_SSP_RX_DES_WORD1_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_GLB_DMA_SSP_RX_DES_WORD1_t {
+ struct {
+ unsigned int data:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_GLB_DMA_SSP_TX_FDES_ADDR0 0x0000008c
+#define DMA_SEC_DMA_GLB_DMA_SSP_TX_FDES_ADDR0_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_GLB_DMA_SSP_TX_FDES_ADDR0_t {
+ struct {
+ unsigned int tx_fdaddr:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_GLB_DMA_SSP_TX_FDES_ADDR1 0x00000090
+#define DMA_SEC_DMA_GLB_DMA_SSP_TX_FDES_ADDR1_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_GLB_DMA_SSP_TX_FDES_ADDR1_t {
+ struct {
+ unsigned int tx_fdaddr:8; /* bits 7:0 */
+ unsigned int rsrvd1:24;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_GLB_DMA_SSP_TX_CDES_ADDR0 0x00000094
+#define DMA_SEC_DMA_GLB_DMA_SSP_TX_CDES_ADDR0_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_GLB_DMA_SSP_TX_CDES_ADDR0_t {
+ struct {
+ unsigned int tx_cdaddr:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_GLB_DMA_SSP_TX_CDES_ADDR1 0x00000098
+#define DMA_SEC_DMA_GLB_DMA_SSP_TX_CDES_ADDR1_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_GLB_DMA_SSP_TX_CDES_ADDR1_t {
+ struct {
+ unsigned int tx_cdaddr:8; /* bits 7:0 */
+ unsigned int rsrvd1:24;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_GLB_DMA_SSP_TX_DES_WORD0 0x0000009c
+#define DMA_SEC_DMA_GLB_DMA_SSP_TX_DES_WORD0_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_GLB_DMA_SSP_TX_DES_WORD0_t {
+ struct {
+ unsigned int data:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_GLB_DMA_SSP_TX_DES_WORD1 0x000000a0
+#define DMA_SEC_DMA_GLB_DMA_SSP_TX_DES_WORD1_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_GLB_DMA_SSP_TX_DES_WORD1_t {
+ struct {
+ unsigned int data:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_GLB_DMA_SSP_DEBUG0 0x000000a4
+#define DMA_SEC_DMA_GLB_DMA_SSP_DEBUG0_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_GLB_DMA_SSP_DEBUG0_t {
+ struct {
+ unsigned int rxsch_cs:3; /* bits 2:0 */
+ unsigned int rsrvd1:1;
+ unsigned int dmarx_cs:5; /* bits 8:4 */
+ unsigned int rsrvd2:3;
+ unsigned int rxfer_cs:3; /* bits 14:12 */
+ unsigned int rsrvd3:1;
+ unsigned int rxfin_cs:2; /* bits 17:16 */
+ unsigned int rsrvd4:2;
+ unsigned int rxfout_cs:3; /* bits 22:20 */
+ unsigned int rsrvd5:9;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_GLB_DMA_SSP_DEBUG1 0x000000a8
+#define DMA_SEC_DMA_GLB_DMA_SSP_DEBUG1_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_GLB_DMA_SSP_DEBUG1_t {
+ struct {
+ unsigned int sp_cs:3; /* bits 2:0 */
+ unsigned int rsrvd1:1;
+ unsigned int rr1_cs:3; /* bits 6:4 */
+ unsigned int rsrvd2:1;
+ unsigned int dmatx_cs:5; /* bits 12:8 */
+ unsigned int rsrvd3:3;
+ unsigned int txfer_cs:3; /* bits 18:16 */
+ unsigned int rsrvd4:1;
+ unsigned int txfout_cs:3; /* bits 22:20 */
+ unsigned int rsrvd5:1;
+ unsigned int mux_cs:3; /* bits 26:24 */
+ unsigned int mmc_cs:2; /* bits 28:27 */
+ unsigned int rsrvd6:3;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_GLB_DMA_SSP_DEBUG2 0x000000ac
+#define DMA_SEC_DMA_GLB_DMA_SSP_DEBUG2_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_GLB_DMA_SSP_DEBUG2_t {
+ struct {
+ unsigned int flash_cs:2; /* bits 1:0 */
+ unsigned int ssptx_cs:3; /* bits 4:2 */
+ unsigned int ssprx_cs:2; /* bits 6:5 */
+ unsigned int rsrvd1:25;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_GLB_DMA_SSP_SPARE0 0x000000b0
+#define DMA_SEC_DMA_GLB_DMA_SSP_SPARE0_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_GLB_DMA_SSP_SPARE0_t {
+ struct {
+ unsigned int dma_spare0:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_GLB_DMA_SSP_SPARE1 0x000000b4
+#define DMA_SEC_DMA_GLB_DMA_SSP_SPARE1_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_GLB_DMA_SSP_SPARE1_t {
+ struct {
+ unsigned int dma_spare1:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+/* DMA_SSP */
+#define DMA_SEC_DMA_SSP_Q_RXQ_CONTROL 0x00000000
+#define DMA_SEC_DMA_SSP_Q_RXQ_CONTROL_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_SSP_Q_RXQ_CONTROL_t {
+ struct {
+ unsigned int rsrvd1:1;
+ unsigned int rxq_flush_en:1; /* bits 1:1 */
+ unsigned int rsrvd2:1;
+ unsigned int burst_size:1; /* bits 3:3 */
+ unsigned int rsrvd3:2;
+ unsigned int rxq_packet_threshold:6; /* bits 11:6 */
+ unsigned int rxq_tmr:20; /* bits 31:12 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_SSP_Q_RXQ_BASE_DEPTH 0x00000004
+#define DMA_SEC_DMA_SSP_Q_RXQ_BASE_DEPTH_dft 0x00000003
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_SSP_Q_RXQ_BASE_DEPTH_t {
+ struct {
+ unsigned int depth:4; /* bits 3:0 */
+ unsigned int base:28; /* bits 31:4 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_SSP_Q_RXQ_BASE 0x00000008
+#define DMA_SEC_DMA_SSP_Q_RXQ_BASE_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_SSP_Q_RXQ_BASE_t {
+ struct {
+ unsigned int base:8; /* bits 7:0 */
+ unsigned int rsrvd1:24;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_SSP_Q_RXQ_WPTR 0x0000000c
+#define DMA_SEC_DMA_SSP_Q_RXQ_WPTR_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_SSP_Q_RXQ_WPTR_t {
+ struct {
+ unsigned int index:13; /* bits 12:0 */
+ unsigned int rsrvd1:19;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_SSP_Q_RXQ_RPTR 0x00000010
+#define DMA_SEC_DMA_SSP_Q_RXQ_RPTR_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_SSP_Q_RXQ_RPTR_t {
+ struct {
+ unsigned int index:13; /* bits 12:0 */
+ unsigned int rsrvd1:19;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_SSP_Q_RXQ_PKTCNT 0x00000014
+#define DMA_SEC_DMA_SSP_Q_RXQ_PKTCNT_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_SSP_Q_RXQ_PKTCNT_t {
+ struct {
+ unsigned int counter:24; /* bits 23:0 */
+ unsigned int rsrvd1:8;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_SSP_Q_TXQ_CONTROL 0x00000018
+#define DMA_SEC_DMA_SSP_Q_TXQ_CONTROL_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_SSP_Q_TXQ_CONTROL_t {
+ struct {
+ unsigned int txq_en:1; /* bits 0:0 */
+ unsigned int txq_flush_en:1; /* bits 1:1 */
+ unsigned int txq_sp_en:1; /* bits 2:2 */
+ unsigned int burst_size:1; /* bits 3:3 */
+ unsigned int rsrvd1:2;
+ unsigned int txq_packet_threshold:6; /* bits 11:6 */
+ unsigned int txq_tmr:20; /* bits 31:12 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_SSP_Q_TXQ_BASE_DEPTH 0x0000001c
+#define DMA_SEC_DMA_SSP_Q_TXQ_BASE_DEPTH_dft 0x00000003
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_SSP_Q_TXQ_BASE_DEPTH_t {
+ struct {
+ unsigned int depth:4; /* bits 3:0 */
+ unsigned int base:28; /* bits 31:4 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_SSP_Q_TXQ_BASE 0x00000020
+#define DMA_SEC_DMA_SSP_Q_TXQ_BASE_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_SSP_Q_TXQ_BASE_t {
+ struct {
+ unsigned int base:8; /* bits 7:0 */
+ unsigned int rsrvd1:24;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_SSP_Q_TXQ_WPTR 0x00000024
+#define DMA_SEC_DMA_SSP_Q_TXQ_WPTR_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_SSP_Q_TXQ_WPTR_t {
+ struct {
+ unsigned int index:13; /* bits 12:0 */
+ unsigned int rsrvd1:19;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_SSP_Q_TXQ_RPTR 0x00000028
+#define DMA_SEC_DMA_SSP_Q_TXQ_RPTR_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_SSP_Q_TXQ_RPTR_t {
+ struct {
+ unsigned int index:13; /* bits 12:0 */
+ unsigned int rsrvd1:19;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_SSP_Q_TXQ_PKTCNT 0x0000002c
+#define DMA_SEC_DMA_SSP_Q_TXQ_PKTCNT_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_SSP_Q_TXQ_PKTCNT_t {
+ struct {
+ unsigned int counter:24; /* bits 23:0 */
+ unsigned int rsrvd1:8;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_SSP_Q_RXQ_INTERRUPT 0x00000030
+#define DMA_SEC_DMA_SSP_Q_RXQ_INTERRUPT_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_SSP_Q_RXQ_INTERRUPT_t {
+ struct {
+ unsigned int rxq_misc_interrupti:1; /* bits 0:0 */
+ unsigned int rxq_coal_interrupti:1; /* bits 1:1 */
+ unsigned int rsrvd1:30;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_SSP_Q_RXQ_INTENABLE 0x00000034
+#define DMA_SEC_DMA_SSP_Q_RXQ_INTENABLE_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_SSP_Q_RXQ_INTENABLE_t {
+ struct {
+ unsigned int rxq_misc_interrupti_en:1; /* bits 0:0 */
+ unsigned int rxq_coal_interrupti_en:1; /* bits 1:1 */
+ unsigned int rsrvd1:30;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_SSP_Q_TXQ_INTERRUPT 0x00000038
+#define DMA_SEC_DMA_SSP_Q_TXQ_INTERRUPT_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_SSP_Q_TXQ_INTERRUPT_t {
+ struct {
+ unsigned int txq_misc_interrupti:1; /* bits 0:0 */
+ unsigned int txq_coal_interrupti:1; /* bits 1:1 */
+ unsigned int rsrvd1:30;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_SSP_Q_TXQ_INTENABLE 0x0000003c
+#define DMA_SEC_DMA_SSP_Q_TXQ_INTENABLE_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_SSP_Q_TXQ_INTENABLE_t {
+ struct {
+ unsigned int txq_misc_interrupti_en:1; /* bits 0:0 */
+ unsigned int txq_coal_interrupti_en:1; /* bits 1:1 */
+ unsigned int rsrvd1:30;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_SSP_Q_RXQ_MISC_INTERRUPT 0x00000040
+#define DMA_SEC_DMA_SSP_Q_RXQ_MISC_INTERRUPT_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_SSP_Q_RXQ_MISC_INTERRUPT_t {
+ struct {
+ unsigned int rxq_full:1; /* bits 0:0 */
+ unsigned int rxq_overrun:1; /* bits 1:1 */
+ unsigned int rxq_desc_err:1; /* bits 2:2 */
+ unsigned int rsrvd1:29;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_SSP_Q_RXQ_MISC_INTENABLE 0x00000044
+#define DMA_SEC_DMA_SSP_Q_RXQ_MISC_INTENABLE_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_SSP_Q_RXQ_MISC_INTENABLE_t {
+ struct {
+ unsigned int rxq_full_en:1; /* bits 0:0 */
+ unsigned int rxq_overrun_en:1; /* bits 1:1 */
+ unsigned int rxq_desc_err_en:1; /* bits 2:2 */
+ unsigned int rsrvd1:29;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_SSP_Q_TXQ_MISC_INTERRUPT 0x00000048
+#define DMA_SEC_DMA_SSP_Q_TXQ_MISC_INTERRUPT_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_SSP_Q_TXQ_MISC_INTERRUPT_t {
+ struct {
+ unsigned int txq_empty:1; /* bits 0:0 */
+ unsigned int txq_overrun:1; /* bits 1:1 */
+ unsigned int txq_desc_err:1; /* bits 2:2 */
+ unsigned int rsrvd1:29;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_SSP_Q_TXQ_MISC_INTENABLE 0x0000004c
+#define DMA_SEC_DMA_SSP_Q_TXQ_MISC_INTENABLE_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_SSP_Q_TXQ_MISC_INTENABLE_t {
+ struct {
+ unsigned int txq_empty_en:1; /* bits 0:0 */
+ unsigned int txq_overrun_en:1; /* bits 1:1 */
+ unsigned int txq_desc_err_en:1; /* bits 2:2 */
+ unsigned int rsrvd1:29;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_SSP_Q_RXQ_COAL_INTERRUPT 0x00000050
+#define DMA_SEC_DMA_SSP_Q_RXQ_COAL_INTERRUPT_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_SSP_Q_RXQ_COAL_INTERRUPT_t {
+ struct {
+ unsigned int rxq_eof:1; /* bits 0:0 */
+ unsigned int rsrvd1:31;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_SSP_Q_RXQ_COAL_INTENABLE 0x00000054
+#define DMA_SEC_DMA_SSP_Q_RXQ_COAL_INTENABLE_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_SSP_Q_RXQ_COAL_INTENABLE_t {
+ struct {
+ unsigned int rxq_eof_en:1; /* bits 0:0 */
+ unsigned int rsrvd1:31;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_SSP_Q_TXQ_COAL_INTERRUPT 0x00000058
+#define DMA_SEC_DMA_SSP_Q_TXQ_COAL_INTERRUPT_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_SSP_Q_TXQ_COAL_INTERRUPT_t {
+ struct {
+ unsigned int txq_eof:1; /* bits 0:0 */
+ unsigned int rsrvd1:31;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_SSP_Q_TXQ_COAL_INTENABLE 0x0000005c
+#define DMA_SEC_DMA_SSP_Q_TXQ_COAL_INTENABLE_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_SSP_Q_TXQ_COAL_INTENABLE_t {
+ struct {
+ unsigned int txq_eof_en:1; /* bits 0:0 */
+ unsigned int rsrvd1:31;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_SSP_Q_RXQ_FRAG_BUFF_ADDR0 0x00000060
+#define DMA_SEC_DMA_SSP_Q_RXQ_FRAG_BUFF_ADDR0_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_SSP_Q_RXQ_FRAG_BUFF_ADDR0_t {
+ struct {
+ unsigned int data:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_SSP_Q_RXQ_FRAG_BUFF_ADDR1 0x00000064
+#define DMA_SEC_DMA_SSP_Q_RXQ_FRAG_BUFF_ADDR1_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_SSP_Q_RXQ_FRAG_BUFF_ADDR1_t {
+ struct {
+ unsigned int data:8; /* bits 7:0 */
+ unsigned int rsrvd1:24;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_SSP_Q_RXQ_FRAG_BUFF_SIZE 0x00000068
+#define DMA_SEC_DMA_SSP_Q_RXQ_FRAG_BUFF_SIZE_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_SSP_Q_RXQ_FRAG_BUFF_SIZE_t {
+ struct {
+ unsigned int buffersize:16; /* bits 15:0 */
+ unsigned int rsrvd1:16;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_SSP_Q_TXQ_FRAG_BUFF_ADDR0 0x0000006c
+#define DMA_SEC_DMA_SSP_Q_TXQ_FRAG_BUFF_ADDR0_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_SSP_Q_TXQ_FRAG_BUFF_ADDR0_t {
+ struct {
+ unsigned int data:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_SSP_Q_TXQ_FRAG_BUFF_ADDR1 0x00000070
+#define DMA_SEC_DMA_SSP_Q_TXQ_FRAG_BUFF_ADDR1_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_SSP_Q_TXQ_FRAG_BUFF_ADDR1_t {
+ struct {
+ unsigned int data:8; /* bits 7:0 */
+ unsigned int rsrvd1:24;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_SSP_Q_TXQ_FRAG_BUFF_SIZE 0x00000074
+#define DMA_SEC_DMA_SSP_Q_TXQ_FRAG_BUFF_SIZE_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_SSP_Q_TXQ_FRAG_BUFF_SIZE_t {
+ struct {
+ unsigned int buffersize:16; /* bits 15:0 */
+ unsigned int rsrvd1:16;
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_SSP_Q_DMA_SPARE_0 0x00000078
+#define DMA_SEC_DMA_SSP_Q_DMA_SPARE_0_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_SSP_Q_DMA_SPARE_0_t {
+ struct {
+ unsigned int dma_spare0:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#define DMA_SEC_DMA_SSP_Q_DMA_SPARE_1 0x0000007c
+#define DMA_SEC_DMA_SSP_Q_DMA_SPARE_1_dft 0x00000000
+#if !defined(__ASSEMBLER__) && !defined(__ASSEMBLY__)
+union DMA_SEC_DMA_SSP_Q_DMA_SPARE_1_t {
+ struct {
+ unsigned int dma_spare1:32; /* bits 31:0 */
+ } bf;
+ unsigned int wrd;
+};
+#endif /* !__ASSEMBLER__ */
+
+#endif /* _CA_NAND_H_ */
--
2.7.4
More information about the U-Boot
mailing list