mirror of
https://github.com/Rockbox/rockbox.git
synced 2025-12-08 20:55:17 -05:00
storage: 64-bit sector offsets
* Create new 'sector_t' type alias:
* uint64_t for all targets with HAVE_LBA48 or HAVE_SDUC
* unsigned long for the everything else
* Alter all storage APIs to use sector_t instead of 'unsigned long'
* Alter Volume/Partition/storage info structures to use sector_t
* Disk cache converted to sector_t
* ATA Core:
* convert to using sector_t for sector addresses and drive sizes
* Always fill out upper 16 bits of LBA48 addresses
* IDENTIFY INFO is fixed at 512 bytes, not SECTOR_SIZE
* USB mass storage:
* convert to using sector_t for sector addesses and drive sizes
* Implement READ_16/WRITE_16 for LBA48 addresses
* Convert FAT code to use sector_t for all sector references
* output_dyn_value() now accepts int64_t instead of 'int'
* Corrected "rockbox info" to work for (MULTIVOLUME & !MULTIDRIVE)
* Better reporting of disk and (logical+physical) sector sizes in debug info
* Detect SDUC cards and report on storage debug_info screen
To-do: SDUC
* Refactor SD core to remove duplicate code in every driver
* Card probe and init state machine
* Implement core SDUC support
* SD2.0 needs to be 2.0+ (fixed for jz47xx and x1000)
* Host and Card ID (ACMD41)
* 32-bit addressing for all read/write/erase operations (CMD22)
* ADD SDUC to target device drivers, defining HAVE_SDUC as appropriate
Change-Id: Ib0138781a0081664d11511037685503df1b93608
This commit is contained in:
parent
9ff308a589
commit
15e5237469
49 changed files with 629 additions and 435 deletions
|
|
@ -446,7 +446,7 @@ static int sd_init_card(const int drive)
|
|||
sd_parse_csd(&card_info[drive]);
|
||||
|
||||
#if defined(HAVE_MULTIDRIVE)
|
||||
hs_card = (card_info[drive].speed == 50000000);
|
||||
hs_card = (card_info[drive].speed >= 50000000);
|
||||
#endif
|
||||
|
||||
/* Boost MCICLK to operating speed */
|
||||
|
|
@ -455,7 +455,7 @@ static int sd_init_card(const int drive)
|
|||
#if defined(HAVE_MULTIDRIVE)
|
||||
else
|
||||
/* MCICLK = PCLK/2 = 31MHz(HS) or PCLK/4 = 15.5 Mhz (STD)*/
|
||||
MCI_CLOCK(drive) = (hs_card ? MCI_HALFSPEED : MCI_QUARTERSPEED) |
|
||||
MCI_CLOCK(drive) = (hs_card ? MCI_HALFSPEED : MCI_QUARTERSPEED) |
|
||||
MCI_CLOCK_POWERSAVE; /* SD supports powersave */
|
||||
#endif
|
||||
|
||||
|
|
@ -680,7 +680,7 @@ static int sd_select_bank(signed char bank)
|
|||
return 0;
|
||||
}
|
||||
|
||||
static int sd_transfer_sectors(IF_MD(int drive,) unsigned long start,
|
||||
static int sd_transfer_sectors(IF_MD(int drive,) sector_t start,
|
||||
int count, void* buf, const bool write)
|
||||
{
|
||||
#ifndef HAVE_MULTIDRIVE
|
||||
|
|
@ -735,7 +735,8 @@ static int sd_transfer_sectors(IF_MD(int drive,) unsigned long start,
|
|||
unsigned int transfer = (count >= 128) ? 127 : count; /* sectors */
|
||||
void *dma_buf;
|
||||
|
||||
unsigned long bank_start = start;
|
||||
sector_t bank_start = start;
|
||||
// XXX 64-bit sectors?
|
||||
|
||||
/* Only switch banks for internal storage */
|
||||
if(drive == INTERNAL_AS3525)
|
||||
|
|
@ -869,7 +870,7 @@ sd_transfer_error_nodma:
|
|||
return ret;
|
||||
}
|
||||
|
||||
int sd_read_sectors(IF_MD(int drive,) unsigned long start, int count,
|
||||
int sd_read_sectors(IF_MD(int drive,) sector_t start, int count,
|
||||
void* buf)
|
||||
{
|
||||
int ret;
|
||||
|
|
@ -881,11 +882,11 @@ int sd_read_sectors(IF_MD(int drive,) unsigned long start, int count,
|
|||
return ret;
|
||||
}
|
||||
|
||||
int sd_write_sectors(IF_MD(int drive,) unsigned long start, int count,
|
||||
int sd_write_sectors(IF_MD(int drive,) sector_t start, int count,
|
||||
const void* buf)
|
||||
{
|
||||
#ifdef VERIFY_WRITE
|
||||
unsigned long saved_start = start;
|
||||
sector_t saved_start = start;
|
||||
int saved_count = count;
|
||||
void *saved_buf = (void*)buf;
|
||||
#endif
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue