mvebu: add a patch to deal with excessive latencies/delays during flash PIO command processing
Signed-off-by: Felix Fietkau <nbd@nbd.name>
This commit is contained in:
parent
a88fc0db9d
commit
13ea815b6c
1 changed files with 36 additions and 0 deletions
|
@ -0,0 +1,36 @@
|
|||
Handle delays/excessive latency during flash command processing with PIO.
|
||||
|
||||
Signed-off-by: Felix Fietkau <nbd@nbd.name>
|
||||
|
||||
--- a/drivers/mtd/nand/pxa3xx_nand.c
|
||||
+++ b/drivers/mtd/nand/pxa3xx_nand.c
|
||||
@@ -227,6 +227,7 @@ struct pxa3xx_nand_info {
|
||||
int use_dma; /* use DMA ? */
|
||||
int use_spare; /* use spare ? */
|
||||
int need_wait;
|
||||
+ int pio_progress;
|
||||
|
||||
/* Amount of real data per full chunk */
|
||||
unsigned int chunk_size;
|
||||
@@ -769,6 +770,7 @@ static irqreturn_t pxa3xx_nand_irq_threa
|
||||
{
|
||||
struct pxa3xx_nand_info *info = data;
|
||||
|
||||
+ info->pio_progress = 1;
|
||||
handle_data_pio(info);
|
||||
|
||||
info->state = STATE_CMD_DONE;
|
||||
@@ -1175,8 +1177,13 @@ static void nand_cmdfunc(struct mtd_info
|
||||
info->need_wait = 1;
|
||||
pxa3xx_nand_start(info);
|
||||
|
||||
+retry:
|
||||
+ info->pio_progress = 0;
|
||||
if (!wait_for_completion_timeout(&info->cmd_complete,
|
||||
CHIP_DELAY_TIMEOUT)) {
|
||||
+ if (info->pio_progress)
|
||||
+ goto retry;
|
||||
+
|
||||
dev_err(&info->pdev->dev, "Wait time out!!!\n");
|
||||
/* Stop State Machine for next command cycle */
|
||||
pxa3xx_nand_stop(info);
|
Loading…
Reference in a new issue