blob: 7fa56970c1046e1c0333e06cb698424eb5acb8d3 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
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);
|