Thank you to anyone who has already donated - your generous donations helped make three months of treatment possible.
My brother Nate continues to fight stage IV Hodgkin's lymphoma. He's just 31, with a wife and baby girl. They have no active income (since he's been unable to return to work), no insurance, and cannot afford the treatment he needs. Nate and his family need your help. Please consider a donation, every dollar helps. Thanks.
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 |
diff --git a/firmware/target/arm/as3525/sd-as3525.c b/firmware/target/arm/as3525/sd-as3525.c index 19914ab..97e8dd6 100644 static int sd_transfer_sectors(IF_MD2(int drive,) unsigned long start, (9<<4) /* 2^9 = 512 */ ; /* Wakeup signal from NAND/MCIO isr on MCI_DATA_ERROR | MCI_DATA_END */ - wakeup_wait(&transfer_completion_signal, TIMEOUT_BLOCK); + int ret = wakeup_wait(&transfer_completion_signal, HZ*5); + if(ret != OBJ_WAIT_SUCCEEDED) + { + panicf("wakeup wait timeout"); + //if(!transfer_error[drive]) + } /* Wait for FIFO to empty, card may still be in PRG state for writes */ - while(MCI_STATUS(drive) & MCI_TX_ACTIVE); + int txloops = 100000; + while(--txloops && MCI_STATUS(drive) & MCI_TX_ACTIVE) + ; + if(txloops == 0) + { + panicf("TX wait too long"); + } last_disk_activity = current_tick; |