From patchwork Mon Jun 1 21:26:49 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Alex Nemirovsky X-Patchwork-Id: 241498 List-Id: U-Boot discussion From: alex.nemirovsky at cortina-access.com (Alex Nemirovsky) Date: Mon, 1 Jun 2020 14:26:49 -0700 Subject: [PATCH v3 1/2] mtd: rawnand: ca_nand: add Cortina Access Parallel NAND controller support Message-ID: <1591046810-9232-1-git-send-email-alex.nemirovsky@cortina-access.com> From: Jason Li 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 Signed-off-by: Alex Nemirovsky CC: Miquel Raynal CC: Simon Glass CC: Tom Rini --- 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 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 +#include +#include +#include +#include +#ifdef CONFIG_MTD_PARTITIONS +#include +#endif + +#include +#include +#include +#include "ca_nand.h" + +#ifdef CONFIG_JFFS2_NAND +#include +#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 + * + * 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_ */ From patchwork Mon Jun 1 21:26:50 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Alex Nemirovsky X-Patchwork-Id: 241497 List-Id: U-Boot discussion From: alex.nemirovsky at cortina-access.com (Alex Nemirovsky) Date: Mon, 1 Jun 2020 14:26:50 -0700 Subject: [PATCH v3 2/2] board: presidio-asic: Add RAW Parallel NAND support In-Reply-To: <1591046810-9232-1-git-send-email-alex.nemirovsky@cortina-access.com> References: <1591046810-9232-1-git-send-email-alex.nemirovsky@cortina-access.com> Message-ID: <1591046810-9232-2-git-send-email-alex.nemirovsky@cortina-access.com> Add Parallel NAND CAxxxx support to Cortina Access Presidio Engineering Board support Signed-off-by: Alex Nemirovsky CC: Miquel Raynal CC: Simon Glass --- Changes in v3: None Changes in v2: None configs/cortina_presidio-asic-bch16_defconfig | 35 ++++++++++++++++++++++++++ configs/cortina_presidio-asic-bch24_defconfig | 36 +++++++++++++++++++++++++++ configs/cortina_presidio-asic-bch40_defconfig | 36 +++++++++++++++++++++++++++ configs/cortina_presidio-asic-bch8_defconfig | 36 +++++++++++++++++++++++++++ include/configs/presidio_asic.h | 15 +++++++++++ 5 files changed, 158 insertions(+) create mode 100644 configs/cortina_presidio-asic-bch16_defconfig create mode 100644 configs/cortina_presidio-asic-bch24_defconfig create mode 100644 configs/cortina_presidio-asic-bch40_defconfig create mode 100644 configs/cortina_presidio-asic-bch8_defconfig diff --git a/configs/cortina_presidio-asic-bch16_defconfig b/configs/cortina_presidio-asic-bch16_defconfig new file mode 100644 index 0000000..57ef98f --- /dev/null +++ b/configs/cortina_presidio-asic-bch16_defconfig @@ -0,0 +1,35 @@ +CONFIG_ARM=y +# CONFIG_SYS_ARCH_TIMER is not set +CONFIG_TARGET_PRESIDIO_ASIC=y +CONFIG_SYS_TEXT_BASE=0x04000000 +CONFIG_ENV_SIZE=0x20000 +CONFIG_ENV_OFFSET=0x400000 +CONFIG_DM_GPIO=y +CONFIG_NR_DRAM_BANKS=1 +CONFIG_IDENT_STRING="Presidio-SoC" +CONFIG_SHOW_BOOT_PROGRESS=y +CONFIG_BOOTDELAY=3 +CONFIG_BOARD_EARLY_INIT_R=y +CONFIG_SYS_PROMPT="G3#" +CONFIG_CMD_NAND=y +CONFIG_CMD_WDT=y +CONFIG_CMD_CACHE=y +CONFIG_CMD_TIMER=y +CONFIG_CMD_SMC=y +CONFIG_CMD_MTDPARTS=y +CONFIG_CMD_UBI=y +CONFIG_OF_CONTROL=y +CONFIG_OF_LIVE=y +CONFIG_DEFAULT_DEVICE_TREE="ca-presidio-engboard" +CONFIG_ENV_IS_IN_NAND=y +# CONFIG_NET is not set +CONFIG_DM=y +CONFIG_CORTINA_GPIO=y +# CONFIG_MMC is not set +CONFIG_MTD=y +CONFIG_MTD_RAW_NAND=y +CONFIG_NAND_CORTINA=y +CONFIG_DM_SERIAL=y +CONFIG_CORTINA_UART=y +CONFIG_WDT=y +CONFIG_WDT_CORTINA=y diff --git a/configs/cortina_presidio-asic-bch24_defconfig b/configs/cortina_presidio-asic-bch24_defconfig new file mode 100644 index 0000000..d22eae7 --- /dev/null +++ b/configs/cortina_presidio-asic-bch24_defconfig @@ -0,0 +1,36 @@ +CONFIG_ARM=y +# CONFIG_SYS_ARCH_TIMER is not set +CONFIG_TARGET_PRESIDIO_ASIC=y +CONFIG_SYS_TEXT_BASE=0x04000000 +CONFIG_ENV_SIZE=0x20000 +CONFIG_ENV_OFFSET=0x400000 +CONFIG_DM_GPIO=y +CONFIG_NR_DRAM_BANKS=1 +CONFIG_IDENT_STRING="Presidio-SoC" +CONFIG_SHOW_BOOT_PROGRESS=y +CONFIG_BOOTDELAY=3 +CONFIG_BOARD_EARLY_INIT_R=y +CONFIG_SYS_PROMPT="G3#" +CONFIG_CMD_NAND=y +CONFIG_CMD_WDT=y +CONFIG_CMD_CACHE=y +CONFIG_CMD_TIMER=y +CONFIG_CMD_SMC=y +CONFIG_CMD_MTDPARTS=y +CONFIG_CMD_UBI=y +CONFIG_OF_CONTROL=y +CONFIG_OF_LIVE=y +CONFIG_DEFAULT_DEVICE_TREE="ca-presidio-engboard" +CONFIG_ENV_IS_IN_NAND=y +# CONFIG_NET is not set +CONFIG_DM=y +CONFIG_CORTINA_GPIO=y +# CONFIG_MMC is not set +CONFIG_MTD=y +CONFIG_MTD_RAW_NAND=y +CONFIG_NAND_CORTINA=y +CONFIG_NAND_CORTINA_ECC_LEVEL=4 +CONFIG_DM_SERIAL=y +CONFIG_CORTINA_UART=y +CONFIG_WDT=y +CONFIG_WDT_CORTINA=y diff --git a/configs/cortina_presidio-asic-bch40_defconfig b/configs/cortina_presidio-asic-bch40_defconfig new file mode 100644 index 0000000..3c39415 --- /dev/null +++ b/configs/cortina_presidio-asic-bch40_defconfig @@ -0,0 +1,36 @@ +CONFIG_ARM=y +# CONFIG_SYS_ARCH_TIMER is not set +CONFIG_TARGET_PRESIDIO_ASIC=y +CONFIG_SYS_TEXT_BASE=0x04000000 +CONFIG_ENV_SIZE=0x20000 +CONFIG_ENV_OFFSET=0x400000 +CONFIG_DM_GPIO=y +CONFIG_NR_DRAM_BANKS=1 +CONFIG_IDENT_STRING="Presidio-SoC" +CONFIG_SHOW_BOOT_PROGRESS=y +CONFIG_BOOTDELAY=3 +CONFIG_BOARD_EARLY_INIT_R=y +CONFIG_SYS_PROMPT="G3#" +CONFIG_CMD_NAND=y +CONFIG_CMD_WDT=y +CONFIG_CMD_CACHE=y +CONFIG_CMD_TIMER=y +CONFIG_CMD_SMC=y +CONFIG_CMD_MTDPARTS=y +CONFIG_CMD_UBI=y +CONFIG_OF_CONTROL=y +CONFIG_OF_LIVE=y +CONFIG_DEFAULT_DEVICE_TREE="ca-presidio-engboard" +CONFIG_ENV_IS_IN_NAND=y +# CONFIG_NET is not set +CONFIG_DM=y +CONFIG_CORTINA_GPIO=y +# CONFIG_MMC is not set +CONFIG_MTD=y +CONFIG_MTD_RAW_NAND=y +CONFIG_NAND_CORTINA=y +CONFIG_NAND_CORTINA_ECC_LEVEL=5 +CONFIG_DM_SERIAL=y +CONFIG_CORTINA_UART=y +CONFIG_WDT=y +CONFIG_WDT_CORTINA=y diff --git a/configs/cortina_presidio-asic-bch8_defconfig b/configs/cortina_presidio-asic-bch8_defconfig new file mode 100644 index 0000000..8cda753 --- /dev/null +++ b/configs/cortina_presidio-asic-bch8_defconfig @@ -0,0 +1,36 @@ +CONFIG_ARM=y +# CONFIG_SYS_ARCH_TIMER is not set +CONFIG_TARGET_PRESIDIO_ASIC=y +CONFIG_SYS_TEXT_BASE=0x04000000 +CONFIG_ENV_SIZE=0x20000 +CONFIG_ENV_OFFSET=0x400000 +CONFIG_DM_GPIO=y +CONFIG_NR_DRAM_BANKS=1 +CONFIG_IDENT_STRING="Presidio-SoC" +CONFIG_SHOW_BOOT_PROGRESS=y +CONFIG_BOOTDELAY=3 +CONFIG_BOARD_EARLY_INIT_R=y +CONFIG_SYS_PROMPT="G3#" +CONFIG_CMD_NAND=y +CONFIG_CMD_WDT=y +CONFIG_CMD_CACHE=y +CONFIG_CMD_TIMER=y +CONFIG_CMD_SMC=y +CONFIG_CMD_MTDPARTS=y +CONFIG_CMD_UBI=y +CONFIG_OF_CONTROL=y +CONFIG_OF_LIVE=y +CONFIG_DEFAULT_DEVICE_TREE="ca-presidio-engboard" +CONFIG_ENV_IS_IN_NAND=y +# CONFIG_NET is not set +CONFIG_DM=y +CONFIG_CORTINA_GPIO=y +# CONFIG_MMC is not set +CONFIG_MTD=y +CONFIG_MTD_RAW_NAND=y +CONFIG_NAND_CORTINA=y +CONFIG_NAND_CORTINA_ECC_LEVEL=2 +CONFIG_DM_SERIAL=y +CONFIG_CORTINA_UART=y +CONFIG_WDT=y +CONFIG_WDT_CORTINA=y diff --git a/include/configs/presidio_asic.h b/include/configs/presidio_asic.h index 51177f4..3e5030f 100644 --- a/include/configs/presidio_asic.h +++ b/include/configs/presidio_asic.h @@ -32,6 +32,8 @@ #define CONFIG_SYS_TIMER_BASE 0xf4321000 +#define GLOBAL_SOFTWARE2 0xf43200c4 + /* Use external clock source */ #define PRESIDIO_APB_CLK 125000000 #define CORTINA_PER_IO_FREQ PRESIDIO_APB_CLK @@ -68,4 +70,17 @@ #define CONFIG_SYS_MAXARGS 64 #define CONFIG_EXTRA_ENV_SETTINGS "silent=y\0" +/* Macros for Flash */ +#define CORTINA_FLASH_CTRL_BASE 0xf4324000 +#define CORTINA_DMA_GLB_BASE 0xf7001000 +#define CORTINA_DMA_SSP_BASE 0xf7001a00 +#define CONFIG_SYS_FLASH_BASE 0xe0000000 + +#ifdef CONFIG_NAND_CORTINA + #define CONFIG_SYS_MAX_NAND_DEVICE 1 + #define CONFIG_SYS_NAND_MAX_CHIPS 1 + #define CONFIG_SYS_NAND_BASE CONFIG_SYS_FLASH_BASE + #define CONFIG_SYS_NAND_BASE_LIST { CONFIG_SYS_NAND_BASE } +#endif + #endif /* __PRESIDIO_ASIC_H */