aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorEzequiel Garcia <ezequiel.garcia@free-electrons.com>2013-08-12 13:14:49 -0400
committerDavid Woodhouse <David.Woodhouse@intel.com>2013-08-30 16:34:52 -0400
commit5bb653e890ca7a5b4ba9042cb60d02f7ddef8c21 (patch)
treee6188756ec5c1856ce848beba9ca02f7a63a8c59
parentcd9d11820f4232856d6254a29fbb9c4f51a981c2 (diff)
mtd: nand: pxa3xx: Allow to set/clear the 'spare enable' field
Some commands (such as the ONFI parameter page read) need to clear the 'spare enable' bit. This commit allows to set/clear depending on the prepared command, instead of having it always set. Signed-off-by: Ezequiel Garcia <ezequiel.garcia@free-electrons.com> Tested-by: Daniel Mack <zonque@gmail.com> Signed-off-by: Brian Norris <computersforpeace@gmail.com> Signed-off-by: David Woodhouse <David.Woodhouse@intel.com>
-rw-r--r--drivers/mtd/nand/pxa3xx_nand.c7
1 files changed, 7 insertions, 0 deletions
diff --git a/drivers/mtd/nand/pxa3xx_nand.c b/drivers/mtd/nand/pxa3xx_nand.c
index 1dcda6badfdc..6e28121d3118 100644
--- a/drivers/mtd/nand/pxa3xx_nand.c
+++ b/drivers/mtd/nand/pxa3xx_nand.c
@@ -185,6 +185,7 @@ struct pxa3xx_nand_info {
185 int cs; 185 int cs;
186 int use_ecc; /* use HW ECC ? */ 186 int use_ecc; /* use HW ECC ? */
187 int use_dma; /* use DMA ? */ 187 int use_dma; /* use DMA ? */
188 int use_spare; /* use spare ? */
188 int is_ready; 189 int is_ready;
189 190
190 unsigned int page_size; /* page size of attached chip */ 191 unsigned int page_size; /* page size of attached chip */
@@ -325,6 +326,11 @@ static void pxa3xx_nand_start(struct pxa3xx_nand_info *info)
325 else 326 else
326 ndcr &= ~NDCR_DMA_EN; 327 ndcr &= ~NDCR_DMA_EN;
327 328
329 if (info->use_spare)
330 ndcr |= NDCR_SPARE_EN;
331 else
332 ndcr &= ~NDCR_SPARE_EN;
333
328 ndcr |= NDCR_ND_RUN; 334 ndcr |= NDCR_ND_RUN;
329 335
330 /* clear status bits and run */ 336 /* clear status bits and run */
@@ -526,6 +532,7 @@ static int prepare_command_pool(struct pxa3xx_nand_info *info, int command,
526 info->buf_count = 0; 532 info->buf_count = 0;
527 info->oob_size = 0; 533 info->oob_size = 0;
528 info->use_ecc = 0; 534 info->use_ecc = 0;
535 info->use_spare = 1;
529 info->use_dma = (use_dma) ? 1 : 0; 536 info->use_dma = (use_dma) ? 1 : 0;
530 info->is_ready = 0; 537 info->is_ready = 0;
531 info->retcode = ERR_NONE; 538 info->retcode = ERR_NONE;