Skip to content

Commit

Permalink
mtd: mxc_nand: compress ID info for send_read_id_v3
Browse files Browse the repository at this point in the history
Also compress the id in case of a v3 NAND flash controller (i.mx51, i.mx53)
and 16Bit buswidth.

Signed-off-by: Roman Schneider <schneider@at.festo.com>
Signed-off-by: Artem Bityutskiy <artem.bityutskiy@linux.intel.com>
  • Loading branch information
Roman Schneider authored and Artem Bityutskiy committed Feb 4, 2013
1 parent 972e1b7 commit a8459f2
Showing 1 changed file with 11 additions and 0 deletions.
11 changes: 11 additions & 0 deletions drivers/mtd/nand/mxc_nand.c
Original file line number Diff line number Diff line change
Expand Up @@ -530,12 +530,23 @@ static void send_page_v1(struct mtd_info *mtd, unsigned int ops)

static void send_read_id_v3(struct mxc_nand_host *host)
{
struct nand_chip *this = &host->nand;

/* Read ID into main buffer */
writel(NFC_ID, NFC_V3_LAUNCH);

wait_op_done(host, true);

memcpy32_fromio(host->data_buf, host->main_area0, 16);

if (this->options & NAND_BUSWIDTH_16) {
/* compress the ID info */
host->data_buf[1] = host->data_buf[2];
host->data_buf[2] = host->data_buf[4];
host->data_buf[3] = host->data_buf[6];
host->data_buf[4] = host->data_buf[8];
host->data_buf[5] = host->data_buf[10];
}
}

/* Request the NANDFC to perform a read of the NAND device ID. */
Expand Down

0 comments on commit a8459f2

Please sign in to comment.