[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