summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRafaël Carré <rafael.carre@gmail.com>2010-05-14 21:41:29 +0000
committerRafaël Carré <rafael.carre@gmail.com>2010-05-14 21:41:29 +0000
commit84b7747069bae8849111c2d8dd3c69c182b7ec38 (patch)
tree7167fd9109c34768a77563d7e50d9b027f589b40
parente72d2daad8061f5f9c5806d571e8317b2bb0f7ae (diff)
as3525v1: detect correctly internal storage capacity
check if SD transfers fit with the card capacity git-svn-id: svn://svn.rockbox.org/rockbox/trunk@26029 a1c6a512-1295-4272-9138-f99709370657
-rw-r--r--firmware/target/arm/as3525/sd-as3525.c25
1 files changed, 25 insertions, 0 deletions
diff --git a/firmware/target/arm/as3525/sd-as3525.c b/firmware/target/arm/as3525/sd-as3525.c
index 9c3ff0b5fe..0cdc56f2c6 100644
--- a/firmware/target/arm/as3525/sd-as3525.c
+++ b/firmware/target/arm/as3525/sd-as3525.c
@@ -374,6 +374,25 @@ static int sd_init_card(const int drive)
const int ret = sd_select_bank(-1);
if(ret < 0)
return ret -16;
+
+ /* CMD7 w/rca = 0: Select card to put it in STBY state */
+ if(!send_cmd(drive, SD_SELECT_CARD, 0, MCI_ARG, NULL))
+ return -17;
+ mci_delay();
+
+ /* CMD9 send CSD again, so we got the correct number of blocks */
+ if(!send_cmd(drive, SD_SEND_CSD, card_info[drive].rca,
+ MCI_RESP|MCI_LONG_RESP|MCI_ARG, card_info[drive].csd))
+ return -18;
+
+ sd_parse_csd(&card_info[drive]);
+ /* The OF is stored in the first blocks */
+ card_info[INTERNAL_AS3525].numblocks -= AMS_OF_SIZE;
+
+ /* CMD7 w/rca: Select card to put it in TRAN state */
+ if(!send_cmd(drive, SD_SELECT_CARD, card_info[drive].rca, MCI_ARG, NULL))
+ return -19;
+ mci_delay();
}
card_info[drive].initialized = 1;
@@ -667,6 +686,12 @@ static int sd_transfer_sectors(IF_MD2(int drive,) unsigned long start,
goto sd_transfer_error;
}
+ if((start+count) > card_info[drive].numblocks)
+ {
+ ret = -20;
+ goto sd_transfer_error;
+ }
+
last_disk_activity = current_tick;
dma_retain();