From cb9dff0a95cc98d83d6e1445c20bdad53614fe00 Mon Sep 17 00:00:00 2001 From: Jack Halpin Date: Tue, 24 Nov 2009 17:43:53 +0000 Subject: AMS Sansa: Include time spent yielding when figuring timeout in sd_wait_for_state(). git-svn-id: svn://svn.rockbox.org/rockbox/trunk@23738 a1c6a512-1295-4272-9138-f99709370657 --- firmware/target/arm/as3525/ata_sd_as3525.c | 12 ++++-------- 1 file changed, 4 insertions(+), 8 deletions(-) (limited to 'firmware/target/arm') diff --git a/firmware/target/arm/as3525/ata_sd_as3525.c b/firmware/target/arm/as3525/ata_sd_as3525.c index 9f2514d8ba..e71c886021 100644 --- a/firmware/target/arm/as3525/ata_sd_as3525.c +++ b/firmware/target/arm/as3525/ata_sd_as3525.c @@ -539,13 +539,10 @@ bool sd_present(IF_MD_NONVOID(int drive)) static int sd_wait_for_state(const int drive, unsigned int state) { unsigned long response = 0; - unsigned int timeout = 100; /* ticks */ - long t = current_tick; + unsigned int timeout = current_tick + 100; /* 100 ticks timeout */ while (1) { - long tick; - if(!send_cmd(drive, SD_SEND_STATUS, card_info[drive].rca, MCI_RESP|MCI_ARG, &response)) return -1; @@ -553,14 +550,13 @@ static int sd_wait_for_state(const int drive, unsigned int state) if (((response >> 9) & 0xf) == state) return 0; - if(TIME_AFTER(current_tick, t + timeout)) + if(TIME_AFTER(current_tick, timeout)) return -2; - if (TIME_AFTER((tick = current_tick), next_yield)) + if (TIME_AFTER(current_tick, next_yield)) { yield(); - timeout += current_tick - tick; - next_yield = tick + MIN_YIELD_PERIOD; + next_yield = current_tick + MIN_YIELD_PERIOD; } } } -- cgit v1.2.3