Lines Matching +full:nand +full:- +full:ecc +full:- +full:engine
1 // SPDX-License-Identifier: GPL-2.0
3 * Marvell NAND flash controller driver
6 * Author: Miquel RAYNAL <miquel.raynal@free-electrons.com>
9 * This NAND controller driver handles two versions of the hardware,
13 * The main visible difference is that NFCv1 only has Hamming ECC
14 * capabilities, while NFCv2 also embeds a BCH ECC engine. Also, DMA
17 * The ECC layouts are depicted in details in Marvell AN-379, but here
21 * or 4) and each chunk will have its own ECC "digest" of 6B at the
23 * bytes (also called "spare" bytes in the driver). This engine
28 * +-------------------------------------------------------------+
29 * | Data 1 | ... | Data N | ECC 1 | ... | ECCN | Free OOB bytes |
30 * +-------------------------------------------------------------+
32 * When using the BCH engine, there are N identical (data + free OOB +
33 * ECC) sections and potentially an extra one to deal with
34 * configurations where the chosen (data + free OOB + ECC) sizes do
35 * not align with the page (data + OOB) size. ECC bytes are always
36 * 30B per ECC chunk. Here is the page layout used by the controller
39 * +-----------------------------------------
40 * | Data 1 | Free OOB bytes 1 | ECC 1 | ...
41 * +-----------------------------------------
43 * -------------------------------------------
44 * ... | Data N | Free OOB bytes N | ECC N |
45 * -------------------------------------------
47 * --------------------------------------------+
48 * Last Data | Last Free OOB bytes | Last ECC |
49 * --------------------------------------------+
52 * first, then all free OOB bytes and finally all ECC bytes. With BCH,
53 * ECC bytes are 30B long and are padded with 0xFF to align on 32
58 * - It can only read 2k at a time. To overcome this limitation, the
61 * - The ECC strength in BCH mode cannot be tuned. It is fixed 16
62 * bits. What can be tuned is the ECC block size as long as it
64 * chip ECC requirements. For instance, using 2kiB ECC chunks
66 * - The controller will always treat data bytes, free OOB bytes
67 * and ECC bytes in that order, no matter what the real layout is
71 * - Because of these weird layouts, the Bad Block Markers can be
89 #include <linux/dma-mapping.h>
90 #include <linux/dma/pxa-dma.h>
91 #include <linux/platform_data/mtd-nand-pxa3xx.h>
111 /* System control registers/bits to enable the NAND controller on some SoCs */
122 /* NAND controller data flash control register */
141 /* NAND interface timing parameter 0 register */
155 /* NAND interface timing parameter 1 register */
164 /* NAND controller status register */
171 #define NDSR_CMDD(cs) BIT(8 - cs)
175 /* NAND ECC control register */
179 /* NAND controller data buffer register */
182 /* NAND controller command buffer 0 register */
195 /* NAND controller command buffer 1 register */
200 /* NAND controller command buffer 2 register */
205 /* NAND controller command buffer 3 register */
210 /* NAND controller command buffer 0 register 'type' and 'xtype' fields */
230 * struct marvell_hw_ecc_layout - layout of Marvell ECC
232 * Marvell ECC engine works differently than the others, in order to limit the
234 * per subpage, and depending on a the desired strength needed by the NAND chip,
235 * a particular layout mixing data/spare/ecc is defined, with a possible last
239 * @chunk: Desired ECC chunk size on which the layout applies
240 * @strength: Desired ECC strength (per chunk size bytes) on which the
243 * @full_chunk_cnt: Number of full-sized chunks, which is the number of
248 * @ecc_bytes: Number of ecc bytes per chunk
251 * @last_ecc_bytes: Number of ecc bytes in the last chunk
284 /* Layouts explained in AN-379_Marvell_SoC_NFC_ECC */
297 * struct marvell_nand_chip_sel - CS line description
299 * The Nand Flash Controller has up to 4 CE and 2 RB pins. The CE selection
319 * struct marvell_nand_chip - stores NAND chip device related information
321 * @chip: Base NAND chip structure
322 * @node: Used to store NAND chips into a list
323 * @layout: NAND layout when using hardware ECC
324 * @ndcr: Controller register value for this NAND chip
325 * @ndtr0: Timing registers 0 value for this NAND chip
326 * @ndtr1: Timing registers 1 value for this NAND chip
329 * @nsels: Number of CS lines required by the NAND chip
351 *nand) in to_nand_sel()
353 return &nand->sels[nand->selected_die]; in to_nand_sel()
357 * struct marvell_nfc_caps - NAND controller capabilities for distinction
363 * system controller (ie. to enable the NAND controller)
381 * struct marvell_nfc - stores Marvell NAND controller information
385 * @regs: NAND controller registers
388 * @complete: Completion object to wait for NAND controller events
390 * @chips: List containing all the NAND chips attached to
391 * this NAND controller
393 * @caps: NAND controller capabilities for each compatible string
396 * @dma_buf: 32-bit aligned buffer for DMA transfers (NFCv1 only)
422 * struct marvell_nfc_timings - NAND controller timings expressed in NAND
456 * @ps: Duration in pico-seconds
457 * @period_ns: Clock period in nano-seconds
459 * Convert the duration in nano-seconds, then divide by the period and
467 * struct marvell_nfc_op - filled during the parsing of the ->exec_op()
513 reg = readl_relaxed(nfc->regs + NDCR); in marvell_nfc_disable_int()
514 writel_relaxed(reg | int_mask, nfc->regs + NDCR); in marvell_nfc_disable_int()
522 reg = readl_relaxed(nfc->regs + NDCR); in marvell_nfc_enable_int()
523 writel_relaxed(reg & ~int_mask, nfc->regs + NDCR); in marvell_nfc_enable_int()
530 reg = readl_relaxed(nfc->regs + NDSR); in marvell_nfc_clear_int()
531 writel_relaxed(int_mask, nfc->regs + NDSR); in marvell_nfc_clear_int()
539 struct marvell_nfc *nfc = to_marvell_nfc(chip->controller); in marvell_nfc_force_byte_access()
543 * Callers of this function do not verify if the NAND is using a 16-bit in marvell_nfc_force_byte_access()
544 * an 8-bit bus for normal operations, so we need to take care of that in marvell_nfc_force_byte_access()
545 * here by leaving the configuration unchanged if the NAND does not have in marvell_nfc_force_byte_access()
548 if (!(chip->options & NAND_BUSWIDTH_16)) in marvell_nfc_force_byte_access()
551 ndcr = readl_relaxed(nfc->regs + NDCR); in marvell_nfc_force_byte_access()
558 writel_relaxed(ndcr, nfc->regs + NDCR); in marvell_nfc_force_byte_access()
563 struct marvell_nfc *nfc = to_marvell_nfc(chip->controller); in marvell_nfc_wait_ndrun()
571 ret = readl_relaxed_poll_timeout(nfc->regs + NDCR, val, in marvell_nfc_wait_ndrun()
575 dev_err(nfc->dev, "Timeout on NAND controller run mode\n"); in marvell_nfc_wait_ndrun()
576 writel_relaxed(readl(nfc->regs + NDCR) & ~NDCR_ND_RUN, in marvell_nfc_wait_ndrun()
577 nfc->regs + NDCR); in marvell_nfc_wait_ndrun()
587 * - call marvell_nfc_prepare_cmd()
588 * -> activate the ND_RUN bit that will kind of 'start a job'
589 * -> wait the signal indicating the NFC is waiting for a command
590 * - send the command (cmd and address cycles)
591 * - enventually send or receive the data
592 * - call marvell_nfc_end_cmd() with the corresponding flag
593 * -> wait the flag to be triggered or cancel the job with a timeout
596 * specialized functions responsible for executing the actual NAND
601 struct marvell_nfc *nfc = to_marvell_nfc(chip->controller); in marvell_nfc_prepare_cmd()
608 dev_err(nfc->dev, "Last operation did not succeed\n"); in marvell_nfc_prepare_cmd()
612 ndcr = readl_relaxed(nfc->regs + NDCR); in marvell_nfc_prepare_cmd()
613 writel_relaxed(readl(nfc->regs + NDSR), nfc->regs + NDSR); in marvell_nfc_prepare_cmd()
616 writel_relaxed(ndcr | NDCR_ND_RUN, nfc->regs + NDCR); in marvell_nfc_prepare_cmd()
617 ret = readl_relaxed_poll_timeout(nfc->regs + NDSR, val, in marvell_nfc_prepare_cmd()
621 dev_err(nfc->dev, "Timeout on WRCMDRE\n"); in marvell_nfc_prepare_cmd()
622 return -ETIMEDOUT; in marvell_nfc_prepare_cmd()
626 writel_relaxed(NDSR_WRCMDREQ, nfc->regs + NDSR); in marvell_nfc_prepare_cmd()
635 struct marvell_nfc *nfc = to_marvell_nfc(chip->controller); in marvell_nfc_send_cmd()
637 dev_dbg(nfc->dev, "\nNDCR: 0x%08x\n" in marvell_nfc_send_cmd()
639 (u32)readl_relaxed(nfc->regs + NDCR), nfc_op->ndcb[0], in marvell_nfc_send_cmd()
640 nfc_op->ndcb[1], nfc_op->ndcb[2], nfc_op->ndcb[3]); in marvell_nfc_send_cmd()
642 writel_relaxed(to_nand_sel(marvell_nand)->ndcb0_csel | nfc_op->ndcb[0], in marvell_nfc_send_cmd()
643 nfc->regs + NDCB0); in marvell_nfc_send_cmd()
644 writel_relaxed(nfc_op->ndcb[1], nfc->regs + NDCB0); in marvell_nfc_send_cmd()
645 writel(nfc_op->ndcb[2], nfc->regs + NDCB0); in marvell_nfc_send_cmd()
651 if (nfc_op->ndcb[0] & NDCB0_LEN_OVRD || in marvell_nfc_send_cmd()
652 NDCB0_ADDR_GET_NUM_CYC(nfc_op->ndcb[0]) >= 6) { in marvell_nfc_send_cmd()
653 if (!WARN_ON_ONCE(!nfc->caps->is_nfcv2)) in marvell_nfc_send_cmd()
654 writel(nfc_op->ndcb[3], nfc->regs + NDCB0); in marvell_nfc_send_cmd()
661 struct marvell_nfc *nfc = to_marvell_nfc(chip->controller); in marvell_nfc_end_cmd()
665 ret = readl_relaxed_poll_timeout(nfc->regs + NDSR, val, in marvell_nfc_end_cmd()
670 dev_err(nfc->dev, "Timeout on %s (NDSR: 0x%08x)\n", in marvell_nfc_end_cmd()
672 if (nfc->dma_chan) in marvell_nfc_end_cmd()
673 dmaengine_terminate_all(nfc->dma_chan); in marvell_nfc_end_cmd()
681 if (nfc->use_dma && (readl_relaxed(nfc->regs + NDCR) & NDCR_DMA_EN)) in marvell_nfc_end_cmd()
684 writel_relaxed(flag, nfc->regs + NDSR); in marvell_nfc_end_cmd()
692 int cs_flag = NDSR_CMDD(to_nand_sel(marvell_nand)->ndcb0_csel); in marvell_nfc_wait_cmdd()
705 st = readl_relaxed(nfc->regs + NDSR); in marvell_nfc_poll_status()
715 return -ETIMEDOUT; in marvell_nfc_poll_status()
720 struct marvell_nfc *nfc = to_marvell_nfc(chip->controller); in marvell_nfc_wait_op()
729 if (mtd->oops_panic_write) { in marvell_nfc_wait_op()
734 init_completion(&nfc->complete); in marvell_nfc_wait_op()
737 ret = wait_for_completion_timeout(&nfc->complete, in marvell_nfc_wait_op()
748 dev_err(nfc->dev, "Timeout waiting for RB signal\n"); in marvell_nfc_wait_op()
749 return -ETIMEDOUT; in marvell_nfc_wait_op()
759 struct marvell_nfc *nfc = to_marvell_nfc(chip->controller); in marvell_nfc_select_target()
766 ndcr_generic = readl_relaxed(nfc->regs + NDCR) & in marvell_nfc_select_target()
768 writel_relaxed(ndcr_generic | marvell_nand->ndcr, nfc->regs + NDCR); in marvell_nfc_select_target()
773 if (chip == nfc->selected_chip && die_nr == marvell_nand->selected_die) in marvell_nfc_select_target()
776 writel_relaxed(marvell_nand->ndtr0, nfc->regs + NDTR0); in marvell_nfc_select_target()
777 writel_relaxed(marvell_nand->ndtr1, nfc->regs + NDTR1); in marvell_nfc_select_target()
779 nfc->selected_chip = chip; in marvell_nfc_select_target()
780 marvell_nand->selected_die = die_nr; in marvell_nfc_select_target()
786 u32 st = readl_relaxed(nfc->regs + NDSR); in marvell_nfc_isr()
787 u32 ien = (~readl_relaxed(nfc->regs + NDCR)) & NDCR_ALL_INT; in marvell_nfc_isr()
802 complete(&nfc->complete); in marvell_nfc_isr()
807 /* HW ECC related functions */
810 struct marvell_nfc *nfc = to_marvell_nfc(chip->controller); in marvell_nfc_enable_hw_ecc()
811 u32 ndcr = readl_relaxed(nfc->regs + NDCR); in marvell_nfc_enable_hw_ecc()
814 writel_relaxed(ndcr | NDCR_ECC_EN, nfc->regs + NDCR); in marvell_nfc_enable_hw_ecc()
820 if (chip->ecc.algo == NAND_ECC_ALGO_BCH) in marvell_nfc_enable_hw_ecc()
821 writel_relaxed(NDECCCTRL_BCH_EN, nfc->regs + NDECCCTRL); in marvell_nfc_enable_hw_ecc()
827 struct marvell_nfc *nfc = to_marvell_nfc(chip->controller); in marvell_nfc_disable_hw_ecc()
828 u32 ndcr = readl_relaxed(nfc->regs + NDCR); in marvell_nfc_disable_hw_ecc()
831 writel_relaxed(ndcr & ~NDCR_ECC_EN, nfc->regs + NDCR); in marvell_nfc_disable_hw_ecc()
832 if (chip->ecc.algo == NAND_ECC_ALGO_BCH) in marvell_nfc_disable_hw_ecc()
833 writel_relaxed(0, nfc->regs + NDECCCTRL); in marvell_nfc_disable_hw_ecc()
842 reg = readl_relaxed(nfc->regs + NDCR); in marvell_nfc_enable_dma()
843 writel_relaxed(reg | NDCR_DMA_EN, nfc->regs + NDCR); in marvell_nfc_enable_dma()
850 reg = readl_relaxed(nfc->regs + NDCR); in marvell_nfc_disable_dma()
851 writel_relaxed(reg & ~NDCR_DMA_EN, nfc->regs + NDCR); in marvell_nfc_disable_dma()
867 sg_init_one(&sg, nfc->dma_buf, dma_len); in marvell_nfc_xfer_data_dma()
868 dma_map_sg(nfc->dma_chan->device->dev, &sg, 1, direction); in marvell_nfc_xfer_data_dma()
869 tx = dmaengine_prep_slave_sg(nfc->dma_chan, &sg, 1, in marvell_nfc_xfer_data_dma()
874 dev_err(nfc->dev, "Could not prepare DMA S/G list\n"); in marvell_nfc_xfer_data_dma()
875 return -ENXIO; in marvell_nfc_xfer_data_dma()
882 return -EIO; in marvell_nfc_xfer_data_dma()
884 dma_async_issue_pending(nfc->dma_chan); in marvell_nfc_xfer_data_dma()
885 ret = marvell_nfc_wait_cmdd(nfc->selected_chip); in marvell_nfc_xfer_data_dma()
886 dma_unmap_sg(nfc->dma_chan->device->dev, &sg, 1, direction); in marvell_nfc_xfer_data_dma()
889 dev_err(nfc->dev, "Timeout waiting for DMA (status: %d)\n", in marvell_nfc_xfer_data_dma()
890 dmaengine_tx_status(nfc->dma_chan, cookie, NULL)); in marvell_nfc_xfer_data_dma()
891 dmaengine_terminate_all(nfc->dma_chan); in marvell_nfc_xfer_data_dma()
892 return -ETIMEDOUT; in marvell_nfc_xfer_data_dma()
906 ioread32_rep(nfc->regs + NDDB, in + i, FIFO_REP(FIFO_DEPTH)); in marvell_nfc_xfer_data_in_pio()
911 ioread32_rep(nfc->regs + NDDB, tmp_buf, FIFO_REP(FIFO_DEPTH)); in marvell_nfc_xfer_data_in_pio()
926 iowrite32_rep(nfc->regs + NDDB, out + i, FIFO_REP(FIFO_DEPTH)); in marvell_nfc_xfer_data_out_pio()
932 iowrite32_rep(nfc->regs + NDDB, tmp_buf, FIFO_REP(FIFO_DEPTH)); in marvell_nfc_xfer_data_out_pio()
941 u8 *ecc, int ecc_len, in marvell_nfc_check_empty_chunk() argument
950 * check if the entire page (with ECC bytes) is actually blank or not. in marvell_nfc_check_empty_chunk()
956 if (!ecc) in marvell_nfc_check_empty_chunk()
959 bf = nand_check_erased_ecc_chunk(data, data_len, ecc, ecc_len, in marvell_nfc_check_empty_chunk()
960 spare, spare_len, chip->ecc.strength); in marvell_nfc_check_empty_chunk()
962 mtd->ecc_stats.failed++; in marvell_nfc_check_empty_chunk()
967 mtd->ecc_stats.corrected += bf; in marvell_nfc_check_empty_chunk()
972 * Check if a chunk is correct or not according to the hardware ECC engine.
973 * mtd->ecc_stats.corrected is updated, as well as max_bitflips, however
974 * mtd->ecc_stats.failure is not, the function will instead return a non-zero
982 struct marvell_nfc *nfc = to_marvell_nfc(chip->controller); in marvell_nfc_hw_ecc_check_bitflips()
986 ndsr = readl_relaxed(nfc->regs + NDSR); in marvell_nfc_hw_ecc_check_bitflips()
990 writel_relaxed(ndsr, nfc->regs + NDSR); in marvell_nfc_hw_ecc_check_bitflips()
993 * Do not increment ->ecc_stats.failed now, instead, return a in marvell_nfc_hw_ecc_check_bitflips()
994 * non-zero value to indicate that this chunk was apparently in marvell_nfc_hw_ecc_check_bitflips()
996 * the chunk (with ECC bytes) is not declared empty, the calling in marvell_nfc_hw_ecc_check_bitflips()
999 return -EBADMSG; in marvell_nfc_hw_ecc_check_bitflips()
1004 writel_relaxed(ndsr, nfc->regs + NDSR); in marvell_nfc_hw_ecc_check_bitflips()
1006 if (chip->ecc.algo == NAND_ECC_ALGO_BCH) in marvell_nfc_hw_ecc_check_bitflips()
1013 mtd->ecc_stats.corrected += bf; in marvell_nfc_hw_ecc_check_bitflips()
1025 struct marvell_nfc *nfc = to_marvell_nfc(chip->controller); in marvell_nfc_hw_ecc_hmg_do_read_page()
1026 const struct marvell_hw_ecc_layout *lt = to_marvell_nand(chip)->layout; in marvell_nfc_hw_ecc_hmg_do_read_page()
1029 NDCB0_ADDR_CYC(marvell_nand->addr_cyc) | in marvell_nfc_hw_ecc_hmg_do_read_page()
1036 unsigned int oob_bytes = lt->spare_bytes + (raw ? lt->ecc_bytes : 0); in marvell_nfc_hw_ecc_hmg_do_read_page()
1040 if (nfc->caps->is_nfcv2) in marvell_nfc_hw_ecc_hmg_do_read_page()
1055 * documentation, spare bytes are protected by the ECC engine, and must in marvell_nfc_hw_ecc_hmg_do_read_page()
1059 if (nfc->use_dma) { in marvell_nfc_hw_ecc_hmg_do_read_page()
1061 lt->data_bytes + oob_bytes); in marvell_nfc_hw_ecc_hmg_do_read_page()
1062 memcpy(data_buf, nfc->dma_buf, lt->data_bytes); in marvell_nfc_hw_ecc_hmg_do_read_page()
1063 memcpy(oob_buf, nfc->dma_buf + lt->data_bytes, oob_bytes); in marvell_nfc_hw_ecc_hmg_do_read_page()
1065 marvell_nfc_xfer_data_in_pio(nfc, data_buf, lt->data_bytes); in marvell_nfc_hw_ecc_hmg_do_read_page()
1076 marvell_nfc_select_target(chip, chip->cur_cs); in marvell_nfc_hw_ecc_hmg_read_page_raw()
1077 return marvell_nfc_hw_ecc_hmg_do_read_page(chip, buf, chip->oob_poi, in marvell_nfc_hw_ecc_hmg_read_page_raw()
1084 const struct marvell_hw_ecc_layout *lt = to_marvell_nand(chip)->layout; in marvell_nfc_hw_ecc_hmg_read_page()
1085 unsigned int full_sz = lt->data_bytes + lt->spare_bytes + lt->ecc_bytes; in marvell_nfc_hw_ecc_hmg_read_page()
1089 marvell_nfc_select_target(chip, chip->cur_cs); in marvell_nfc_hw_ecc_hmg_read_page()
1091 marvell_nfc_hw_ecc_hmg_do_read_page(chip, buf, chip->oob_poi, false, in marvell_nfc_hw_ecc_hmg_read_page()
1100 * When ECC failures are detected, check if the full page has been in marvell_nfc_hw_ecc_hmg_read_page()
1105 return -ENOMEM; in marvell_nfc_hw_ecc_hmg_read_page()
1108 lt->data_bytes, true, page); in marvell_nfc_hw_ecc_hmg_read_page()
1117 * Spare area in Hamming layouts is not protected by the ECC engine (even if
1118 * it appears before the ECC bytes when reading), the ->read_oob_raw() function
1119 * also stands for ->read_oob().
1125 marvell_nfc_select_target(chip, chip->cur_cs); in marvell_nfc_hw_ecc_hmg_read_oob_raw()
1126 return marvell_nfc_hw_ecc_hmg_do_read_page(chip, buf, chip->oob_poi, in marvell_nfc_hw_ecc_hmg_read_oob_raw()
1139 struct marvell_nfc *nfc = to_marvell_nfc(chip->controller); in marvell_nfc_hw_ecc_hmg_do_write_page()
1140 const struct marvell_hw_ecc_layout *lt = to_marvell_nand(chip)->layout; in marvell_nfc_hw_ecc_hmg_do_write_page()
1143 NDCB0_ADDR_CYC(marvell_nand->addr_cyc) | in marvell_nfc_hw_ecc_hmg_do_write_page()
1150 unsigned int oob_bytes = lt->spare_bytes + (raw ? lt->ecc_bytes : 0); in marvell_nfc_hw_ecc_hmg_do_write_page()
1154 if (nfc->caps->is_nfcv2) in marvell_nfc_hw_ecc_hmg_do_write_page()
1168 if (nfc->use_dma) { in marvell_nfc_hw_ecc_hmg_do_write_page()
1169 memcpy(nfc->dma_buf, data_buf, lt->data_bytes); in marvell_nfc_hw_ecc_hmg_do_write_page()
1170 memcpy(nfc->dma_buf + lt->data_bytes, oob_buf, oob_bytes); in marvell_nfc_hw_ecc_hmg_do_write_page()
1171 marvell_nfc_xfer_data_dma(nfc, DMA_TO_DEVICE, lt->data_bytes + in marvell_nfc_hw_ecc_hmg_do_write_page()
1172 lt->ecc_bytes + lt->spare_bytes); in marvell_nfc_hw_ecc_hmg_do_write_page()
1174 marvell_nfc_xfer_data_out_pio(nfc, data_buf, lt->data_bytes); in marvell_nfc_hw_ecc_hmg_do_write_page()
1183 PSEC_TO_MSEC(sdr->tPROG_max)); in marvell_nfc_hw_ecc_hmg_do_write_page()
1191 marvell_nfc_select_target(chip, chip->cur_cs); in marvell_nfc_hw_ecc_hmg_write_page_raw()
1192 return marvell_nfc_hw_ecc_hmg_do_write_page(chip, buf, chip->oob_poi, in marvell_nfc_hw_ecc_hmg_write_page_raw()
1202 marvell_nfc_select_target(chip, chip->cur_cs); in marvell_nfc_hw_ecc_hmg_write_page()
1204 ret = marvell_nfc_hw_ecc_hmg_do_write_page(chip, buf, chip->oob_poi, in marvell_nfc_hw_ecc_hmg_write_page()
1212 * Spare area in Hamming layouts is not protected by the ECC engine (even if
1213 * it appears before the ECC bytes when reading), the ->write_oob_raw() function
1214 * also stands for ->write_oob().
1222 memset(buf, 0xFF, mtd->writesize); in marvell_nfc_hw_ecc_hmg_write_oob_raw()
1224 marvell_nfc_select_target(chip, chip->cur_cs); in marvell_nfc_hw_ecc_hmg_write_oob_raw()
1225 return marvell_nfc_hw_ecc_hmg_do_write_page(chip, buf, chip->oob_poi, in marvell_nfc_hw_ecc_hmg_write_oob_raw()
1234 const struct marvell_hw_ecc_layout *lt = to_marvell_nand(chip)->layout; in marvell_nfc_hw_ecc_bch_read_page_raw()
1235 u8 *oob = chip->oob_poi; in marvell_nfc_hw_ecc_bch_read_page_raw()
1236 int chunk_size = lt->data_bytes + lt->spare_bytes + lt->ecc_bytes; in marvell_nfc_hw_ecc_bch_read_page_raw()
1237 int ecc_offset = (lt->full_chunk_cnt * lt->spare_bytes) + in marvell_nfc_hw_ecc_bch_read_page_raw()
1238 lt->last_spare_bytes; in marvell_nfc_hw_ecc_bch_read_page_raw()
1239 int data_len = lt->data_bytes; in marvell_nfc_hw_ecc_bch_read_page_raw()
1240 int spare_len = lt->spare_bytes; in marvell_nfc_hw_ecc_bch_read_page_raw()
1241 int ecc_len = lt->ecc_bytes; in marvell_nfc_hw_ecc_bch_read_page_raw()
1244 marvell_nfc_select_target(chip, chip->cur_cs); in marvell_nfc_hw_ecc_bch_read_page_raw()
1247 memset(chip->oob_poi, 0xFF, mtd->oobsize); in marvell_nfc_hw_ecc_bch_read_page_raw()
1251 for (chunk = 0; chunk < lt->nchunks; chunk++) { in marvell_nfc_hw_ecc_bch_read_page_raw()
1253 if (chunk >= lt->full_chunk_cnt) { in marvell_nfc_hw_ecc_bch_read_page_raw()
1254 data_len = lt->last_data_bytes; in marvell_nfc_hw_ecc_bch_read_page_raw()
1255 spare_len = lt->last_spare_bytes; in marvell_nfc_hw_ecc_bch_read_page_raw()
1256 ecc_len = lt->last_ecc_bytes; in marvell_nfc_hw_ecc_bch_read_page_raw()
1261 buf + (lt->data_bytes * chunk), in marvell_nfc_hw_ecc_bch_read_page_raw()
1265 nand_read_data_op(chip, oob + (lt->spare_bytes * chunk), in marvell_nfc_hw_ecc_bch_read_page_raw()
1268 /* Read ECC bytes */ in marvell_nfc_hw_ecc_bch_read_page_raw()
1270 (ALIGN(lt->ecc_bytes, 32) * chunk), in marvell_nfc_hw_ecc_bch_read_page_raw()
1283 struct marvell_nfc *nfc = to_marvell_nfc(chip->controller); in marvell_nfc_hw_ecc_bch_read_chunk()
1284 const struct marvell_hw_ecc_layout *lt = to_marvell_nand(chip)->layout; in marvell_nfc_hw_ecc_bch_read_chunk()
1288 NDCB0_ADDR_CYC(marvell_nand->addr_cyc) | in marvell_nfc_hw_ecc_bch_read_chunk()
1310 else if (chunk < lt->nchunks - 1) in marvell_nfc_hw_ecc_bch_read_chunk()
1322 * Drain the FIFO, 8 32-bit reads at a time, and skip in marvell_nfc_hw_ecc_bch_read_chunk()
1349 const struct marvell_hw_ecc_layout *lt = to_marvell_nand(chip)->layout; in marvell_nfc_hw_ecc_bch_read_page()
1350 int data_len = lt->data_bytes, spare_len = lt->spare_bytes; in marvell_nfc_hw_ecc_bch_read_page()
1351 u8 *data = buf, *spare = chip->oob_poi; in marvell_nfc_hw_ecc_bch_read_page()
1356 marvell_nfc_select_target(chip, chip->cur_cs); in marvell_nfc_hw_ecc_bch_read_page()
1364 memset(chip->oob_poi, 0xFF, mtd->oobsize); in marvell_nfc_hw_ecc_bch_read_page()
1368 for (chunk = 0; chunk < lt->nchunks; chunk++) { in marvell_nfc_hw_ecc_bch_read_page()
1370 if (chunk >= lt->full_chunk_cnt) { in marvell_nfc_hw_ecc_bch_read_page()
1371 data_len = lt->last_data_bytes; in marvell_nfc_hw_ecc_bch_read_page()
1372 spare_len = lt->last_spare_bytes; in marvell_nfc_hw_ecc_bch_read_page()
1392 * Please note that dumping the ECC bytes during a normal read with OOB in marvell_nfc_hw_ecc_bch_read_page()
1393 * area would add a significant overhead as ECC bytes are "consumed" by in marvell_nfc_hw_ecc_bch_read_page()
1394 * the controller in normal mode and must be re-read in raw mode. To in marvell_nfc_hw_ecc_bch_read_page()
1396 * user should re-read the page in raw mode if ECC bytes are required. in marvell_nfc_hw_ecc_bch_read_page()
1400 * In case there is any subpage read error, we usually re-read only ECC in marvell_nfc_hw_ecc_bch_read_page()
1402 * it is normal that the ECC check failed and we just ignore the error. in marvell_nfc_hw_ecc_bch_read_page()
1407 * this strange behavior, the whole page is re-read in raw mode, not in marvell_nfc_hw_ecc_bch_read_page()
1408 * only the ECC bytes. in marvell_nfc_hw_ecc_bch_read_page()
1410 for (chunk = 0; chunk < lt->nchunks; chunk++) { in marvell_nfc_hw_ecc_bch_read_page()
1419 data_off_in_page = chunk * (lt->data_bytes + lt->spare_bytes + in marvell_nfc_hw_ecc_bch_read_page()
1420 lt->ecc_bytes); in marvell_nfc_hw_ecc_bch_read_page()
1422 (chunk < lt->full_chunk_cnt ? lt->data_bytes : in marvell_nfc_hw_ecc_bch_read_page()
1423 lt->last_data_bytes); in marvell_nfc_hw_ecc_bch_read_page()
1425 (chunk < lt->full_chunk_cnt ? lt->spare_bytes : in marvell_nfc_hw_ecc_bch_read_page()
1426 lt->last_spare_bytes); in marvell_nfc_hw_ecc_bch_read_page()
1428 data_off = chunk * lt->data_bytes; in marvell_nfc_hw_ecc_bch_read_page()
1429 spare_off = chunk * lt->spare_bytes; in marvell_nfc_hw_ecc_bch_read_page()
1430 ecc_off = (lt->full_chunk_cnt * lt->spare_bytes) + in marvell_nfc_hw_ecc_bch_read_page()
1431 lt->last_spare_bytes + in marvell_nfc_hw_ecc_bch_read_page()
1432 (chunk * (lt->ecc_bytes + 2)); in marvell_nfc_hw_ecc_bch_read_page()
1434 data_len = chunk < lt->full_chunk_cnt ? lt->data_bytes : in marvell_nfc_hw_ecc_bch_read_page()
1435 lt->last_data_bytes; in marvell_nfc_hw_ecc_bch_read_page()
1436 spare_len = chunk < lt->full_chunk_cnt ? lt->spare_bytes : in marvell_nfc_hw_ecc_bch_read_page()
1437 lt->last_spare_bytes; in marvell_nfc_hw_ecc_bch_read_page()
1438 ecc_len = chunk < lt->full_chunk_cnt ? lt->ecc_bytes : in marvell_nfc_hw_ecc_bch_read_page()
1439 lt->last_ecc_bytes; in marvell_nfc_hw_ecc_bch_read_page()
1442 * Only re-read the ECC bytes, unless we are using the 2k/8b in marvell_nfc_hw_ecc_bch_read_page()
1443 * layout which is buggy in the sense that the ECC engine will in marvell_nfc_hw_ecc_bch_read_page()
1445 * case, re-read the entire page. in marvell_nfc_hw_ecc_bch_read_page()
1447 if (lt->writesize == 2048 && lt->strength == 8) { in marvell_nfc_hw_ecc_bch_read_page()
1452 chip->oob_poi + spare_off, spare_len, in marvell_nfc_hw_ecc_bch_read_page()
1457 chip->oob_poi + ecc_off, ecc_len, in marvell_nfc_hw_ecc_bch_read_page()
1460 /* Check the entire chunk (data + spare + ecc) for emptyness */ in marvell_nfc_hw_ecc_bch_read_page()
1462 chip->oob_poi + spare_off, spare_len, in marvell_nfc_hw_ecc_bch_read_page()
1463 chip->oob_poi + ecc_off, ecc_len, in marvell_nfc_hw_ecc_bch_read_page()
1474 return chip->ecc.read_page_raw(chip, buf, true, page); in marvell_nfc_hw_ecc_bch_read_oob_raw()
1481 return chip->ecc.read_page(chip, buf, true, page); in marvell_nfc_hw_ecc_bch_read_oob()
1489 const struct marvell_hw_ecc_layout *lt = to_marvell_nand(chip)->layout; in marvell_nfc_hw_ecc_bch_write_page_raw()
1490 int full_chunk_size = lt->data_bytes + lt->spare_bytes + lt->ecc_bytes; in marvell_nfc_hw_ecc_bch_write_page_raw()
1491 int data_len = lt->data_bytes; in marvell_nfc_hw_ecc_bch_write_page_raw()
1492 int spare_len = lt->spare_bytes; in marvell_nfc_hw_ecc_bch_write_page_raw()
1493 int ecc_len = lt->ecc_bytes; in marvell_nfc_hw_ecc_bch_write_page_raw()
1495 int ecc_offset = (lt->full_chunk_cnt * lt->spare_bytes) + in marvell_nfc_hw_ecc_bch_write_page_raw()
1496 lt->last_spare_bytes; in marvell_nfc_hw_ecc_bch_write_page_raw()
1499 marvell_nfc_select_target(chip, chip->cur_cs); in marvell_nfc_hw_ecc_bch_write_page_raw()
1503 for (chunk = 0; chunk < lt->nchunks; chunk++) { in marvell_nfc_hw_ecc_bch_write_page_raw()
1504 if (chunk >= lt->full_chunk_cnt) { in marvell_nfc_hw_ecc_bch_write_page_raw()
1505 data_len = lt->last_data_bytes; in marvell_nfc_hw_ecc_bch_write_page_raw()
1506 spare_len = lt->last_spare_bytes; in marvell_nfc_hw_ecc_bch_write_page_raw()
1507 ecc_len = lt->last_ecc_bytes; in marvell_nfc_hw_ecc_bch_write_page_raw()
1515 nand_write_data_op(chip, buf + (chunk * lt->data_bytes), in marvell_nfc_hw_ecc_bch_write_page_raw()
1523 nand_write_data_op(chip, chip->oob_poi + spare_offset, in marvell_nfc_hw_ecc_bch_write_page_raw()
1526 /* Write the ECC bytes */ in marvell_nfc_hw_ecc_bch_write_page_raw()
1528 nand_write_data_op(chip, chip->oob_poi + ecc_offset, in marvell_nfc_hw_ecc_bch_write_page_raw()
1545 struct marvell_nfc *nfc = to_marvell_nfc(chip->controller); in marvell_nfc_hw_ecc_bch_write_chunk()
1546 const struct marvell_hw_ecc_layout *lt = to_marvell_nand(chip)->layout; in marvell_nfc_hw_ecc_bch_write_chunk()
1563 if (lt->nchunks == 1) in marvell_nfc_hw_ecc_bch_write_chunk()
1569 NDCB0_ADDR_CYC(marvell_nand->addr_cyc) | in marvell_nfc_hw_ecc_bch_write_chunk()
1573 } else if (chunk < lt->nchunks - 1) { in marvell_nfc_hw_ecc_bch_write_chunk()
1580 if (chunk == lt->nchunks - 1) in marvell_nfc_hw_ecc_bch_write_chunk()
1594 iowrite32_rep(nfc->regs + NDDB, data, FIFO_REP(data_len)); in marvell_nfc_hw_ecc_bch_write_chunk()
1595 iowrite32_rep(nfc->regs + NDDB, spare, FIFO_REP(spare_len)); in marvell_nfc_hw_ecc_bch_write_chunk()
1607 const struct marvell_hw_ecc_layout *lt = to_marvell_nand(chip)->layout; in marvell_nfc_hw_ecc_bch_write_page()
1609 const u8 *spare = chip->oob_poi; in marvell_nfc_hw_ecc_bch_write_page()
1610 int data_len = lt->data_bytes; in marvell_nfc_hw_ecc_bch_write_page()
1611 int spare_len = lt->spare_bytes; in marvell_nfc_hw_ecc_bch_write_page()
1614 marvell_nfc_select_target(chip, chip->cur_cs); in marvell_nfc_hw_ecc_bch_write_page()
1618 memset(chip->oob_poi, 0xFF, mtd->oobsize); in marvell_nfc_hw_ecc_bch_write_page()
1622 for (chunk = 0; chunk < lt->nchunks; chunk++) { in marvell_nfc_hw_ecc_bch_write_page()
1623 if (chunk >= lt->full_chunk_cnt) { in marvell_nfc_hw_ecc_bch_write_page()
1624 data_len = lt->last_data_bytes; in marvell_nfc_hw_ecc_bch_write_page()
1625 spare_len = lt->last_spare_bytes; in marvell_nfc_hw_ecc_bch_write_page()
1634 * Waiting only for CMDD or PAGED is not enough, ECC are in marvell_nfc_hw_ecc_bch_write_page()
1642 ret = marvell_nfc_wait_op(chip, PSEC_TO_MSEC(sdr->tPROG_max)); in marvell_nfc_hw_ecc_bch_write_page()
1658 memset(buf, 0xFF, mtd->writesize); in marvell_nfc_hw_ecc_bch_write_oob_raw()
1660 return chip->ecc.write_page_raw(chip, buf, true, page); in marvell_nfc_hw_ecc_bch_write_oob_raw()
1668 memset(buf, 0xFF, mtd->writesize); in marvell_nfc_hw_ecc_bch_write_oob()
1670 return chip->ecc.write_page(chip, buf, true, page); in marvell_nfc_hw_ecc_bch_write_oob()
1673 /* NAND framework ->exec_op() hooks and related helpers */
1679 struct marvell_nfc *nfc = to_marvell_nfc(chip->controller); in marvell_nfc_parse_instructions()
1687 for (op_id = 0; op_id < subop->ninstrs; op_id++) { in marvell_nfc_parse_instructions()
1692 instr = &subop->instrs[op_id]; in marvell_nfc_parse_instructions()
1694 switch (instr->type) { in marvell_nfc_parse_instructions()
1697 nfc_op->ndcb[0] |= in marvell_nfc_parse_instructions()
1698 NDCB0_CMD1(instr->ctx.cmd.opcode); in marvell_nfc_parse_instructions()
1700 nfc_op->ndcb[0] |= in marvell_nfc_parse_instructions()
1701 NDCB0_CMD2(instr->ctx.cmd.opcode) | in marvell_nfc_parse_instructions()
1704 nfc_op->cle_ale_delay_ns = instr->delay_ns; in marvell_nfc_parse_instructions()
1711 addrs = &instr->ctx.addr.addrs[offset]; in marvell_nfc_parse_instructions()
1713 nfc_op->ndcb[0] |= NDCB0_ADDR_CYC(naddrs); in marvell_nfc_parse_instructions()
1716 nfc_op->ndcb[1] |= addrs[i] << (8 * i); in marvell_nfc_parse_instructions()
1719 nfc_op->ndcb[2] |= NDCB2_ADDR5_CYC(addrs[4]); in marvell_nfc_parse_instructions()
1721 nfc_op->ndcb[3] |= NDCB3_ADDR6_CYC(addrs[5]); in marvell_nfc_parse_instructions()
1723 nfc_op->ndcb[3] |= NDCB3_ADDR7_CYC(addrs[6]); in marvell_nfc_parse_instructions()
1725 nfc_op->cle_ale_delay_ns = instr->delay_ns; in marvell_nfc_parse_instructions()
1729 nfc_op->data_instr = instr; in marvell_nfc_parse_instructions()
1730 nfc_op->data_instr_idx = op_id; in marvell_nfc_parse_instructions()
1731 nfc_op->ndcb[0] |= NDCB0_CMD_TYPE(TYPE_READ); in marvell_nfc_parse_instructions()
1732 if (nfc->caps->is_nfcv2) { in marvell_nfc_parse_instructions()
1733 nfc_op->ndcb[0] |= in marvell_nfc_parse_instructions()
1737 nfc_op->ndcb[3] |= round_up(len, FIFO_DEPTH); in marvell_nfc_parse_instructions()
1739 nfc_op->data_delay_ns = instr->delay_ns; in marvell_nfc_parse_instructions()
1743 nfc_op->data_instr = instr; in marvell_nfc_parse_instructions()
1744 nfc_op->data_instr_idx = op_id; in marvell_nfc_parse_instructions()
1745 nfc_op->ndcb[0] |= NDCB0_CMD_TYPE(TYPE_WRITE); in marvell_nfc_parse_instructions()
1746 if (nfc->caps->is_nfcv2) { in marvell_nfc_parse_instructions()
1747 nfc_op->ndcb[0] |= in marvell_nfc_parse_instructions()
1751 nfc_op->ndcb[3] |= round_up(len, FIFO_DEPTH); in marvell_nfc_parse_instructions()
1753 nfc_op->data_delay_ns = instr->delay_ns; in marvell_nfc_parse_instructions()
1757 nfc_op->rdy_timeout_ms = instr->ctx.waitrdy.timeout_ms; in marvell_nfc_parse_instructions()
1758 nfc_op->rdy_delay_ns = instr->delay_ns; in marvell_nfc_parse_instructions()
1768 struct marvell_nfc *nfc = to_marvell_nfc(chip->controller); in marvell_nfc_xfer_data_pio()
1769 const struct nand_op_instr *instr = nfc_op->data_instr; in marvell_nfc_xfer_data_pio()
1770 unsigned int op_id = nfc_op->data_instr_idx; in marvell_nfc_xfer_data_pio()
1773 bool reading = (instr->type == NAND_OP_DATA_IN_INSTR); in marvell_nfc_xfer_data_pio()
1776 if (instr->ctx.data.force_8bit) in marvell_nfc_xfer_data_pio()
1780 u8 *in = instr->ctx.data.buf.in + offset; in marvell_nfc_xfer_data_pio()
1784 const u8 *out = instr->ctx.data.buf.out + offset; in marvell_nfc_xfer_data_pio()
1789 if (instr->ctx.data.force_8bit) in marvell_nfc_xfer_data_pio()
1803 reading = (nfc_op.data_instr->type == NAND_OP_DATA_IN_INSTR); in marvell_nfc_monolithic_access_exec()
1850 struct marvell_nfc *nfc = to_marvell_nfc(chip->controller); in marvell_nfc_monolithic_access_exec()
1852 writel_relaxed(readl(nfc->regs + NDCR) & ~NDCR_ND_RUN, in marvell_nfc_monolithic_access_exec()
1853 nfc->regs + NDCR); in marvell_nfc_monolithic_access_exec()
1874 switch (subop->instrs[0].type) { in marvell_nfc_naked_access_exec()
1921 if (subop->instrs[0].type == NAND_OP_DATA_OUT_INSTR) { in marvell_nfc_naked_access_exec()
1922 struct marvell_nfc *nfc = to_marvell_nfc(chip->controller); in marvell_nfc_naked_access_exec()
1924 writel_relaxed(readl(nfc->regs + NDCR) & ~NDCR_ND_RUN, in marvell_nfc_naked_access_exec()
1925 nfc->regs + NDCR); in marvell_nfc_naked_access_exec()
2147 struct marvell_nfc *nfc = to_marvell_nfc(chip->controller); in marvell_nfc_exec_op()
2150 marvell_nfc_select_target(chip, op->cs); in marvell_nfc_exec_op()
2152 if (nfc->caps->is_nfcv2) in marvell_nfc_exec_op()
2168 const struct marvell_hw_ecc_layout *lt = to_marvell_nand(chip)->layout; in marvell_nand_ooblayout_ecc()
2171 return -ERANGE; in marvell_nand_ooblayout_ecc()
2173 oobregion->length = (lt->full_chunk_cnt * lt->ecc_bytes) + in marvell_nand_ooblayout_ecc()
2174 lt->last_ecc_bytes; in marvell_nand_ooblayout_ecc()
2175 oobregion->offset = mtd->oobsize - oobregion->length; in marvell_nand_ooblayout_ecc()
2184 const struct marvell_hw_ecc_layout *lt = to_marvell_nand(chip)->layout; in marvell_nand_ooblayout_free()
2187 return -ERANGE; in marvell_nand_ooblayout_free()
2193 if (mtd->writesize == SZ_4K && lt->data_bytes == SZ_2K) in marvell_nand_ooblayout_free()
2194 oobregion->offset = 6; in marvell_nand_ooblayout_free()
2196 oobregion->offset = 2; in marvell_nand_ooblayout_free()
2198 oobregion->length = (lt->full_chunk_cnt * lt->spare_bytes) + in marvell_nand_ooblayout_free()
2199 lt->last_spare_bytes - oobregion->offset; in marvell_nand_ooblayout_free()
2205 .ecc = marvell_nand_ooblayout_ecc,
2210 struct nand_ecc_ctrl *ecc) in marvell_nand_hw_ecc_controller_init() argument
2213 struct marvell_nfc *nfc = to_marvell_nfc(chip->controller); in marvell_nand_hw_ecc_controller_init()
2217 if (!nfc->caps->is_nfcv2 && in marvell_nand_hw_ecc_controller_init()
2218 (mtd->writesize + mtd->oobsize > MAX_CHUNK_SIZE)) { in marvell_nand_hw_ecc_controller_init()
2219 dev_err(nfc->dev, in marvell_nand_hw_ecc_controller_init()
2221 mtd->writesize, MAX_CHUNK_SIZE - mtd->oobsize); in marvell_nand_hw_ecc_controller_init()
2222 return -ENOTSUPP; in marvell_nand_hw_ecc_controller_init()
2225 to_marvell_nand(chip)->layout = NULL; in marvell_nand_hw_ecc_controller_init()
2228 if (mtd->writesize == l->writesize && in marvell_nand_hw_ecc_controller_init()
2229 ecc->size == l->chunk && ecc->strength == l->strength) { in marvell_nand_hw_ecc_controller_init()
2230 to_marvell_nand(chip)->layout = l; in marvell_nand_hw_ecc_controller_init()
2235 if (!to_marvell_nand(chip)->layout || in marvell_nand_hw_ecc_controller_init()
2236 (!nfc->caps->is_nfcv2 && ecc->strength > 1)) { in marvell_nand_hw_ecc_controller_init()
2237 dev_err(nfc->dev, in marvell_nand_hw_ecc_controller_init()
2238 "ECC strength %d at page size %d is not supported\n", in marvell_nand_hw_ecc_controller_init()
2239 ecc->strength, mtd->writesize); in marvell_nand_hw_ecc_controller_init()
2240 return -ENOTSUPP; in marvell_nand_hw_ecc_controller_init()
2243 /* Special care for the layout 2k/8-bit/512B */ in marvell_nand_hw_ecc_controller_init()
2244 if (l->writesize == 2048 && l->strength == 8) { in marvell_nand_hw_ecc_controller_init()
2245 if (mtd->oobsize < 128) { in marvell_nand_hw_ecc_controller_init()
2246 dev_err(nfc->dev, "Requested layout needs at least 128 OOB bytes\n"); in marvell_nand_hw_ecc_controller_init()
2247 return -ENOTSUPP; in marvell_nand_hw_ecc_controller_init()
2249 chip->bbt_options |= NAND_BBT_NO_OOB_BBM; in marvell_nand_hw_ecc_controller_init()
2254 ecc->steps = l->nchunks; in marvell_nand_hw_ecc_controller_init()
2255 ecc->size = l->data_bytes; in marvell_nand_hw_ecc_controller_init()
2257 if (ecc->strength == 1) { in marvell_nand_hw_ecc_controller_init()
2258 chip->ecc.algo = NAND_ECC_ALGO_HAMMING; in marvell_nand_hw_ecc_controller_init()
2259 ecc->read_page_raw = marvell_nfc_hw_ecc_hmg_read_page_raw; in marvell_nand_hw_ecc_controller_init()
2260 ecc->read_page = marvell_nfc_hw_ecc_hmg_read_page; in marvell_nand_hw_ecc_controller_init()
2261 ecc->read_oob_raw = marvell_nfc_hw_ecc_hmg_read_oob_raw; in marvell_nand_hw_ecc_controller_init()
2262 ecc->read_oob = ecc->read_oob_raw; in marvell_nand_hw_ecc_controller_init()
2263 ecc->write_page_raw = marvell_nfc_hw_ecc_hmg_write_page_raw; in marvell_nand_hw_ecc_controller_init()
2264 ecc->write_page = marvell_nfc_hw_ecc_hmg_write_page; in marvell_nand_hw_ecc_controller_init()
2265 ecc->write_oob_raw = marvell_nfc_hw_ecc_hmg_write_oob_raw; in marvell_nand_hw_ecc_controller_init()
2266 ecc->write_oob = ecc->write_oob_raw; in marvell_nand_hw_ecc_controller_init()
2268 chip->ecc.algo = NAND_ECC_ALGO_BCH; in marvell_nand_hw_ecc_controller_init()
2269 ecc->strength = 16; in marvell_nand_hw_ecc_controller_init()
2270 ecc->read_page_raw = marvell_nfc_hw_ecc_bch_read_page_raw; in marvell_nand_hw_ecc_controller_init()
2271 ecc->read_page = marvell_nfc_hw_ecc_bch_read_page; in marvell_nand_hw_ecc_controller_init()
2272 ecc->read_oob_raw = marvell_nfc_hw_ecc_bch_read_oob_raw; in marvell_nand_hw_ecc_controller_init()
2273 ecc->read_oob = marvell_nfc_hw_ecc_bch_read_oob; in marvell_nand_hw_ecc_controller_init()
2274 ecc->write_page_raw = marvell_nfc_hw_ecc_bch_write_page_raw; in marvell_nand_hw_ecc_controller_init()
2275 ecc->write_page = marvell_nfc_hw_ecc_bch_write_page; in marvell_nand_hw_ecc_controller_init()
2276 ecc->write_oob_raw = marvell_nfc_hw_ecc_bch_write_oob_raw; in marvell_nand_hw_ecc_controller_init()
2277 ecc->write_oob = marvell_nfc_hw_ecc_bch_write_oob; in marvell_nand_hw_ecc_controller_init()
2284 struct nand_ecc_ctrl *ecc) in marvell_nand_ecc_init() argument
2288 nanddev_get_ecc_requirements(&chip->base); in marvell_nand_ecc_init()
2289 struct marvell_nfc *nfc = to_marvell_nfc(chip->controller); in marvell_nand_ecc_init()
2292 if (ecc->engine_type != NAND_ECC_ENGINE_TYPE_NONE && in marvell_nand_ecc_init()
2293 (!ecc->size || !ecc->strength)) { in marvell_nand_ecc_init()
2294 if (requirements->step_size && requirements->strength) { in marvell_nand_ecc_init()
2295 ecc->size = requirements->step_size; in marvell_nand_ecc_init()
2296 ecc->strength = requirements->strength; in marvell_nand_ecc_init()
2298 dev_info(nfc->dev, in marvell_nand_ecc_init()
2299 "No minimum ECC strength, using 1b/512B\n"); in marvell_nand_ecc_init()
2300 ecc->size = 512; in marvell_nand_ecc_init()
2301 ecc->strength = 1; in marvell_nand_ecc_init()
2305 switch (ecc->engine_type) { in marvell_nand_ecc_init()
2307 ret = marvell_nand_hw_ecc_controller_init(mtd, ecc); in marvell_nand_ecc_init()
2314 if (!nfc->caps->is_nfcv2 && mtd->writesize != SZ_512 && in marvell_nand_ecc_init()
2315 mtd->writesize != SZ_2K) { in marvell_nand_ecc_init()
2316 dev_err(nfc->dev, "NFCv1 cannot write %d bytes pages\n", in marvell_nand_ecc_init()
2317 mtd->writesize); in marvell_nand_ecc_init()
2318 return -EINVAL; in marvell_nand_ecc_init()
2322 return -EINVAL; in marvell_nand_ecc_init()
2355 struct marvell_nfc *nfc = to_marvell_nfc(chip->controller); in marvell_nfc_setup_interface()
2356 unsigned int period_ns = 1000000000 / clk_get_rate(nfc->core_clk) * 2; in marvell_nfc_setup_interface()
2366 * SDR timings are given in pico-seconds while NFC timings must be in marvell_nfc_setup_interface()
2367 * expressed in NAND controller clock cycles, which is half of the in marvell_nfc_setup_interface()
2368 * frequency of the accessible ECC clock retrieved by clk_get_rate(). in marvell_nfc_setup_interface()
2376 nfc_tmg.tRP = TO_CYCLES(DIV_ROUND_UP(sdr->tRC_min, 2), period_ns) - 1; in marvell_nfc_setup_interface()
2378 nfc_tmg.tWP = TO_CYCLES(DIV_ROUND_UP(sdr->tWC_min, 2), period_ns) - 1; in marvell_nfc_setup_interface()
2380 nfc_tmg.tCS = TO_CYCLES(sdr->tCS_min, period_ns); in marvell_nfc_setup_interface()
2381 nfc_tmg.tCH = TO_CYCLES(sdr->tCH_min, period_ns) - 1; in marvell_nfc_setup_interface()
2382 nfc_tmg.tADL = TO_CYCLES(sdr->tADL_min, period_ns); in marvell_nfc_setup_interface()
2385 * logic. With non-EDO timings, this is MIN_RD_DEL_CNT clock cycles. In in marvell_nfc_setup_interface()
2389 read_delay = sdr->tRC_min >= 30000 ? in marvell_nfc_setup_interface()
2392 nfc_tmg.tAR = TO_CYCLES(sdr->tAR_min, period_ns); in marvell_nfc_setup_interface()
2398 nfc_tmg.tWHR = TO_CYCLES(max_t(int, sdr->tWHR_min, sdr->tCCS_min), in marvell_nfc_setup_interface()
2399 period_ns) - 2, in marvell_nfc_setup_interface()
2400 nfc_tmg.tRHW = TO_CYCLES(max_t(int, sdr->tRHW_min, sdr->tCCS_min), in marvell_nfc_setup_interface()
2407 if (nfc->caps->is_nfcv2) { in marvell_nfc_setup_interface()
2408 nfc_tmg.tR = TO_CYCLES(sdr->tWB_max, period_ns); in marvell_nfc_setup_interface()
2410 nfc_tmg.tR = TO_CYCLES64(sdr->tWB_max + sdr->tR_max, in marvell_nfc_setup_interface()
2413 nfc_tmg.tR = nfc_tmg.tCH - 3; in marvell_nfc_setup_interface()
2421 marvell_nand->ndtr0 = in marvell_nfc_setup_interface()
2430 marvell_nand->ndtr1 = in marvell_nfc_setup_interface()
2435 if (nfc->caps->is_nfcv2) { in marvell_nfc_setup_interface()
2436 marvell_nand->ndtr0 |= in marvell_nfc_setup_interface()
2441 marvell_nand->ndtr1 |= in marvell_nfc_setup_interface()
2453 struct marvell_nfc *nfc = to_marvell_nfc(chip->controller); in marvell_nand_attach_chip()
2454 struct pxa3xx_nand_platform_data *pdata = dev_get_platdata(nfc->dev); in marvell_nand_attach_chip()
2457 if (pdata && pdata->flash_bbt) in marvell_nand_attach_chip()
2458 chip->bbt_options |= NAND_BBT_USE_FLASH; in marvell_nand_attach_chip()
2460 if (chip->bbt_options & NAND_BBT_USE_FLASH) { in marvell_nand_attach_chip()
2462 * We'll use a bad block table stored in-flash and don't in marvell_nand_attach_chip()
2465 chip->bbt_options |= NAND_BBT_NO_OOB_BBM; in marvell_nand_attach_chip()
2466 chip->bbt_td = &bbt_main_descr; in marvell_nand_attach_chip()
2467 chip->bbt_md = &bbt_mirror_descr; in marvell_nand_attach_chip()
2470 /* Save the chip-specific fields of NDCR */ in marvell_nand_attach_chip()
2471 marvell_nand->ndcr = NDCR_PAGE_SZ(mtd->writesize); in marvell_nand_attach_chip()
2472 if (chip->options & NAND_BUSWIDTH_16) in marvell_nand_attach_chip()
2473 marvell_nand->ndcr |= NDCR_DWIDTH_M | NDCR_DWIDTH_C; in marvell_nand_attach_chip()
2479 if (mtd->writesize <= 512) { in marvell_nand_attach_chip()
2480 marvell_nand->addr_cyc = 1; in marvell_nand_attach_chip()
2482 marvell_nand->addr_cyc = 2; in marvell_nand_attach_chip()
2483 marvell_nand->ndcr |= NDCR_RA_START; in marvell_nand_attach_chip()
2494 if (chip->options & NAND_ROW_ADDR_3) in marvell_nand_attach_chip()
2495 marvell_nand->addr_cyc += 3; in marvell_nand_attach_chip()
2497 marvell_nand->addr_cyc += 2; in marvell_nand_attach_chip()
2500 chip->ecc.size = pdata->ecc_step_size; in marvell_nand_attach_chip()
2501 chip->ecc.strength = pdata->ecc_strength; in marvell_nand_attach_chip()
2504 ret = marvell_nand_ecc_init(mtd, &chip->ecc); in marvell_nand_attach_chip()
2506 dev_err(nfc->dev, "ECC init failed: %d\n", ret); in marvell_nand_attach_chip()
2510 if (chip->ecc.engine_type == NAND_ECC_ENGINE_TYPE_ON_HOST) { in marvell_nand_attach_chip()
2512 * Subpage write not available with hardware ECC, prohibit also in marvell_nand_attach_chip()
2515 * uncorrectable ECC errors. in marvell_nand_attach_chip()
2517 chip->options |= NAND_NO_SUBPAGE_WRITE; in marvell_nand_attach_chip()
2520 if (pdata || nfc->caps->legacy_of_bindings) { in marvell_nand_attach_chip()
2526 mtd->name = "pxa3xx_nand-0"; in marvell_nand_attach_chip()
2527 } else if (!mtd->name) { in marvell_nand_attach_chip()
2531 * should define the following property in your NAND node, ie: in marvell_nand_attach_chip()
2533 * label = "main-storage"; in marvell_nand_attach_chip()
2535 * This way, mtd->name will be set by the core when in marvell_nand_attach_chip()
2538 mtd->name = devm_kasprintf(nfc->dev, GFP_KERNEL, in marvell_nand_attach_chip()
2539 "%s:nand.%d", dev_name(nfc->dev), in marvell_nand_attach_chip()
2540 marvell_nand->sels[0].cs); in marvell_nand_attach_chip()
2541 if (!mtd->name) { in marvell_nand_attach_chip()
2542 dev_err(nfc->dev, "Failed to allocate mtd->name\n"); in marvell_nand_attach_chip()
2543 return -ENOMEM; in marvell_nand_attach_chip()
2567 * The legacy "num-cs" property indicates the number of CS on the only in marvell_nand_chip_init()
2571 * When not using legacy bindings, a couple of "reg" and "nand-rb" in marvell_nand_chip_init()
2573 * "reg" points to the CS lines and "nand-rb" to the RB line. in marvell_nand_chip_init()
2575 if (pdata || nfc->caps->legacy_of_bindings) { in marvell_nand_chip_init()
2581 return -EINVAL; in marvell_nand_chip_init()
2585 /* Alloc the nand chip structure */ in marvell_nand_chip_init()
2591 return -ENOMEM; in marvell_nand_chip_init()
2594 marvell_nand->nsels = nsels; in marvell_nand_chip_init()
2595 marvell_nand->selected_die = -1; in marvell_nand_chip_init()
2598 if (pdata || nfc->caps->legacy_of_bindings) { in marvell_nand_chip_init()
2614 if (cs >= nfc->caps->max_cs_nb) { in marvell_nand_chip_init()
2616 cs, nfc->caps->max_cs_nb); in marvell_nand_chip_init()
2617 return -EINVAL; in marvell_nand_chip_init()
2620 if (test_and_set_bit(cs, &nfc->assigned_cs)) { in marvell_nand_chip_init()
2622 return -EINVAL; in marvell_nand_chip_init()
2633 marvell_nand->sels[i].cs = cs; in marvell_nand_chip_init()
2637 marvell_nand->sels[i].ndcb0_csel = 0; in marvell_nand_chip_init()
2641 marvell_nand->sels[i].ndcb0_csel = NDCB0_CSEL; in marvell_nand_chip_init()
2644 return -EINVAL; in marvell_nand_chip_init()
2648 if (pdata || nfc->caps->legacy_of_bindings) { in marvell_nand_chip_init()
2652 ret = of_property_read_u32_index(np, "nand-rb", i, in marvell_nand_chip_init()
2662 if (rb >= nfc->caps->max_rb_nb) { in marvell_nand_chip_init()
2664 rb, nfc->caps->max_rb_nb); in marvell_nand_chip_init()
2665 return -EINVAL; in marvell_nand_chip_init()
2668 marvell_nand->sels[i].rb = rb; in marvell_nand_chip_init()
2671 chip = &marvell_nand->chip; in marvell_nand_chip_init()
2672 chip->controller = &nfc->controller; in marvell_nand_chip_init()
2675 if (!of_property_read_bool(np, "marvell,nand-keep-config")) in marvell_nand_chip_init()
2676 chip->options |= NAND_KEEP_TIMINGS; in marvell_nand_chip_init()
2679 mtd->dev.parent = dev; in marvell_nand_chip_init()
2682 * Default to HW ECC engine mode. If the nand-ecc-mode property is given in marvell_nand_chip_init()
2685 chip->ecc.engine_type = NAND_ECC_ENGINE_TYPE_ON_HOST; in marvell_nand_chip_init()
2689 * ->setup_interface() is called. in marvell_nand_chip_init()
2691 marvell_nand->ndtr0 = readl_relaxed(nfc->regs + NDTR0); in marvell_nand_chip_init()
2692 marvell_nand->ndtr1 = readl_relaxed(nfc->regs + NDTR1); in marvell_nand_chip_init()
2694 chip->options |= NAND_BUSWIDTH_AUTO; in marvell_nand_chip_init()
2696 ret = nand_scan(chip, marvell_nand->nsels); in marvell_nand_chip_init()
2698 dev_err(dev, "could not scan the nand chip\n"); in marvell_nand_chip_init()
2704 ret = mtd_device_register(mtd, pdata->parts, pdata->nr_parts); in marvell_nand_chip_init()
2713 list_add_tail(&marvell_nand->node, &nfc->chips); in marvell_nand_chip_init()
2724 list_for_each_entry_safe(entry, temp, &nfc->chips, node) { in marvell_nand_chips_cleanup()
2725 chip = &entry->chip; in marvell_nand_chips_cleanup()
2729 list_del(&entry->node); in marvell_nand_chips_cleanup()
2735 struct device_node *np = dev->of_node; in marvell_nand_chips_init()
2737 int max_cs = nfc->caps->max_cs_nb; in marvell_nand_chips_init()
2747 dev_err(dev, "too many NAND chips: %d (max = %d CS)\n", nchips, in marvell_nand_chips_init()
2749 return -EINVAL; in marvell_nand_chips_init()
2753 * Legacy bindings do not use child nodes to exhibit NAND chip in marvell_nand_chips_init()
2754 * properties and layout. Instead, NAND properties are mixed with the in marvell_nand_chips_init()
2756 * NAND controller node. in marvell_nand_chips_init()
2758 if (nfc->caps->legacy_of_bindings) { in marvell_nand_chips_init()
2781 struct platform_device *pdev = container_of(nfc->dev, in marvell_nfc_init_dma()
2789 dev_warn(nfc->dev, in marvell_nfc_init_dma()
2791 return -ENOTSUPP; in marvell_nfc_init_dma()
2794 ret = dma_set_mask_and_coherent(nfc->dev, DMA_BIT_MASK(32)); in marvell_nfc_init_dma()
2798 nfc->dma_chan = dma_request_chan(nfc->dev, "data"); in marvell_nfc_init_dma()
2799 if (IS_ERR(nfc->dma_chan)) { in marvell_nfc_init_dma()
2800 ret = PTR_ERR(nfc->dma_chan); in marvell_nfc_init_dma()
2801 nfc->dma_chan = NULL; in marvell_nfc_init_dma()
2802 return dev_err_probe(nfc->dev, ret, "DMA channel request failed\n"); in marvell_nfc_init_dma()
2807 ret = -ENXIO; in marvell_nfc_init_dma()
2813 config.src_addr = r->start + NDDB; in marvell_nfc_init_dma()
2814 config.dst_addr = r->start + NDDB; in marvell_nfc_init_dma()
2817 ret = dmaengine_slave_config(nfc->dma_chan, &config); in marvell_nfc_init_dma()
2819 dev_err(nfc->dev, "Failed to configure DMA channel\n"); in marvell_nfc_init_dma()
2829 nfc->dma_buf = kmalloc(MAX_CHUNK_SIZE, GFP_KERNEL | GFP_DMA); in marvell_nfc_init_dma()
2830 if (!nfc->dma_buf) { in marvell_nfc_init_dma()
2831 ret = -ENOMEM; in marvell_nfc_init_dma()
2835 nfc->use_dma = true; in marvell_nfc_init_dma()
2840 dma_release_channel(nfc->dma_chan); in marvell_nfc_init_dma()
2841 nfc->dma_chan = NULL; in marvell_nfc_init_dma()
2849 * ECC operations and interruptions are only enabled when specifically in marvell_nfc_reset()
2850 * needed. ECC shall not be activated in the early stages (fails probe). in marvell_nfc_reset()
2852 * SPARE_EN bit must always be set or ECC bytes will not be at the same in marvell_nfc_reset()
2856 NDCR_RD_ID_CNT(NFCV1_READID_LEN), nfc->regs + NDCR); in marvell_nfc_reset()
2857 writel_relaxed(0xFFFFFFFF, nfc->regs + NDSR); in marvell_nfc_reset()
2858 writel_relaxed(0, nfc->regs + NDECCCTRL); in marvell_nfc_reset()
2863 struct device_node *np = nfc->dev->of_node; in marvell_nfc_init()
2866 * Some SoCs like A7k/A8k need to enable manually the NAND in marvell_nfc_init()
2871 if (nfc->caps->need_system_controller) { in marvell_nfc_init()
2874 "marvell,system-controller"); in marvell_nfc_init()
2895 if (!nfc->caps->is_nfcv2) in marvell_nfc_init()
2905 struct device *dev = &pdev->dev; in marvell_nfc_probe()
2910 nfc = devm_kzalloc(&pdev->dev, sizeof(struct marvell_nfc), in marvell_nfc_probe()
2913 return -ENOMEM; in marvell_nfc_probe()
2915 nfc->dev = dev; in marvell_nfc_probe()
2916 nand_controller_init(&nfc->controller); in marvell_nfc_probe()
2917 nfc->controller.ops = &marvell_nand_controller_ops; in marvell_nfc_probe()
2918 INIT_LIST_HEAD(&nfc->chips); in marvell_nfc_probe()
2920 nfc->regs = devm_platform_ioremap_resource(pdev, 0); in marvell_nfc_probe()
2921 if (IS_ERR(nfc->regs)) in marvell_nfc_probe()
2922 return PTR_ERR(nfc->regs); in marvell_nfc_probe()
2928 nfc->core_clk = devm_clk_get(&pdev->dev, "core"); in marvell_nfc_probe()
2931 if (nfc->core_clk == ERR_PTR(-ENOENT)) in marvell_nfc_probe()
2932 nfc->core_clk = devm_clk_get(&pdev->dev, NULL); in marvell_nfc_probe()
2934 if (IS_ERR(nfc->core_clk)) in marvell_nfc_probe()
2935 return PTR_ERR(nfc->core_clk); in marvell_nfc_probe()
2937 ret = clk_prepare_enable(nfc->core_clk); in marvell_nfc_probe()
2941 nfc->reg_clk = devm_clk_get(&pdev->dev, "reg"); in marvell_nfc_probe()
2942 if (IS_ERR(nfc->reg_clk)) { in marvell_nfc_probe()
2943 if (PTR_ERR(nfc->reg_clk) != -ENOENT) { in marvell_nfc_probe()
2944 ret = PTR_ERR(nfc->reg_clk); in marvell_nfc_probe()
2948 nfc->reg_clk = NULL; in marvell_nfc_probe()
2951 ret = clk_prepare_enable(nfc->reg_clk); in marvell_nfc_probe()
2958 0, "marvell-nfc", nfc); in marvell_nfc_probe()
2962 /* Get NAND controller capabilities */ in marvell_nfc_probe()
2963 if (pdev->id_entry) in marvell_nfc_probe()
2964 nfc->caps = (void *)pdev->id_entry->driver_data; in marvell_nfc_probe()
2966 nfc->caps = of_device_get_match_data(&pdev->dev); in marvell_nfc_probe()
2968 if (!nfc->caps) { in marvell_nfc_probe()
2970 ret = -EINVAL; in marvell_nfc_probe()
2988 if (nfc->use_dma) in marvell_nfc_probe()
2989 dma_release_channel(nfc->dma_chan); in marvell_nfc_probe()
2991 clk_disable_unprepare(nfc->reg_clk); in marvell_nfc_probe()
2993 clk_disable_unprepare(nfc->core_clk); in marvell_nfc_probe()
3004 if (nfc->use_dma) { in marvell_nfc_remove()
3005 dmaengine_terminate_all(nfc->dma_chan); in marvell_nfc_remove()
3006 dma_release_channel(nfc->dma_chan); in marvell_nfc_remove()
3009 clk_disable_unprepare(nfc->reg_clk); in marvell_nfc_remove()
3010 clk_disable_unprepare(nfc->core_clk); in marvell_nfc_remove()
3020 list_for_each_entry(chip, &nfc->chips, node) in marvell_nfc_suspend()
3021 marvell_nfc_wait_ndrun(&chip->chip); in marvell_nfc_suspend()
3023 clk_disable_unprepare(nfc->reg_clk); in marvell_nfc_suspend()
3024 clk_disable_unprepare(nfc->core_clk); in marvell_nfc_suspend()
3034 ret = clk_prepare_enable(nfc->core_clk); in marvell_nfc_resume()
3038 ret = clk_prepare_enable(nfc->reg_clk); in marvell_nfc_resume()
3043 * Reset nfc->selected_chip so the next command will cause the timing in marvell_nfc_resume()
3046 nfc->selected_chip = NULL; in marvell_nfc_resume()
3101 .name = "pxa3xx-nand",
3110 .compatible = "marvell,armada-8k-nand-controller",
3114 .compatible = "marvell,armada370-nand-controller",
3118 .compatible = "marvell,pxa3xx-nand-controller",
3123 .compatible = "marvell,armada-8k-nand",
3127 .compatible = "marvell,armada370-nand",
3131 .compatible = "marvell,pxa3xx-nand",
3140 .name = "marvell-nfc",
3151 MODULE_DESCRIPTION("Marvell NAND controller driver");