summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJens Arnold <amiconn@rockbox.org>2005-02-04 00:58:47 +0000
committerJens Arnold <amiconn@rockbox.org>2005-02-04 00:58:47 +0000
commit404fd12aae9a4691fa71c9b8053211c4b58ea825 (patch)
treec46436e3a94e2c5437b439c99e1736748413b82e
parentdd924a522d6e453d7ba7245f1c515088c22517ab (diff)
downloadrockbox-404fd12aae9a4691fa71c9b8053211c4b58ea825.tar.gz
rockbox-404fd12aae9a4691fa71c9b8053211c4b58ea825.zip
MMC driver now panics on out-of-bound accesses.
git-svn-id: svn://svn.rockbox.org/rockbox/trunk@5768 a1c6a512-1295-4272-9138-f99709370657
-rw-r--r--apps/debug_menu.c7
-rw-r--r--firmware/drivers/ata_mmc.c18
-rw-r--r--firmware/export/ata_mmc.h1
3 files changed, 16 insertions, 10 deletions
diff --git a/apps/debug_menu.c b/apps/debug_menu.c
index 0637d0ce8a..a41baf6753 100644
--- a/apps/debug_menu.c
+++ b/apps/debug_menu.c
@@ -1278,7 +1278,6 @@ bool dbg_mmc_info(void)
1278{ 1278{
1279 bool done = false; 1279 bool done = false;
1280 int currval = 0; 1280 int currval = 0;
1281 unsigned long value;
1282 tCardInfo *card; 1281 tCardInfo *card;
1283 unsigned char pbuf[32], pbuf2[32]; 1282 unsigned char pbuf[32], pbuf2[32];
1284 unsigned char card_name[7]; 1283 unsigned char card_name[7];
@@ -1322,10 +1321,8 @@ bool dbg_mmc_info(void)
1322 (int) mmc_extract_bits(card->cid, 0, 8), 1321 (int) mmc_extract_bits(card->cid, 0, 8),
1323 (int) mmc_extract_bits(card->cid, 8, 16)); 1322 (int) mmc_extract_bits(card->cid, 8, 16));
1324 lcd_puts(0, 4, pbuf); 1323 lcd_puts(0, 4, pbuf);
1325 value = mmc_extract_bits(card->csd, 54, 12) 1324 snprintf(pbuf, sizeof(pbuf), "Size: %d MB",
1326 * (SECTOR_SIZE << (mmc_extract_bits(card->csd, 78, 3)+2)); 1325 card->numsectors * SECTOR_SIZE / (1024*1024));
1327 snprintf(pbuf, sizeof(pbuf), "Size: %ld MB",
1328 value / (1024*1024));
1329 lcd_puts(0, 5, pbuf); 1326 lcd_puts(0, 5, pbuf);
1330 } 1327 }
1331 else /* Technical details */ 1328 else /* Technical details */
diff --git a/firmware/drivers/ata_mmc.c b/firmware/drivers/ata_mmc.c
index e27e693528..260418c694 100644
--- a/firmware/drivers/ata_mmc.c
+++ b/firmware/drivers/ata_mmc.c
@@ -476,6 +476,10 @@ static int initialize_card(int card_no)
476 card->r2w_factor = 1 << temp; 476 card->r2w_factor = 1 << temp;
477 card->write_timeout = card->read_timeout * card->r2w_factor; 477 card->write_timeout = card->read_timeout * card->r2w_factor;
478 478
479 /* card size */
480 card->numsectors = mmc_extract_bits(card->csd, 54, 12)
481 * (1 << (mmc_extract_bits(card->csd, 78, 3)+2));
482
479 /* switch to full speed */ 483 /* switch to full speed */
480 setup_sci1(card->bitrate_register); 484 setup_sci1(card->bitrate_register);
481 485
@@ -616,11 +620,10 @@ static int send_single_sector(const unsigned char *buf, int timeout)
616 return ret; 620 return ret;
617} 621}
618 622
619int ata_read_sectors( 623int ata_read_sectors(IF_MV2(int drive,)
620 IF_MV2(int drive,) 624 unsigned long start,
621 unsigned long start, 625 int incount,
622 int incount, 626 void* inbuf)
623 void* inbuf)
624{ 627{
625 int ret = 0; 628 int ret = 0;
626 int i; 629 int i;
@@ -639,6 +642,9 @@ int ata_read_sectors(
639 card = &card_info[current_card]; 642 card = &card_info[current_card];
640 ret = select_card(current_card); 643 ret = select_card(current_card);
641#endif 644#endif
645 if (start + incount > card->numsectors)
646 panicf("Reading past end of card\n");
647
642 if (ret == 0) 648 if (ret == 0)
643 { 649 {
644 if (incount == 1) 650 if (incount == 1)
@@ -702,6 +708,8 @@ int ata_write_sectors(IF_MV2(int drive,)
702 card = &card_info[current_card]; 708 card = &card_info[current_card];
703 ret = select_card(current_card); 709 ret = select_card(current_card);
704#endif 710#endif
711 if (start + count > card->numsectors)
712 panicf("Writing past end of card\n");
705 713
706 if (ret == 0) 714 if (ret == 0)
707 { 715 {
diff --git a/firmware/export/ata_mmc.h b/firmware/export/ata_mmc.h
index 3e88b0e019..957849925b 100644
--- a/firmware/export/ata_mmc.h
+++ b/firmware/export/ata_mmc.h
@@ -33,6 +33,7 @@ typedef struct
33 unsigned int nsac; /* clock cycles */ 33 unsigned int nsac; /* clock cycles */
34 unsigned int tsac; /* n * 0.1 ns */ 34 unsigned int tsac; /* n * 0.1 ns */
35 unsigned int r2w_factor; 35 unsigned int r2w_factor;
36 unsigned int numsectors; /* size in sectors */
36} tCardInfo; 37} tCardInfo;
37 38
38void mmc_select_clock(int card_no); 39void mmc_select_clock(int card_no);